[Ting's笔记Day3]解决Git常见错误non-fast-forward问题
写文章最难的部分,是找题材!
所以最近每次遇到bug或错误都挺兴奋开心(zflwx)的,因为又可以写笔记了
也可以记录新手学习之路上遇到的常见问题,提供其他新手参考。
最近学Udemy平台Ruby学习在线课程,我在本机练习做了一个Ruby on Rails项目(名称定为:yelpdemo),
我先用subl .叫出Sublime编写项目内的网页,做一点修改后,
再用Terminal按照我自己Day2笔记所说的Git步骤试着同步此项目到Github的同名repository储存库。
前情提要:我再Github的repo是上周设定好的,所以自己有点忘记当初发生什么事~导致接下来的问题
Step1.首先git status
看看目前working directory中所有档案的情形,红色代表这些档案需要被追踪:
Step2.git add .
把以上所有档案交给Git,再输入一次git status,绿色代表已更改为被追踪:
Step3 git commit
git commit -m“first commit”,备注-m里写上“执行第一个提交指令commit”,将staged档案储存到储存库:
然后再输入一次git status:
好了,到这边都挺顺的~
Step4.设定好要加入的路径git remote add origin
git remote add origin https://github.com/(你的帐号)/(你的项目名称):
设定远端origin的repository路径,然后再推送:
git push -u origin master
-u是update的意思,用了参数-u之后,未来就能直接使用不带参数的git pull从以前push过的分支来pull。
如果你没有先git remote add origin就直接git push
就会像我一开始一样,出现了'找不到储存库'的问题喔!
Step5.git push -u origin master
[灯等!]更新被拒绝了,因为上周我在Remote建的的repo里面,有些更动过的档案版本,本地端并没有:
[解决]提示告诉我可以先用git pull,
然后再git push一次:
重点在于最后一行:git push预设会推送「本地分支」到相同文件名的「远端分支」
When push.default is set to 'matching',git will push local branchesto the remote branches that already exist with the same name.
[灯等!]问题再度出现:The current branch master has no upstream branch,表示当前分支主机没有上游分支:
[解决]按照提示,依样画葫芦地git push --set-upstream origin master
[灯等!]新的问题产生,提示说我的master是non-fast forward
这个non-fast forward的意思是本机commit和远端的不相同,本地和远端的Repository发生文件冲突问题(线图有分岔)。
由于上周在远端创建的文件夹内容文件发生改变,因此不允许我把本地的文件覆盖上去。
关于合并local端和remote端,近一步了解可以看git官网,或是连猴子都能懂的Git入门指南解释
在push之前,我需要
git fetch
git merge
将远端的改变用merge合并到本地上。
或是我可以用git push -f强制覆盖本地文件替代git储存库的内容。
Google关键字在stackoverflow找到的解法是
git push -f origin <branch>。
-f代表force:强制推送。如果不想把远端分支的更动合并(merge)到本地分支,则可以使用这个指令。但要小心使用。
[解决]
回到github站上检查,终于同步完成(leafor):
===
后记:
这是写给自己提升记忆的笔记。相信之后如果在本机再建立其他新项目、远端建立储存库并使用gite功能,可能还是会遇到以上类似的问题,身为自学git新新手,我没有直接发问求救,而是靠google增加观念、进而找到解答,因此还蛮开心的!
看了数据,有些工程师的建议是少用git pull,以git fetch和git merge代替。也许以后实作之后有类似的经验和心得,再写点相关的文章。
[Ting's笔记Day3]解决Git常见错误non-fast-forward问题的更多相关文章
- git常见错误及解决方案总结
git常见错误及解决方案总结 使用git在本地创建一个项目的过程 $ makdir ~/hello-world //创建一个项目hello- ...
- Git - 常见错误与解决方案
1.windows使用git时出现:warning: LF will be replaced by CRLF 分析: windows中的换行符为 CRLF, 而在linux下的换行符为LF,所以在执行 ...
- mzy git学习,禁用Fast forward的普通合并(六)
git merge --no-ff -m "msg" x-branch:禁用Fast forward的普通合并 通常,合并分支时,如果可能,Git会用Fast forward模式, ...
- Git分支(2/5) -- Fast Forward 合并
快捷操作: 切换并创建分支: git checkout -b 分支名. git checkout -b some-change 然后我打开某个文件(index.html)修改一下标题. Commit之 ...
- Git 常见错误 之 error:error: src refspec main does not match any/ error: failed to push some refs to 简单解决
错误产生的原因:Github 工程默认名为了 main 由于受到"Black Lives Matter"运动的影响,GitHub 从今年 10 月 1 日起,在该平台上创建的所有新 ...
- git常见错误
一.如果输: $ git remote add origin git@github.com:djqiang(github帐号名)/gitdemo(项目名).git 提示出错信息:fat ...
- (转)git常见错误
如果输入$ Git remote add origin git@github.com:djqiang(github帐号名)/gitdemo(项目名).git 提示出错信息:fatal: remote ...
- 【Git】Git常见错误
错误1.fatal: refusing to merge unrelated histories 致命的:拒绝合并不相关的历史 原因:比如我本地分支是V1.0,我现在想要合并远程master分支上的内 ...
- Git常见错误处理
如果输入$ Git remote add origin git@github.com:djqiang(github帐号名)/gitdemo(项目名).git 提示出错信息:fatal: remo ...
随机推荐
- 录制JMeter脚本的方式
一.使用BadBoy录制JMeter脚本 JMeter和BadBoy下载地址:点击去下载 1.打开BadBoy并输入你要录制脚本的网址 这里我输入百度的网址,可以看到step下已经有一个请求了 2.录 ...
- Python全栈之路----函数----作用域
Python中,一个函数就是一个作用域. 局部变量放置在其作用域中,根据作用域来区分,函数属于你,函数属于我. 定义完成后,作用域已经生成,使用时顺着作用域链向上查找. 函数定义完成后,不管被在哪儿被 ...
- this指向问题 --无return
this的指向在函数定义的时候是确定不了的只有在函数执行的时候才能确定this到底指向谁.this指向上一级对象 1.函数调用,this指向window var color = "red&q ...
- Python数据类型的可变与不可变
首先,我们需要知道在python中哪些是可变数据类型,哪些是不可变数据类型.可变数据类型:列表list和字典dict:不可变数据类型:整型int.浮点型float.字符串型string和元组tuple ...
- django基础 -- 10.form , ModelForm ,modelformset
一.生成页面可用的 HTML标签 1.form 所有内置字段 Field required=True, 是否允许为空 widget=None, HTML插件 label=None, 用于生成Label ...
- c++ CreateProcess调用dos命令
// test.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <windows.h> #include &l ...
- 单源最短路径算法——Dijkstra算法(迪杰斯特拉算法)
一 综述 Dijkstra算法(迪杰斯特拉算法)主要是用于求解有向图中单源最短路径问题.其本质是基于贪心策略的(具体见下文).其基本原理如下: (1)初始化:集合vertex_set初始为{sourc ...
- 纯CSS制作图形效果
下面所有的例子都是在demo.html的基础上添加相关样式实现的. <!DOCTYPE html> <html> <head> <meta charset=& ...
- 关于分布式uuid的一点设想
在一次公开课上,听别人讲过全局分布式uuid的设计,听过twitter的snowflake的设计.也听过,如果使用单独的计数器服务,不可能每次都保存当前计数器到文本,自己想到应该可以每隔一些数,例如1 ...
- Python发送微信消息
针对此 需要安装itchat第三方模块 采用pip安装就可以了 pip install itchat import itchatimport time#引入时间函数进行测试time_format= ...