Git简介
Git是目前世界上最先进的分布式版本控制系统(没有之一)。
Linux之父Linux用C语言写了Git分布式版本控制系统。
分布式版本控制系统与集中式版本控制系统的区别
区别 | 分布式 | 集中式 |
---|---|---|
中央服务器 | 有,版本库集中存放在中央服务器,工作时需从中央服务器获取最新版本代码,工作完成后在将代码推送到中央服务器。中央服务器出了问题,开发者几乎无法工作 | 无,开发人员本地都有本地存储库(Local Repository) |
联网 | 必须,必须要联网才能工作,而且对网络的依赖性较强,网络较差或者文件较大,文件提交的速度会受很大的限制 | 不是必要的,在没有网络的情况下也可以执行commit、查看版本提交记录、以及分支操作,在有网络的情况下执行 push 将代码从本地仓库推送到远程仓库(Remote Repository)。 |
存储格式 | 原始文件,体积大 | 元数据,体积小 |
分支操作 | 创建新的分支则所有的人都会拥有和你一样的分支 | 分支操作不会影响其他开发人员 |
提交方式 | 直接提交到中央版本库 | 先commit到本地仓库,再push到远程仓库 |
优点 | 方便管理,逻辑明确,上手快;更能保证代码的安全性;代码一致性非常高;有良好的目录级权限控制系统 | 速度快、灵活,分支之间可以任意切换;单机合并分支,开发者之间容易解决冲突;可离线工作,不影响本地代码编写;公共服务器压力小,数据传输量少 |
缺点 | 服务器性能要求高,数据体量大;必须联网;不适合开源;分支管理不灵活 | 不符合常规思维,学习周期相对较长;代码保密性差,一旦开发者把整个库克隆下来就可以完全公开所有代码和版本信息。 |
创建版本库
- 创建一个项目目录(mkdir Git)
- 进入到这个目录(cd Git)
- 初始化版本库(git init)
在当前目录下会有.git的目录,它是git进行跟踪和管理版本库,禁止删改此文件(如果没看到可能是您的电脑不显示隐藏文件,在命令行工具运行 ls -ah可查看)。
$ mkdir Git
$ cd Git
$ git init
// Initialized empty Git repository in /Users/zhengdahua/Documents/Project/Private/Git/.git/ 初始化空的版本库
- 编写一个README.md文件
- 将README.md添加到暂存区(git add README.md)
- 确认提交文件到仓库(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 <kenvin.zheng@drigle.com>
Date: Sun Feb 24 22:24:51 2019 +0800
update document.md
commit f953ccc298a430939e5e64eeedd49cc2db5a3fdb
Author: kevin <kenvin.zheng@drigle.com>
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 "youremail@example.com"
上传公钥
登陆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 git@github.com: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 git@github.com:dahuazheng/vue-note.git
- 使用https示例
$ git clone https://github.com/dahuazheng...
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。