写文章最难的部分,是找题材!

所以最近每次遇到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问题的更多相关文章

  1. git常见错误及解决方案总结

    git常见错误及解决方案总结 使用git在本地创建一个项目的过程  $ makdir ~/hello-world                              //创建一个项目hello- ...

  2. Git - 常见错误与解决方案

    1.windows使用git时出现:warning: LF will be replaced by CRLF 分析: windows中的换行符为 CRLF, 而在linux下的换行符为LF,所以在执行 ...

  3. mzy git学习,禁用Fast forward的普通合并(六)

    git merge --no-ff -m "msg" x-branch:禁用Fast forward的普通合并 通常,合并分支时,如果可能,Git会用Fast forward模式, ...

  4. Git分支(2/5) -- Fast Forward 合并

    快捷操作: 切换并创建分支: git checkout -b 分支名. git checkout -b some-change 然后我打开某个文件(index.html)修改一下标题. Commit之 ...

  5. 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 日起,在该平台上创建的所有新 ...

  6. git常见错误

    一.如果输: $ git remote add origin git@github.com:djqiang(github帐号名)/gitdemo(项目名).git         提示出错信息:fat ...

  7. (转)git常见错误

    如果输入$ Git remote add origin git@github.com:djqiang(github帐号名)/gitdemo(项目名).git 提示出错信息:fatal: remote ...

  8. 【Git】Git常见错误

    错误1.fatal: refusing to merge unrelated histories 致命的:拒绝合并不相关的历史 原因:比如我本地分支是V1.0,我现在想要合并远程master分支上的内 ...

  9. Git常见错误处理

      如果输入$ Git remote add origin git@github.com:djqiang(github帐号名)/gitdemo(项目名).git  提示出错信息:fatal: remo ...

随机推荐

  1. XQuery:查询任何可作为 XML 形态呈现的数据,包括数据库

    XQuery 也被称为 XML Query,被设计用来查询 XML 数据. 学习这个 需要知道 HTML / XHTML XML / XML 命名空间 XPath XML 实例文档 我们将在下面的例子 ...

  2. 1.5 pycharm使用

    1.5 pycharm使用 前言    在写脚本之前,先要找个顺手的写脚本工具.python是一门解释性编程语言,所以一般把写python的工具叫解释器.写python脚本的工具很多,小编这里就不一一 ...

  3. iOS tableView分割线高度自定义

    1.系统自带的集中分割线的形式 myTableView.separatorStyle=UITableViewCellSeparatorStyleNone;(这个是去掉所有分割线)可以通过这个来设置 2 ...

  4. 【leetcode】427. Construct Quad Tree

    problem 427. Construct Quad Tree 参考 1. Leetcode_427. Construct Quad Tree; 完

  5. django中向用户发送邮件信息

    发送邮件来让用户激活,因此,邮件中需要包含用户信息.但用户信息需要加密才可以.因此加密采用的是itsdangerous中的TimedJSONWebSignatureSerializer. 参考链接:h ...

  6. spring boot 之 spring task(定时任务)

    cron:通过表达式来配置任务执行时间cron表达式详解 一个cron表达式有至少6个(也可能7个)有空格分隔的时间元素.按顺序依次为: 秒(0~59)分钟(0~59)3 小时(0~23)4  天(0 ...

  7. java实现四则运算应用(基于控制台)

    项目地址:https://gitee.com/wxrqforever/object_oriented_exp1.git 一.需求分析: 一个基于控制台的四则运算系统,要能实现生成并计算含有真,假分数, ...

  8. ubuntu 16.04 安装 网易云

    现在网易云官网上下载对应版本 文件名:netease-cloud-music_1.0.0-2_amd64_ubuntu16.04.deb 进入下载目录: 正常安装会出现错误 解决的办法是换源 换源教程 ...

  9. systemd service 设置limit,不生效问题

    参考博文: http://smilejay.com/2016/06/centos-7-systemd-conf-limits/(解决方法参考此博文)   问题简述:Centos7下修改系统的最大文件打 ...

  10. pyhdfs安装

    参考: http://blog.csdn.net/sinat_33741547/article/details/54428726 1.先更新pip,防止版本过低pip install --upgrad ...