git 版本管理配置和常用命令


(自己记录的一些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 "[email protected]"

git config --global user.name "账号"    可以直接设置git仓库的分支账号密码

2)生成密钥:

$ ssh-keygen -t rsa -C “[email protected]”(请填你设置的邮箱地址)

按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 "[email protected]"

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 “[email protected]”(请填你设置的邮箱地址):生成秘钥

git remote remove origin : 移除关联的远程仓库

git remote add origin [email protected]:michekdh/learngit.git : 关联远程仓库

git push origin master  :  提交本地仓库的代码到远程仓库

git pull -r origin master : 拉取远程仓库上的东西到本地

git clone   [email protected]: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 : 建立本地分支和远程分支的关联。

你可能感兴趣的:(git 版本管理配置和常用命令)