git 及其基本操作

git与github

  1. 首先gitgithub不是同一个东西。Git是一款免费、开源的分布式版本控制系统,而github是基于git代码托管平台且同时也具有版本记忆功能。
  2. git是分布式版本管理系统。
  3. git是由linux的创造者linus开发的。
  4. 不同于CVSSVN的集中式版本控制方式,git使用分布式进行版本控制。将较而言,git分布式版本控制可以实现本地化的版本库,工作时不必联网;git具有强大的分支管理能力,稳定性更高。(便捷)

git首次安装后的设置

首先打开hash.exe输入用户名和邮箱

//配置全局用户信息
$ git config --global user.name "Your Name"
$ git config --global user.email "email@example.com"
//修改当前用户信息
$ git config user.name 你的目标用户名;
$ git config user.email 你的目标邮箱名;

利用git本地仓库进行版本控制可以简单的理解为:a 持有实际文件的物理工作目录,b 暂存区,c 本地仓库(git在本地默认建立的一个master分支)

其中a-->b是由add实现,而b-->c是由commit实现。

利用git在本地进行版本库存储

  1. git在本地指定地点建立仓库(或者是指向克隆下来的仓库):

        cd e:/github_projects/tisikcci.github.io
  2. 初始化一个git仓库:

         init

    初始化之后,会在tisikcci.github.io文件夹下生成一个默认隐藏的.git文件夹

    添加远程库:在本地的learngit仓库下运行命令:$ git remote add origin 仓库地址

  3. 向这个隐藏的文件夹中添加文件:README.md(可以是别的文件,要将这个文件放在.git同级文件夹下):

         git add README.md

    也可以一次添加多个文件,类似于:

            git add README1.md README2.md README3.md
  4. 将文件存入本地仓库(当前分支),同时添加改动或者说是更新说明:(-m后这里的‘first commit’应该是与本次提交或者更新有关系有实际意义的说明,方便以后溯源)

    git commit -m'first commit'
  5. 在上面的3,4步骤过程后可以使用以下命令看到内容的变动

        git status

    第一次提交时:git push -u origin master

  6. 可以使用以下代码查看git版本库的修改或者说是更新次数(使用q可以退出这个命令)

           git log

    如果觉得这样得到的信息太多,可以使用下面的命令,使得每次修改信息漂亮的显示在同一行

           git log --pretty=oneline

    也可以选定查看最近2次的版本更新信息:

           git log -n 2            
  7. 可以利用reset实现版本回退:

           git reset --hard head^

    注意:HEAD表示当前版本(就是一个指针),在后面加一个^,表示(指向)上一个版本,前第N个版本是HEAD~N,回退以后想恢复之前最新的版本或者是某次特定的版本,可以利用如下代码查找操作代码库的关键步骤 历史记录的ID实现:

           git reflog

    根据ID,比如是441736f,前进到回退前的某个版本

           git reset --hard 441736f
  8. commit之后又对项目中的某个文件内容进行了更新,可以利用以下命令回到离commit最近的状态(就是丢弃掉没有进行add操作的更改内容,回到上次commit操作时的状态

           git checkout -- 文件名 

    这里本质是利用本地版本库中的相同文件替换了本地文件夹中的文件,所以看起来是回到之前commit操作时的状态了(但是如果更改已经add了,除非放弃add操作内容,否则下次commit又会更新本地仓库)。更进一步,撤销已经add到暂存区但没有commit到本地分支的文件

           git reset head 文件名

    以上过程中可以使用以下命令查看具体文件的内容

           cat 文件名
  9. 删除本地版本库中的文件
    首先说一下一种特殊情况:本地的文件夹中的项目相关文件被删除了,但没有更新本地的版本库,如果这时想恢复被删除的项目相关文件,可以利用以下命令:

           git checkout -- 文件名

    第二种情况是真的想删除本地仓库中的相关文件,利用以下代码删除本地文件夹中的文件(也可以手动删除)

           rm 文件名

    然后利用以下代码删除本地仓库中的文件

           git  rm 文件名

    并且利用git commit进行保存

           git commit -m"remove 文件名"         
    
  10. 新建一个分支,可以利用

           git branch 分支名
           git checkout 分支名

    上面的代码分别表示新建一个分支,并将head(指针)指向新建的指针,也可以使用下面的方式直接
    实现新建一个分支并使head指向它

           git checkout -b 分支名

    可以利用下面的命令分别查看本地分支,远程分支和所有分支,当前指向分支前会加*号

           git branch<br>git branch -r<br>git branch -a

    删除已经存在的指定本地分支,远程分支(注意要先将指针指向其他分支才能删除此分支)

           git branch -d 分支名
           git push origin :分支名

    重命名分支

           git branch -m 原分支名 新分支名
    
  11. 在新分支上提交内容,对之前的主分支master并不会有影响,可以利用如下方式再切换回主分支

           git checkout master

    此时head会重新指向master,将master替换为别的分支,可以实现切换到任意指定分支

  12. 将新建立的分支合并到主分支(首先要切换回主分支)

           git merge 新分支

    合并后,就可以利用上面给出的方法删除新分支

  13. 如果想保留新建的分支,并推送到远程仓库,可以利用

           git push origin 新建的分支
  14. 可以给项目进度添加版本号,通过添加标签的方式实现

           git tag 版本号

    通过省略版本号可以直接查看已经添加的版本号

           git tag

    可以给以前的某次提交补加版本号,只要查找到之前commit操作对应的ID,比如:441736f

           git tag 版本号 441736f

    可以利用如下的方式实现在添加标签时添加说明

           git tag -a 版本号 -m "版本说明"

    可以通过以下命令查看指定版本内容

           git show 版本号

    删除不想要的标签

           git tag -d 已经存在的标签(版本号)

    可以将本地标签推送到远程仓库

           git push 远程主机名(比如origin) 版本号

    比如:

           git push origin v1.0

    将本地所有的版本号都推送到远程仓库

           git push origin --tags

    如果想删除远程仓库的版本号,需要进行两步
    a. 首先要删除本地版本号(标签)
    b. 再删除远程版本号

    git push origin :refs/tags/版本号

利用以上步骤,基本可以实现利用git本地进行操作,以下要实现将本地git仓库同步到远程仓库(例如github,当然也可以自己在一台PC上搭建一个服务器,作为远程仓库)

利用github充当远程仓库是一种很不错的方式,git本地仓库和github可以通过SSH加密,利用多种方式进行数据传输:HTTP(s)、SSH、Git、本地协议等,前两种比较常用。

本地git仓库同步到远程仓库

  1. 要想将本地仓库同步到Github上,首先需要建立本地和Github上使用的SSH私钥和公钥,在git的bash.exe中输入
    ssh-keygen -t rsa -C “tisikcci@foxmail.com
    这样在用户下的.ssh目录里就可以创建id_rsaid_rsa.pub这两个文件,一路回车《git 及其基本操作》
  2. 在电脑上生成公钥和私钥,将公钥上传到github
    登录Github,找到右上角的图标,打开点进里面的Settings,再选中里面的SSH and GPG KEYS,点击右上角的New SSH key,然后Title里面随便填,再把刚才id_rsa.pub里面的内容复制到Title下面的Key内容框里面,最后点击Add SSH key,这样就完成了SSH Key的加密
  3. 测试是否连接成功

    ssh -T git@github.com
  4. Github上建立一个你想和本地仓库进行同名的仓库(名字相同)
  5. 利用上面的cd...指向本地仓库的位置,然后关联到Github的远程仓库:

             git remote add origin git@github.com:tisikcci/tisikcci.github.com.git
  6. 关联好之后,可以把本地仓库中的内容推送到Github上的远程仓库了
    在首次进行推送的时候,需要:

             git pull --rebase origin master(如果初始化的仓库有文件比如README要先和本地合并)
             git push -u origin master

    此处加 -u 是用来将本地master和远程master进行关联的,以后再次推送就不需要再加了,origin是远程主机的名字,可以通过以下代码来查看

             git remote

    或者是

             git remote -v

    这个主机名字是可以人为指定的。首次推送之后,下次再向远程仓库master分支推送项目时,只需要

               git push origin master
  7. 上面提到可以人为指定远程主机的名字,在将远程仓库克隆到本地的时候,可以实现

           git clone -o 新主机名 https://github.com/tisikcci/first-static-web-page.git/

    如果使用默认的主机名并且克隆到本地指定的位置,可以利用

           git clone https://github.com/tisikcci/first-static-web-page.git/ 

    本地地址
    最好是直接利用SSH协议进行clone,如下

           git clone 仓库的SSH地址  本地建立的空文件夹地址
           git clone git@github.com:tisikcci/test.git e:/github_projects/zz

    就将远程仓库的test克隆到了本地的zz文件夹中。

远程仓库同步本地git仓库

git pull命令

git pull命令用于从另一个存储库或本地分支获取并集成(整合)。git pull命令的作用是:取回远程主机某个分支的更新,再与本地的指定分支合并,它的完整格式稍稍有点复杂

使用语法

git pull [options] [<repository> [<refspec>…]]

描述

将远程存储库中的更改合并到当前分支中。在默认模式下,git pullgit fetch后跟git merge FETCH_HEAD的缩写。

更准确地说,git pull使用给定的参数运行git fetch,并调用git merge将检索到的分支头合并到当前分支中。 使用–rebase,它运行git rebase而不是git merge。

示例

$ git pull <远程主机名> <远程分支名>:<本地分支名>

比如,要取回origin主机的next分支,与本地的master分支合并,需要写成下面这样 –

$ git pull origin next:master

如果远程分支(next)要与当前分支合并,则冒号后面的部分可以省略。上面命令可以简写为:

$ git pull origin next

上面命令表示,取回origin/next分支,再与当前分支合并。实质上,这等同于先做git fetch,再执行git merge

$ git fetch origin
$ git merge origin/next

在某些场合,Git会自动在本地分支与远程分支之间,建立一种
追踪关系(tracking)。比如,在
git clone的时候,所有本地分支默认与远程主机的同名分支,建立追踪关系,也就是说,本地的master分支自动”追踪”
origin/master分支。

Git也允许手动建立追踪关系。

$ git branch --set-upstream master origin/next

上面命令指定master分支追踪origin/next分支。

如果当前分支与远程分支存在追踪关系,git pull就可以省略远程分支名。

$ git pull origin

上面命令表示,本地的当前分支自动与对应的origin主机”追踪分支”(remote-tracking branch)进行合并。

如果当前分支只有一个追踪分支,连远程主机名都可以省略。

$ git pull

上面命令表示,当前分支自动与唯一一个追踪分支进行合并。

如果合并需要采用rebase模式,可以使用–rebase选项(rebase可查看下文)。

$ git pull --rebase <远程主机名> <远程分支名>:<本地分支名>

git fetchgit pull的区别

  1. git fetch:相当于是从远程获取最新版本到本地,不会自动合并。

           $ git fetch origin master
           $ git log -p master..origin/master
           $ git merge origin/master

以上命令的含义:

 - 首先从远程的`origin`的`master`主分支下载最新的版本到`origin/master`分支上
 - 然后比较本地的`master`分支和`origin/master`分支的差别
 - 最后进行合并
 

上述过程其实可以用以下更清晰的方式来进行:

        $ git fetch origin master:tmp
        $ git diff tmp 
        $ git merge tmp    
  1. git pull:相当于是从远程获取最新版本并merge到本地

           git pull origin master
    

上述命令其实相当于git fetchgit merge
在实际使用中,git fetch更安全一些,因为在merge前,我们可以查看更新情况,然后再决定是否合并。

rebase模式

假设你现在基于远程分支"origin",创建一个叫"mywork"的分支。

$ git checkout -b mywork origin

《git 及其基本操作》

现在我们在这个分支做一些修改,然后生成两个提交(commit).

$ vi file.txt  
$ git commit
$ vi otherfile.txt
$ git commit
//vi命令是UNIX操作系统和类UNIX操作系统中最通用的全屏幕纯文本编辑器。Linux中的vi编辑器叫vim,它是vi的增强版(vi Improved),与vi编辑器完全兼容,而且实现了很多增强功能

但是与此同时,有些人也在"origin"分支上做了一些修改并且做了提交了. 这就意味着"origin""mywork"这两个分支各自”前进”了,它们之间”分叉”了。

《git 及其基本操作》

在这里,你可以用"pull"命令把"origin"分支上的修改拉下来并且和你的修改合并; 结果看起来就像一个新的"合并的提交"(merge commit):

《git 及其基本操作》

但是,如果你想让"mywork"分支历史看起来像没有经过任何合并一样,你也许可以用 git rebase:

$ git checkout mywork
$ git rebase origin

这些命令会把你的"mywork"分支里的每个提交(commit)取消掉,并且把它们临时保存为补丁(patch)(这些补丁放到”.git/rebase”目录中),然后把"mywork"分支更新到最新的"origin"分支,最后把保存的这些补丁应用到"mywork"分支上。

《git 及其基本操作》

'mywork'分支更新之后,它会指向这些新创建的提交(commit),而那些老的提交会被丢弃。 如果运行垃圾收集命令(pruning garbage collection), 这些被丢弃的提交就会删除. (请查看 git gc)

现在我们可以看一下用合并(merge)rebase所产生的历史的区别

《git 及其基本操作》

rebase的过程中,也许会出现冲突(conflict). 在这种情况,Git会停止rebase并会让你去解决 冲突;在解决完冲突后,用"git-add"命令去更新这些内容的索引(index), 然后,你无需执行 git-commit,只要执行:

$ git rebase --continue

这样git会继续应用(apply)余下的补丁。
在任何时候,你可以用--abort参数来终止rebase的行动,并且"mywork" 分支会回到rebase开始前的状态。

$ git rebase --abort

如何多人协作开发

多人协作开发,就不能使用master分支了,而是要每个开发者单独拉一个分支,使用git checkout -b <branchname>,运行git branch可以看到本地所有的分支名称。

自己的分支,如果想同步master分支的内容,可运行git merge master。切换分支可使用git checkout <branchname>

在自己的分支上修改了内容,可以将自己的分支提交到远程服务器

git checkout -b <branchname> //创建并切换分支
git add .
git commit -m "xxx"
git push origin <branchname>

最后,待代码测试没问题,再将自己分支的内容合并到master分支,然后提交到远程服务器。

git checkout master  //切换分支
git merge <branchname>  //合并分支
git push origin master...

详细版
首先,我们创建dev分支,然后切换到dev分支:

$ git checkout -b dev
Switched to a new branch 'dev'

git checkout命令加上-b参数表示创建并切换,相当于以下两条命令:

$ git branch dev
$ git checkout dev
Switched to branch 'dev'

然后,用git branch命令查看当前分支:

$ git branch
* dev
  master

git branch命令会列出所有分支,当前分支前面会标一个*号。

然后,我们就可以在dev分支上正常提交,比如对readme.txt做个修改,加上一行:

Creating a new branch is quick.

然后提交:

$ git add readme.txt 
$ git commit -m "branch test"
[dev b17d20e] branch test
 1 file changed, 1 insertion(+)

现在,dev分支的工作完成,我们就可以切换回master分支:

$ git checkout master
Switched to branch 'master'

切换回master分支后,再查看一个readme.txt文件,刚才添加的内容不见了!因为那个提交是在dev分支上,而master分支此刻的提交点并没有变.
现在,我们把dev分支的工作成果合并到master分支上:

$ git merge dev
Updating d46f35e..b17d20e
Fast-forward
 readme.txt | 1 +
 1 file changed, 1 insertion(+)

git merge命令用于合并指定分支到当前分支。合并后,再查看readme.txt的内容,就可以看到,和dev分支的最新提交是完全一样的。

注意到上面的
Fast-forward信息,
Git告诉我们,这次合并是“
快进模式”,也就是直接把
master指向
dev的当前提交,所以合并速度非常快。

当然,也不是每次合并都能Fast-forward,我们后面会讲其他方式的合并。

合并完成后,就可以放心地删除dev分支了:

$ git branch -d dev
Deleted branch dev (was b17d20e).

删除后,查看branch,就只剩下master分支了:

$ git branch
* master

因为创建、合并和删除分支非常快,所以Git鼓励你使用分支完成某个任务,合并后再删掉分支,这和直接在master分支上工作效果是一样的,但过程更安全。

git版本回退

  1. git reset –hard HEAD ^   ( ^ 表示回到上一个版本,回退几个版本后面就跟几个^,或git reset –hard HEAD~3,回退3个版本 );
  2. git reset –hard 版本号

git本地分支同步远程分支

远程先创建分支然后拉到本地维护

git checkout -b [本地分支名] origin/[远程分支名]    //检出远程分支到本地一般设置一样的名字

本地先创建分支然后推送到远程

git checkout -b [本地分支名]    //创建并切换到分支  
git push origin [远程分支名]:[本地分支名]  (--force 强制)  //推送本地的分支(没有会自动创建)

git 重命名本地分支,并提交到远程

  1. 重命名 git branch -m oldBranchName newBranchName
  2. 删除远程分支:git push origin oldBranchName
  3. 将重命名过的分支提交:git push origin newBranchName

git 合并某个提交commit到指定的分支上

B分支的commitInfo 提交 合并到 A分支上

  1. git checkout B,来到B分支;
  2. git log查找并记住commitInfo的提交id;
  3. git checkout A切换到A分支;
  4. git cherry-pick commit_id.

小结

Git鼓励大量使用分支:

查看分支:git branch

创建分支:git branch <name>

切换分支:git checkout <name>

创建+切换分支:git checkout -b <name>

合并某分支到当前分支:git merge <name>

删除分支:git branch -d <name>

绑定本地分支到远程服务器分支: git branch --set-upstream-to origin/[远程分支名] [本地分支名]

推送本地更新到远程分支: git push <远程库名>(origin) [本地分支名]:[远程分支名]

克隆远程分支:git clone -b [远程分支名] [远程仓库地址]

获取远程服务器的指定分支: git pull <远程库名>(origin) <远程分支名>:<本地分支名>

参考链接:

    原文作者:Mr_zhang
    原文地址: https://segmentfault.com/a/1190000011171610
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞