git入门

第x章 软件开发生命周期

1.开发流程

项目立项-->需求调研-->需求拆解-->交给不同的开发进行开发-->测试环境测试-->部署生产环境。

2.环境解释

开发环境:一般开发环境是指开发人员自己的电脑环境,不同语言不通的环境,比如python,go,php,java等。
测试环境:开发好的代码先要在测试环境跑通,测试环境的软件版本和生产环境一致,但是数据一般为测试数据,作用主要是测试开发好的代码各个组件之间是否能跑通。
预发布环境:比测试环境更贴近生产环境,数据更接近真实环境,与生产环境的域名不同,主要用于质量检测。
生产环境:真正面向用户的线上环境,一般只有运维有权限进行代码的部署和维护,其他人员一般没有权限。

3.手动部署的问题

1.上传方式不方便,scp rsync rz ftp等
2.手动部署效率低下,占用大量时间
3.如果服务器多,上线速度慢
4.手动部署容易误操作,不能保证准确率
5.出问题不好回滚,手忙脚乱

4.自动部署的优势

4.1 持续集成

1.开发的代码持续的集成到代码仓库里就是持续集成,不用等所有人都开发完毕在合并,可以多个开发人员同时工作。
2.开发将代码提交到代码仓库,由ci服务器自动将代码拉下来进行编译,测试,然后将结果返回给开发人员。
3.持续集成的目的是可以频繁的将开发的功能进行合并,提高工作效率。

4.2 持续交付

1.持续交付就是将编译开发好的代码持续的交付到测试环境进行测试。
2.在预发布环境我们可以对代码进行质量扫描和漏洞扫描,并且将测试结果返回给测试人员。
3.如果测试的代码有问题,测试人员就通知开发人员进行修复,如果没有问题则进入下一个部署环节。

4.3 持续部署

1.代码测试没有问题之后就可以进入预发布环境进行进一步测试,如果预发布环境也没有问题可以通过jenkins服务器持续的部署到生产服务器
2.如果新部署的服务发现有问题,通过jenkins服务器可以快速的回滚到正常的代码。

第1章 准备环境

主机名     IP                  服务            内存    
gitlab  10.0.0.200  Gitlab      2G
jenkins 10.0.0.201  Jenkins     1G
nexus     10.0.0.202    Nexus         2G
sonar     10.0.0.203    SonarQube     2G
web       10.0.0.7    Nginx       1G

第2章 git基本配置

0.git介绍

1.安装命令

yum install git -y

2.查看配置

[root@gitlab ~]# git config 
用法:git config [选项]

配置文件位置
    --global              使用全局配置文件
    --system              使用系统级配置文件
    --local               使用版本库级配置文件
    -f, --file <文件>      使用指定的配置文件

3.配置使用git的用户

git config --global user.name "zhangya"

4.配置使用git的邮箱

git config --global user.email "526195417@qq.com"

5.设置语法高亮

git config --global color.ui true

6.查看配置

[root@gitlab ~]# git config --list
user.name=zhangya
user.email=526195417@qq.com
color.ui=true

[root@gitlab ~]# cat .gitconfig 
[user]
        name = zhangya
        email = 526195417@qq.com
[color]
        ui = true

第3章 git初始化

1.创建工作目录

mkdir /git_data

2.初始化

cd /git_data
git init 

3.查看状态

git status

4.隐藏文件介绍

[root@gitlab /git_data]# ls .git|xargs -n 1
branches                #分支目录
config                  #定义项目的特有配置
description         #描述
HEAD                        #当前分支
hooks                       #git钩子文件
info                        #包含一个全局排除文件
objects                 #存放所有数据,包含info和pack两个子文件夹
refs                        #存放指向数据(分支)的提交对象的指针
index                   #保存暂存区信息,在执行git init的时候,这个文件还没有

第4章 基本命令

1.在工作目录创建测试文件

[root@gitlab /git_data]# touch a b c 
[root@gitlab /git_data]# git status
# 位于分支 master
#
# 初始提交
#
# 未跟踪的文件:
#   (使用 "git add <file>..." 以包含要提交的内容)
#
#       a
#       b
#       c
提交为空,但是存在尚未跟踪的文件(使用 "git add" 建立跟踪)

2.提交文件到暂存区

提交a文件到暂存区

[root@gitlab /git_data]# git add a
[root@gitlab /git_data]# git status
# 位于分支 master
#
# 初始提交
#
# 要提交的变更:
#   (使用 "git rm --cached <file>..." 撤出暂存区)
#
#       新文件:    a
#
# 未跟踪的文件:
#   (使用 "git add <file>..." 以包含要提交的内容)
#
#       b
#       c

查看隐藏目录

[root@gitlab /git_data]# ll .git/
总用量 20
drwxr-xr-x 2 root root    6 5月  11 12:32 branches
-rw-r--r-- 1 root root   92 5月  11 12:32 config
-rw-r--r-- 1 root root   73 5月  11 12:32 description
-rw-r--r-- 1 root root   23 5月  11 12:32 HEAD
drwxr-xr-x 2 root root 4096 5月  11 12:32 hooks
-rw-r--r-- 1 root root   96 5月  11 13:01 index              # git add a 把文件提交到了暂存区
drwxr-xr-x 2 root root   20 5月  11 12:32 info
drwxr-xr-x 5 root root   37 5月  11 13:01 objects
drwxr-xr-x 4 root root   29 5月  11 12:32 refs

提交所有文件

[root@gitlab /git_data]# git add .
[root@gitlab /git_data]# git status
# 位于分支 master
#
# 初始提交
#
# 要提交的变更:
#   (使用 "git rm --cached <file>..." 撤出暂存区)
#
#       新文件:    a
#       新文件:    b
#       新文件:    c

3.撤回提交到暂存区的文件

[root@gitlab /git_data]# git rm --cached c
rm 'c'

[root@gitlab /git_data]# git status       
# 位于分支 master
#
# 初始提交
#
# 要提交的变更:
#   (使用 "git rm --cached <file>..." 撤出暂存区)
#
#       新文件:    a
#       新文件:    b
#
# 未跟踪的文件:
#   (使用 "git add <file>..." 以包含要提交的内容)
#
#       c
[root@git

4.删除提交到暂存区的文件

方法1: 先从暂存区撤回到工作区,然后直接删除文件

[root@gitlab /git_data]# rm -f c
[root@gitlab /git_data]# git status
# 位于分支 master
#
# 初始提交
#
# 要提交的变更:
#   (使用 "git rm --cached <file>..." 撤出暂存区)
#
#       新文件:    a
#       新文件:    b

方法2:直接同时删除工作目录和暂存区的文件

[root@gitlab /git_data]# ll
总用量 0
-rw-r--r-- 1 root root 0 5月  11 13:00 a
-rw-r--r-- 1 root root 0 5月  11 13:00 b

[root@gitlab /git_data]# git rm -f b
rm 'b'

[root@gitlab /git_data]# git status
# 位于分支 master
#
# 初始提交
#
# 要提交的变更:
#   (使用 "git rm --cached <file>..." 撤出暂存区)
#
#       新文件:    a
#

[root@gitlab /git_data]# ll
总用量 0
-rw-r--r-- 1 root root 0 5月  11 13:00 a

5.提交当前暂存区的所有文件到本地仓库

[root@gitlab /git_data]# git commit -m "commit a"
[master(根提交) 1153f56] commit a
 1 file changed, 0 insertions(+), 0 deletions(-)
 create mode 100644 a
 
[root@gitlab /git_data]# git status
# 位于分支 master
无文件要提交,干净的工作区

6.重命名已提交到本地仓库的文件

方法1:手动修改

[root@gitlab /git_data]# mv a a.txt
[root@gitlab /git_data]# git status
# 位于分支 master
# 尚未暂存以备提交的变更:
#   (使用 "git add/rm <file>..." 更新要提交的内容)
#   (使用 "git checkout -- <file>..." 丢弃工作区的改动)
#
#       删除:      a
#
# 未跟踪的文件:
#   (使用 "git add <file>..." 以包含要提交的内容)
#
#       a.txt
修改尚未加入提交(使用 "git add" 和/或 "git commit -a")

[root@gitlab /git_data]# git rm --cached a
rm 'a'
[root@gitlab /git_data]# git status
# 位于分支 master
# 要提交的变更:
#   (使用 "git reset HEAD <file>..." 撤出暂存区)
#
#       删除:      a
#
# 未跟踪的文件:
#   (使用 "git add <file>..." 以包含要提交的内容)
#
#       a.txt

[root@gitlab /git_data]# git add a.txt
[root@gitlab /git_data]# git status
# 位于分支 master
# 要提交的变更:
#   (使用 "git reset HEAD <file>..." 撤出暂存区)
#
#       重命名:    a -> a.txt

[root@gitlab /git_data]# git commit -m "commit a.txt"
[master 42ede9c] commit a.txt
 1 file changed, 0 insertions(+), 0 deletions(-)
 rename a => a.txt (100%)
[root@gitlab /git_data]# git status
# 位于分支 master
无文件要提交,干净的工作区

[root@gitlab /git_data]# ll
总用量 0
-rw-r--r-- 1 root root 0 5月  11 13:00 a.txt

方法2:git修改

[root@gitlab /git_data]# git mv a.txt a
[root@gitlab /git_data]# git status
# 位于分支 master
# 要提交的变更:
#   (使用 "git reset HEAD <file>..." 撤出暂存区)
#
#       重命名:    a.txt -> a

[root@gitlab /git_data]# git commit -m "rename a.txt a"
[master 5c3ddba] rename a.txt a
 1 file changed, 0 insertions(+), 0 deletions(-)
 rename a.txt => a (100%)
[root@gitlab /git_data]# git status
# 位于分支 master
无文件要提交,干净的工作区

7.对比工作目录的文件和暂存区文件的差异

[root@gitlab /git_data]# echo aaaa > a
[root@gitlab /git_data]# git diff
diff --git a/a b/a
index e69de29..5d308e1 100644
--- a/a
+++ b/a
@@ -0,0 +1 @@
+aaaa

8.对比暂存区和本地仓库的文件内容的差异

提交a到本地暂存区,用git diff查看是相同的

[root@gitlab /git_data]# git add a
[root@gitlab /git_data]# git diff

对比暂存区和本地仓库文件的不同

[root@gitlab /git_data]# git diff --cached a
diff --git a/a b/a
index e69de29..5d308e1 100644
--- a/a
+++ b/a
@@ -0,0 +1 @@
+aaaa

将暂存区文件提交到本地仓库后再对比

[root@gitlab /git_data]# git commit -m "modified a"
[master 8203c87] modified a
 1 file changed, 1 insertion(+)
[root@gitlab /git_data]# git diff --cached a

9.查看历史的提交记录

查看详细信息

[root@gitlab /git_data]# git log
commit 8203c878bc30c3bd23ee977e5980232fa660ddae
Author: zhangya <526195417@qq.com>
Date:   Mon May 11 13:38:22 2020 +0800

    modified a

commit 5c3ddba7bc8de6b8575e77513ee9805021ffc5ef
Author: zhangya <526195417@qq.com>
Date:   Mon May 11 13:26:10 2020 +0800

    rename a.txt a

commit 42ede9cc10865b67e4b1e8ad58a601eadf45cd61
Author: zhangya <526195417@qq.com>
Date:   Mon May 11 13:24:35 2020 +0800

    commit a.txt

commit 1153f564c45678cc9d4c265a1b55f5ba7b610ac9
Author: zhangya <526195417@qq.com>
Date:   Mon May 11 13:16:13 2020 +0800

    commit a

查看简单的信息一行现实

[root@gitlab /git_data]# git log --oneline 
8203c87 modified a
5c3ddba rename a.txt a
42ede9c commit a.txt
1153f56 commit a

显示当前的指针指向

[root@gitlab /git_data]# git log --oneline --decorate
8203c87 (HEAD, master) modified a
5c3ddba rename a.txt a
42ede9c commit a.txt
1153f56 commit a

显示具体内容的变化

[root@gitlab /git_data]# git log -p

只显示最新的内容

[root@gitlab /git_data]# git log -1
commit 8203c878bc30c3bd23ee977e5980232fa660ddae
Author: zhangya <526195417@qq.com>
Date:   Mon May 11 13:38:22 2020 +0800

    modified a

10.回滚到指定版本

提交新内容bbb到文件a

[root@gitlab /git_data]# echo bbb >> a
[root@gitlab /git_data]# git add a
[root@gitlab /git_data]# git commit -m "add bbb"
[master b11e0b2] add bbb
 1 file changed, 1 insertion(+)

提交新内容ccc到文件a

[root@gitlab /git_data]# echo ccc >> a
[root@gitlab /git_data]# git commit -am "add ccc"
[master 4df18d4] add ccc
 1 file changed, 1 insertion(+)

查看版本号

[root@gitlab /git_data]# git log --oneline 
4df18d4 add ccc
b11e0b2 add bbb
8203c87 modified a
5c3ddba rename a.txt a
42ede9c commit a.txt
1153f56 commit a

回滚到指定版本 modified a

[root@gitlab /git_data]# git reset --hard 8203c87
HEAD 现在位于 8203c87 modified a
[root@gitlab /git_data]# cat a 
aaaa

此时发现回滚错了,应该回退到bbb

此时查看历史会发现并没有bbb,因为回到了过去,那时候提交bbb还没发生,所有看不到记录

[root@gitlab /git_data]# git log --oneline 
8203c87 modified a
5c3ddba rename a.txt a
42ede9c commit a.txt
1153f56 commit a

我们可以使用reflog来查看总的历史记录

[root@gitlab /git_data]# git reflog 
8203c87 HEAD@{0}: reset: moving to 8203c87
4df18d4 HEAD@{1}: commit: add ccc
b11e0b2 HEAD@{2}: commit: add bbb
8203c87 HEAD@{3}: commit: modified a
5c3ddba HEAD@{4}: commit: rename a.txt a
42ede9c HEAD@{5}: commit: commit a.txt
1153f56 HEAD@{6}: commit (initial): commit a

然后再指定回退到bbb版本

[root@gitlab /git_data]# git reset --hard b11e0b2
HEAD 现在位于 b11e0b2 add bbb
[root@gitlab /git_data]# cat a 
aaaa
bbb

第5章 分支

1.查看当前属于什么分支

[root@gitlab /git_data]# git branch 
* master

2.创建分支

创建新分支

[root@gitlab /git_data]# git branch testing

创建新分支并切换到指定分支

[root@gitlab /git_data]# git checkout -b testing        
切换到一个新分支 'testing'
[root@gitlab /git_data]# git branch 
  master
* testing

4.查看分支指向

[root@gitlab /git_data]# git log --oneline --decorate
b11e0b2 (HEAD, testing, master) add bbb
8203c87 modified a
5c3ddba rename a.txt a
42ede9c commit a.txt
1153f56 commit a

5.切换到指定分支

切换到testing分支

[root@gitlab /git_data]# git checkout testing 
切换到分支 'testing'
[root@gitlab /git_data]# git branch 
  master
* testing

在当前分支创建文件并提交到本地仓库

[root@gitlab /git_data]# touch test
[root@gitlab /git_data]# git add .
[root@gitlab /git_data]# git commit -m "commit test"
[testing d50853d] commit test
 1 file changed, 0 insertions(+), 0 deletions(-)
 create mode 100644 test
[root@gitlab /git_data]# ll
总用量 4
-rw-r--r-- 1 root root 9 5月  11 15:51 a
-rw-r--r-- 1 root root 0 5月  11 16:02 test

切换到master分支查看文件

[root@gitlab /git_data]# git checkout master
切换到分支 'master'
[root@gitlab /git_data]# git branch 
* master
  testing
[root@gitlab /git_data]# ll
总用量 4
-rw-r--r-- 1 root root 9 5月  11 15:51 a

在master分支下创建文件

[root@gitlab /git_data]# touch master
[root@gitlab /git_data]# git add .
[root@gitlab /git_data]# git commit -m "commit master"
[master 6f9e2f0] commit master
 1 file changed, 0 insertions(+), 0 deletions(-)
 create mode 100644 master
[root@gitlab /git_data]# ll
总用量 4
-rw-r--r-- 1 root root 9 5月  11 15:51 a
-rw-r--r-- 1 root root 0 5月  11 16:10 master

6.合并分支

将test和master分支合并

[root@gitlab /git_data]# git branch 
* master
  testing
[root@gitlab /git_data]# git merge testing 
Merge made by the 'recursive' strategy.
 test | 0
 1 file changed, 0 insertions(+), 0 deletions(-)
 create mode 100644 test

查看提交日志

 [root@gitlab /git_data]# git log --oneline --decorate
6f38df1 (HEAD, master) Merge branch 'testing'
6f9e2f0 commit master
d50853d (testing) commit test
b11e0b2 add bbb
8203c87 modified a
5c3ddba rename a.txt a
42ede9c commit a.txt
1153f56 commit a

查看文件

[root@gitlab /git_data]# ll
总用量 4
-rw-r--r-- 1 root root 9 5月  11 15:51 a
-rw-r--r-- 1 root root 0 5月  11 16:10 master
-rw-r--r-- 1 root root 0 5月  11 16:11 test

7.冲突合并

在master分支下编辑a文件并提交

[root@gitlab /git_data]# echo "master" >> a
[root@gitlab /git_data]# git commit -am "modified a master"
[master 38fd841] modified a master
 1 file changed, 1 insertion(+)
[root@gitlab /git_data]# cat a
aaaa
bbb
master

切换到test分支下编辑文件并提交

[root@gitlab /git_data]# git checkout testing 
切换到分支 'testing'
[root@gitlab /git_data]# echo "testing" >> a
[root@gitlab /git_data]# git commit -am "modified a on testing branch"
[testing 71c50c8] modified a on testing branch
 1 file changed, 1 insertion(+)
 [root@gitlab /git_data]# cat a 
aaaa
bbb
testing

切换到master分支并合并test分支,此时两个分支的文件内容是有冲突的

[root@gitlab /git_data]# git checkout master 
切换到分支 'master'
[root@gitlab /git_data]# git merge testing 
自动合并 a
冲突(内容):合并冲突于 a
自动合并失败,修正冲突然后提交修正的结果。

此时冲突内容会自动写到文件里

[root@gitlab /git_data]# cat a
aaaa
bbb
<<<<<<< HEAD
master
=======
testing
>>>>>>> testing

要想解决冲突,我们需要手动修改文件,保留最终的文件,然后重新提交

[root@gitlab /git_data]# vim a 
[root@gitlab /git_data]# cat a    
aaaa
bbb
master
[root@gitlab /git_data]# git commit -am "merge testing to master"
[master 921d88e] merge testing to master

查看提交日志

[root@gitlab /git_data]# git log --oneline --decorate
921d88e (HEAD, master) merge testing to master
71c50c8 (testing) modified a on testing branch
38fd841 modified a master
6f38df1 Merge branch 'testing'
6f9e2f0 commit master
d50853d commit test
b11e0b2 add bbb
8203c87 modified a
5c3ddba rename a.txt a
42ede9c commit a.txt
1153f56 commit a

8.删除指定分支

[root@gitlab /git_data]# git branch -d testing 
已删除分支 testing(曾为 71c50c8)。
[root@gitlab /git_data]# git branch 
* master

第6章 git标签使用

1.给当前版本创建标签

[root@gitlab /git_data]# git tag v1.0 -m "aaa bbb master testing version v1.0"

2.给指定版本打标签

[root@gitlab /git_data]# git log --oneline 
921d88e merge testing to master
71c50c8 modified a on testing branch
38fd841 modified a master
6f38df1 Merge branch 'testing'
6f9e2f0 commit master
d50853d commit test
b11e0b2 add bbb
8203c87 modified a
5c3ddba rename a.txt a
42ede9c commit a.txt
1153f56 commit a
[root@gitlab /git_data]# git tag -a v2.0 b11e0b2 -m "add bbb version v2.0"

3.查看标签

[root@gitlab /git_data]# git tag 
v1.0
v2.0

4.回滚到指定标签

首先查看当前版本文件

[root@gitlab /git_data]# ll
总用量 4
-rw-r--r-- 1 root root 16 5月  11 16:36 a
-rw-r--r-- 1 root root  0 5月  11 16:33 master
-rw-r--r-- 1 root root  0 5月  11 16:11 test

回滚到指定版本

[root@gitlab /git_data]# git reset --hard v2.0
HEAD 现在位于 b11e0b2 add bbb

再次查看文件

[root@gitlab /git_data]# ll
总用量 4
-rw-r--r-- 1 root root 9 5月  11 16:52 a

第7章 总结

1.命令总结

git init         #初始化一个目录为git版本库
git add .           #将没有被管理的文件,加入git管理,添加到暂存区
git commit -m "描述"  #将暂存区的文件提交到版本库中,进行版本的管理
git log             #查看提交的历史记录
git reflog      #查看git提交的所有历史记录
git status      #查看当前的文件管理状态(已提交|未提交)
git reset --hard  commitID  #回退到指定的提交版本记录

2.图解

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,039评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,223评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,916评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,009评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,030评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,011评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,934评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,754评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,202评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,433评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,590评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,321评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,917评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,568评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,738评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,583评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,482评论 2 352