Git基础知识教程整理(Git基本操作)

Git简介

Git是目前世界上最先进的分布式版本控制系统(没有之一)。
Linux之父Linux用C语言写了Git分布式版本控制系统。

分布式版本控制系统与集中式版本控制系统的区别

区别分布式集中式
中央服务器有,版本库集中存放在中央服务器,工作时需从中央服务器获取最新版本代码,工作完成后在将代码推送到中央服务器。中央服务器出了问题,开发者几乎无法工作无,开发人员本地都有本地存储库(Local Repository)
联网必须,必须要联网才能工作,而且对网络的依赖性较强,网络较差或者文件较大,文件提交的速度会受很大的限制不是必要的,在没有网络的情况下也可以执行commit、查看版本提交记录、以及分支操作,在有网络的情况下执行 push 将代码从本地仓库推送到远程仓库(Remote Repository)。
存储格式原始文件,体积大元数据,体积小
分支操作创建新的分支则所有的人都会拥有和你一样的分支分支操作不会影响其他开发人员
提交方式直接提交到中央版本库先commit到本地仓库,再push到远程仓库
优点方便管理,逻辑明确,上手快;更能保证代码的安全性;代码一致性非常高;有良好的目录级权限控制系统速度快、灵活,分支之间可以任意切换;单机合并分支,开发者之间容易解决冲突;可离线工作,不影响本地代码编写;公共服务器压力小,数据传输量少
缺点服务器性能要求高,数据体量大;必须联网;不适合开源;分支管理不灵活不符合常规思维,学习周期相对较长;代码保密性差,一旦开发者把整个库克隆下来就可以完全公开所有代码和版本信息。

创建版本库

  1. 创建一个项目目录(mkdir Git)
  2. 进入到这个目录(cd Git)
  3. 初始化版本库(git init)

在当前目录下会有.git的目录,它是git进行跟踪和管理版本库,禁止删改此文件(如果没看到可能是您的电脑不显示隐藏文件,在命令行工具运行 ls -ah可查看)。

$ mkdir Git
$ cd Git
$ git init
// Initialized empty Git repository in /Users/zhengdahua/Documents/Project/Private/Git/.git/ 初始化空的版本库
  1. 编写一个README.md文件
  2. 将README.md添加到暂存区(git add README.md)
  3. 确认提交文件到仓库(git commit -m 'add example file')

我们当前的项目目录是工作区,git初始化之后会生成一个.git文件,即我们所说的版本库(respository),.git中有一个index文件就是暂存区(stage),git还为我们自动生成了一个分支master以及指向该分支的指针head。想了解更多,请移步git工作区、暂存区、版本库之间的关系

$ type nul>README.md
$ git add README.md
$ git commit -m 'add example file'

版本回退

  • 查看版本库的状态(git status)。下面的命令输出告诉我们,document.md被修改过了,但还没有提交。
➜  Git git:(master) git status 
On branch master
Changes not staged for commit:
  (use "git add <file>..." to update what will be committed)
  (use "git checkout -- <file>..." to discard changes in working directory)

        modified:   docs/document.md

no changes added to commit (use "git add" and/or "git commit -a")
➜  Git git:(master) ✗
  • 比较两次修改的差异(git diff)。“-”后面跟的是删除的内容,“+”后面跟的是新增的内容
-### 4. 编写一个README.md文件
-### 5. 将README.md添加到暂存区(git add README.md)
-### 6. 确认提交文件到仓库(git commit -m 'add example file')
++ 4. 编写一个README.md文件
++ 5. 将README.md添加到暂存区(git add README.md)
  • 查看提交日志(git log)。显示从最近到最远的提交日志
commit 241f77158c2d59b0b10e482b74a24150a0bebeb4 (HEAD -> master)
Author: kevin <[email protected]>
Date:   Sun Feb 24 22:24:51 2019 +0800

    update document.md

commit f953ccc298a430939e5e64eeedd49cc2db5a3fdb
Author: kevin <[email protected]>
Date:   Sun Feb 24 21:43:08 2019 +0800
  • 回退版本(git reset --hard HEAD^)。用HEAD表示当前版本,则HEAD^就是上个版本,HEAD^表示上上个版本,HEAD~100表示上一百个版本,“241f77158c2d59b0b10e482b74a24150a0bebeb4”指的是版本的id,我们要回退到指定版本是只需要id的前几位就行,但最好5位以上。回退指定版本(git reset --hard f953c)。
  • 查看所有分支的版本操作记录(git reflog)。当你用$ git reset --hard HEAD^回退到以前版本时,再想恢复到append GPL,就必须找到append GPL的commit id,通过git reflog就可以append GPL的commit id了。
241f771 (HEAD -> master) HEAD@{0}: reset: moving to 241f771
f953ccc HEAD@{1}: reset: moving to HEAD^
241f771 (HEAD -> master) HEAD@{2}: commit: update document.md
f953ccc HEAD@{3}: commit (amend): add first file
bd07a32 HEAD@{4}: commit (amend): add first file
98f7467 HEAD@{5}: commit (initial): add first file

修改管理

Git 并不跟踪与文件相关的文件名和目录名,而是跟踪的是文件的内容,查看Git 追踪内容详解。因此文件的每一次修改,都需要git add添加到暂存区,然后在commit到版本库。

  • 修改撤销(git checkout -- README.md)。这里有两种情况:一种是README.md自修改后还没有被放到暂存区,现在,撤销修改就回到和版本库一模一样的状态;一种是readme.txt已经添加到暂存区后,又作了修改,现在,撤销修改就回到添加到暂存区后的状态。总之,就是让这个文件回到最近一次git commit或git add时的状态。
  • 删除文件。工作区直接删除文件,提交到版本库。

远程仓库

为了能在任意 Git 项目上协作,你需要知道如何管理自己的远程仓库。 远程仓库是指托管在因特网或其他网络中的你的项目的版本库,例如github、gitlab、码云或者你自己用服务器搭建的远程仓库。 你可以有好几个远程仓库,通常有些仓库对你只读,有些则可以读写。 与他人协作涉及管理远程仓库以及根据需要推送或拉取数据。 管理远程仓库包括了解如何添加远程仓库、移除无效的远程仓库、管理不同的远程分支并定义它们是否被跟踪等等。

创建SSH Key 。

在用户目录下查看有没有.ssh文件目录(电脑需要显示隐藏文件),如果有再查看有没有id_rsa(私匙)和id_rsa.pub(公匙)。有直接跳过第一步,没有则创建SSH Key,邮箱换成你自己的邮箱,一路回车即可。

$ ssh-keygen -t rsa -C "[email protected]"

上传公钥

登陆GitHub,打开“Account settings”,“SSH Keys”页面;然后,点“Add SSH Key”,填上任意Title,在Key文本框里粘贴id_rsa.pub文件的内容。

注:Github通过公钥识别你的身份,确认只有你自己才能推送。GitHub允许你添加多个Key,如果有多台电脑,把电脑的公钥都添加到Github上,这样不管用哪台电脑都可以向Github推送代码了。

添加远程库。

在github上创建一个project,在Repository name填入项目名(Git),其他保持默认设置,点击“Create repository”按钮,就成功地创建了一个新的Git仓库。

目前,在GitHub上的这个Git仓库还是空的,GitHub告诉我们,可以从这个仓库克隆出新的仓库,也可以把一个已有的本地仓库与之关联,然后,把本地仓库的内容推送到GitHub仓库。

现在,我们根据GitHub的提示,在本地的Git仓库下运行命令:

$ git remote add origin [email protected]:dahuazheng/Git.git

注:dahuazheng为你github的账户名

添加远程仓库后,远程库的名字就是origin,这是Git默认的叫法,也可以改成别的,但是origin这个名字一看就知道是远程库,接下来把本地库的所有内容推送到远程库上:

$ git push -u origin master

把本地库的内容推送到远程,用git push命令,实际上是把当前分支master推送到远程。

由于远程库是空的,我们第一次推送master分支时,加上了-u参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令。

克隆远程仓库(git clone)

Git支持多种协议,默认使用ssh,也可以使用https等其他协议。通过ssh支持的原生git协议速度最快。使用https除了速度慢以外,还有个最大的麻烦是每次推送都必须输入口令,但是在某些只开放http端口的公司内部就无法使用ssh协议而只能用https。

  • 使用ssh示例
$ git clone [email protected]:dahuazheng/vue-note.git
  • 使用https示例
$ git clone https://github.com/dahuazheng...

相关推荐