(自己记录的一些git 使用方法,可能有错误,不喜勿喷,有什么问题希望多多指点,适合初学git 者观看)
一、SSH 配置公钥的问题
如果你是跟着廖雪峰的博客学Git的。先在本地创建了个仓库,并且你git init , git add . ,git commit 巴拉巴拉的,敲了一大堆。然后当你进行本地仓库跟远程仓库链接之后。执行git push origin master 命令进行push 出现这个问题。
是因为GitHub上创建仓库的时候生成的README.md文件与本地的README.md冲突了。只需要在终端使用命令git pull –r origin master 再push 就好了。
如果错误关联了远程仓库,想要取消关联使用命令git remote remove origin,就移除你跟关联着的远程仓库的联系关系了。
------------===================---------=========---------=========-------
Could not read from remote repository 这个问题是因为 github 上,没有创建SSH key
如何创建 SSH key :
1.配置本机的user name 和 email
git config --global user.email "12344@163.com"
git config --global user.name "账号" 可以直接设置git仓库的分支账号密码
2)生成密钥:
$ ssh-keygen -t rsa -C “haiyan.xu.vip@gmail.com”(请填你设置的邮箱地址)
按3个回车,密码设置的最少5个字符。
然后系统会自动在.ssh文件夹下生成两个文件,id_rsa和id_rsa.pub
(出现如上图所示就说明操作正确了)
3. cat ~/.ssh/id_rsa.pub : 获取到id_rsa.pub 文件里的内容讲其全部复制下来。(包括ssh-rsa 和结尾处的你的邮箱)
4.在.ssh 文件夹中执行 ssh-add id_rsa 再次输入之前输入的密码
5.设置github 上的SSH (操作三连图)
点 add SSH key 就设置完成了。
-------------------------------------------------------------------------------------
二、自己在分支上的开发历史保留
通常,合并分支时,如果可能,Git会用Fast forward模式,但这种模式下,删除分支后,会丢掉分支信息。如果要强制禁用Fast forward模式,Git就会在merge时生成一个新的commit,这样,从分支历史上就可以看出分支信息
准备合并dev分支,请注意--no-ff参数,表示禁用Fast forward:
git merge --no-ff -m "merge with no-ff" dev :合并dev 分支并且不会删除dev分支的历史记录
因为本次合并要创建一个新的commit,所以加上-m参数,把commit描述写进去。
-------------------------------------------------------------------
三、多人协作模式
现在,你的小伙伴要在dev分支上开发,就必须创建远程origin的dev分支到本地,于是他用这个命令创建本地dev分支:
git checkout -b dev origin/dev : 创建远程origin 分支下的dev 分支
现在你的小伙伴就可以在 dev 分支上修改,时不时的push dev 分支到远程仓库
一般多人协作实战开发时的场景一般是:
首先,可以试图用git push origin 推送自己的修改;
如果推送失败,则因为远程分支比你的本地更新,需要先用git pull试图合并;
如果合并有冲突,则解决冲突,并在本地提交;
没有冲突或者解决掉冲突后,再用git push origin 推送就能成功!
如果git pull提示no tracking information,则说明本地分支和远程分支的链接关系没有创建,用命令git branch --set-upstream-to origin/。
--------------------------------------------------
(还有一些Bug 分支功能, Feature 分支功能,感觉目前也用不上,就不写了,但是知道有这么个东西,以后需要的话就去廖雪峰的git 教学官网上查看就可以了。)
git rebase : 把提交历史整理成一条直线。(额 ,更好看)。详情请看廖大神
git config --global alias.st status :设置 st 就代表命令 status ,把git 命令简单化,其他的git 命令想修改都是一样的道理。
-----------------------------===============----------------
四、git 使用到的命令记录
(本地仓库的一些操作)
mkdir learngit : mkdir 命令是在当前目录下创建一个文件夹
ls -ah : .git 文件默认是隐藏的,ls -ah 命令就可以看见这个文件夹了
pwd : 显示当前文件的路径
git init : 把这个目录变成git 可以管理的仓库
vi readme.txt : 创建一个TXT 文件
git add readme.txt : 用命令 git add 告诉Git ,把文件添加到仓库
git commit -m 'wrote a readme.txt file' : 用命令git commit 告诉Git ,把文件添加到仓库
git config --global user.email "12344@163.com"
git config --global user.name "账号" 可以直接设置git仓库的分支账号密码
git status : 时刻掌握仓库当前的状态 ,告诉你那个文件被改动过了
git diff file1 : 查看文件file1 具体什么地方被改动了。
git diff HEAD --learngit.txt : 查看工作区跟版本儿库里最新版本儿的区别。
git log : 查看历史版本
git log --pretty=oneline : 查看历史版本的时候加上 --pretty=oneline 显示的就是你每次 提交版本的时候加的注释,看起来简洁一些。
git reset --hard HEAD^ : 回退到上一个版本儿, 回退到上两个版本儿: HEAD^^ ,回退到上100个版本:HEAD~100
git reset HEAD readme.txt : 把文件readme.txt 暂存区的修改撤销掉,放回工作区,这样如果再执行 git checkout -- readme.txt 的话,就可以把修改撤销了。
git reset --hard 1923a : 这是如果你回退一个版本,只要你知道回退之前的版本号1923a,(这是版本号的前几位,版本号写前几位就行了,没必要写全)就可以回到未来,git 就是这么神奇。
cat file1 : 查看file1 这个文件里的内容。
git reflog 记录你之前用过的命令。如果你回退到了某个版本儿,关机之后,第二天再想回到未来的版本儿,发现找不到commit id 了,你就可以使用这个命令,查看你之前打过哪些命令。所以说在git 里,总有一款后悔药,适合你吃的。
git 版本儿管理系统追踪的是修改,而不是文件。commit 只会提交add 过的文件内的差异,没有add 到缓存区的文件的修改,都不会提交。
git checkout -- file :撤回修改,就是撤回文件最近修改的内容,撤回工作区的修改,只要add 到了缓存区,就checkout 不了了。
rm file : 删除一个文件 就用 rm 命令
git rm file : 删除版本儿库里的file 文件
(远程仓库的一些操作)
$ ssh-keygen -t rsa -C “haiyan.xu.vip@gmail.com”(请填你设置的邮箱地址):生成秘钥
git remote remove origin : 移除关联的远程仓库
git remote add origin git@github.com:michekdh/learngit.git : 关联远程仓库
git push origin master : 提交本地仓库的代码到远程仓库
git pull -r origin master : 拉取远程仓库上的东西到本地
git clone git@github.com:michekdh/learngit.git :( 这个远程仓库地址换成自己的)克隆远程仓库到本地。先创建远程仓库,再创建本地仓库。
----------------------------------------------------------------------------------------
(远程库分支的一些操作)
git remote : 查看远程仓库信息。
git remote -v 显示远程仓库更详细的信息。
git checkout -b dev : 创建 dev 分支,并切换到 dev 分支 。相当于两条命令:git branch dev ,git checkout dev
git branch : 分支查看,查看一共有多少分支,现在处在哪个分支上。
git merge dev : 把dev 分支上的成果合并到当前分支上(如果你要想把dev 分支上的东西合并到master 分支,你就应该在master 分支上进行这个命令操作)。分支有冲突的话,就可以直接打开冲突文件进去手动修改。
git branch -d dev : 删除dev 分支,需要你先 git checkout master 切换到主分支上再删除dev分支
git log --graph --pretty=oneline --abbrev-commit : 可以查看分支合并情况
git log --graph : 查看分支合并图。
git merge --no-ff -m "merge with no-ff" dev :合并dev 分支并且不会删除dev分支的历史记录(准备合并dev分支,请注意--no-ff参数,表示禁用Fast forward:)
git branch --set-upstream branch-name origin/branch-name : 建立本地分支和远程分支的关联。