本文全为实战 建议观后实践
(上周写的哦)
大家假期安康,我是测试君。
下面我们来一起学习git操作,相信我这对你来说并不难。
一、Git原理
Git是目前世界上最先进的分布式版本控制系统(没有之一)。
简单来说就是:高端大气上档次!
SVN管理:
属于集中式版本控制系统,版本库是集中存放在中央服务器,必须联网才能工作,脱离局域网,采取互联网提交大文件会比较慢
Git管理:
属于分布式版本控制系统,根本没有“中央服务器”,安全性高,每个人的电脑上都是一个完整的版本库,即电脑硬盘上会有个版本这样,你工作的时候,就不需要联网了。即使中央服务器出了问题,从其他人那复制一个就好了
一般工作流程如下:
下图展示了 Git 的工作流程:
$ git config --global user.name "username"
$ git config --global user.email yourmail
Ps:只是一个空目录哦
$ mkdir mytest
$ git init
Initialized empty Git repository in C:/Users/userAccount/Desktop/test/.git/
ps:目录下会自动生成.git,误删,毕竟全靠它做版本管理
第一步,用命令git add告诉Git,把文件添加到仓库:
$ git add readme.txt
执行上面的命令,没有任何显示,这就对了,Unix的哲学是“没有消息就是好消息”,说明添加成功。
第二步,用命令git commit告诉Git,把文件提交到仓库:
$ git commit -m "test add file"
[master (root-commit) 5a92835] test add file
1 file changed, 1 insertion(+)
create mode 100644 mytest/readme.txt
本地版本操作:(连续操作一个文件并提交好多次)
git log日志查看命令
$ git log
commit d9669171c9c5890fd282c40a7e7fe0c372074233 (HEAD -> master)
Date: Thu Apr 4 14:52:23 2019 +0800
test third version
commit 6b39a4a6ce09c472e7f9c09e50c79c78b2efee16
Date: Thu Apr 4 14:51:11 2019 +0800
test second version
commit 9e42e41abf01d85e163b3d63c41bf5b099920d47
Date: Thu Apr 4 14:47:32 2019 +0800
test first version
commit dca156cf9c72b17f5d1aaff88ebfbfc79d5b91e2
Date: Thu Apr 4 14:46:39 2019 +0800
test add file
:
比较直观的方式查看
$ git log --pretty=oneline
比如返回上一个版本
$ git reset --hard HEAD^
HEAD is now at 6b39a4a test second version
Git的版本是生成是十六进制生成的,我的上一版本是如截图:
再查看日志当前版本是否为6b39a4a
回滚到某个指定版本
$ git reset --hard dca156cf
HEAD is now at dca156c test add file
再查看日志当前版本是否为dca156cf
优势:回滚很快呀
比如我对readme.txt内容做了修改,再输入git status查看状态
git checkout -- file可以丢弃工作区的修改,即撤销修改
$ git checkout -- readme.txt
再次输入git status 发现文件回滚到改动之前了
先增加一个文件
$ git add delete.txt
再删除文件
$ rm delete.txt
查看文件状态
$ git status
On branch master
Changes to be committed:
(use "git reset HEAD <file>..." to unstage)
new file: delete.txt
Changes not staged for commit:
(use "git add/rm <file>..." to update what will be committed)
(use "git checkout -- <file>..." to discard changes in working directory)
deleted: delete.txt
提交修改
$ git commit -m "remove test.txt"
[master cc6aa8f] remove test.txt
1 file changed, 0 insertions(+), 0 deletions(-)
create mode 100644 mytest/delete.txt
$ git remote add origin git@172.16.5.128:RefainZero/demo.git
把本地库的所有内容推送到远程库
$ git push -u origin master
从现在起,只要本地作了提交,就可以通过命令:
$ git push origin master
Everything up-to-date
$ git clone git@172.16.5.128:RefainZero/demo.git
Cloning into 'demo'...
remote: Counting objects: 16, done.
remote: Compressing objects: 100% (5/5), done.
remote: Total 16 (delta 0), reused 0 (delta 0)
Receiving objects: 100% (16/16), done.
1)、先制造一个冲突
情景,readme.txt中的,文本默认是test
git status
修改本地的readme.txt中文本内容为“20191635”
在服务器也修改了readme.txt,修改文本内容为“就想冲突下”
2)、提交本地的代码到远程仓库
在服务器执行git pull(获取最新代码)
不负众望,果然发生代码冲突
3)、解决文件中冲突的的部分
打开冲突的文件
4)、把冲突标记删掉,把冲突解决正确
提交修改,并同步到远程仓库
$ git add readme.txt
$ git commit -m '解决冲突的测试'
[master 0feb18f] 解决冲突的测试
$ git push origin master
Counting objects: 8, done.
Delta compression using up to 8 threads.
Compressing objects: 100% (4/4), done.
Writing objects: 100% (8/8), 740 bytes | 740.00 KiB/s, done.
Total 8 (delta 0), reused 0 (delta 0)
To 172.16.5.128:RefainZero/demo.git
ca9bc5e..0feb18f master -> master
5)、再次从服务器上获取最新代码,验证是否冲突
$ git pull
Already up to date.
END