Git 操作

一、分支

1、查看远程的分支

命令:git branch

事例

yuancandeMacBook-Pro-2:NJZ_Tourist yuancan$ git branch
* master
  v1.3.0

 

命令:git branch -a

事例

yuancandeMacBook-Pro-2:NJZ_Tourist yuancan$ git branch -a
* master
  v1.3.0
  v1.3.1
  remotes/origin/HEAD -> origin/master
  remotes/origin/master
  remotes/origin/v1.3.0
  remotes/origin/v1.3.1
  remotes/origin/v2.0.0

 2、切换分支

命令:git checkout 分支名称

事例

yuancandeMacBook-Pro-2:NJZ_Tourist yuancan$ git checkout v1.3.0
Switched to branch 'v1.3.0'

3、合并分支

第一步:切换到主分支
yuancandeMacBook-Pro-2:NJZ_Tourist yuancan$ git checkout master
Switched to branch 'master'

第二步:在主分支上合并分支

yuancandeMacBook-Pro-2:NJZ_Tourist yuancan$ git merge v1.3.0
Updating cfbdc69..9a80336

 

4、新建分支

命令:git branch 分支名称

事例

1、在本地新建一个分支

    git branch v1.3.1

2、将本地分支推送到远程服务器

    git push origin v1.3.1

二、Git忽略规则(.gitignore配置)不生效原因和解决

 

第一种方法:

.gitignore中已经标明忽略的文件目录下的文件,git push的时候还会出现在push的目录中,或者用git status查看状态,想要忽略的文件还是显示被追踪状态。

原因是因为在git忽略目录中,新建的文件在git中会有缓存,如果某些文件已经被纳入了版本管理中,就算是在.gitignore中已经声明了忽略路径也是不起作用的,

这时候我们就应该先把本地缓存删除,然后再进行git的提交,这样就不会出现忽略的文件了。

  

解决方法: git清除本地缓存(改变成未track状态),然后再提交:

[root@kevin ~]# git rm -r --cached .

[root@kevin ~]# git add .

[root@kevin ~]# git commit -m 'update .gitignore'

[root@kevin ~]# git push -u origin master

 

需要特别注意的是:

1).gitignore只能忽略那些原来没有被track的文件,如果某些文件已经被纳入了版本管理中,则修改.gitignore是无效的。

2)想要.gitignore起作用,必须要在这些文件不在暂存区中才可以,.gitignore文件只是忽略没有被staged(cached)文件,

   对于已经被staged文件,加入ignore文件时一定要先从staged移除,才可以忽略。 

 

第二种方法:(推荐)

在每个clone下来的仓库中手动设置不要检查特定文件的更改情况。

[root@kevin ~]# git update-index --assume-unchanged PATH                  //在PATH处输入要忽略的文件

.gitignore忽略规则简单说明

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

#               表示此为注释,将被Git忽略

*.a             表示忽略所有 .a 结尾的文件

!lib.a          表示但lib.a除外

/TODO           表示仅仅忽略项目根目录下的 TODO 文件,不包括 subdir/TODO

build/          表示忽略 build/目录下的所有文件,过滤整个build文件夹;

doc/*.txt       表示会忽略doc/notes.txt但不包括 doc/server/arch.txt

 

bin/:           表示忽略当前路径下的bin文件夹,该文件夹下的所有内容都会被忽略,不忽略 bin 文件

/bin:           表示忽略根目录下的bin文件

/*.c:           表示忽略cat.c,不忽略 build/cat.c

debug/*.obj:    表示忽略debug/io.obj,不忽略 debug/common/io.obj和tools/debug/io.obj

**/foo:         表示忽略/foo,a/foo,a/b/foo

a/**/b:         表示忽略a/b, a/x/b,a/x/y/b

!/bin/run.sh    表示不忽略bin目录下的run.sh文件

*.log:          表示忽略所有 .log 文件

config.php:     表示忽略当前路径的 config.php 文件

 

/mtk/           表示过滤整个文件夹

*.zip           表示过滤所有.zip文件

/mtk/do.c       表示过滤某个具体文件

 

被过滤掉的文件就不会出现在git仓库中(gitlab或github)了,当然本地库中还有,只是push的时候不会上传。

 

需要注意的是,gitignore还可以指定要将哪些文件添加到版本管理中,如下:

!*.zip

!/mtk/one.txt

 

唯一的区别就是规则开头多了一个感叹号,Git会将满足这类规则的文件添加到版本管理中。为什么要有两种规则呢?

想象一个场景:假如我们只需要管理/mtk/目录中的one.txt文件,这个目录中的其他文件都不需要管理,那么.gitignore规则应写为::

/mtk/*

!/mtk/one.txt

 

假设我们只有过滤规则,而没有添加规则,那么我们就需要把/mtk/目录下除了one.txt以外的所有文件都写出来!

注意上面的/mtk/*不能写为/mtk/,否则父目录被前面的规则排除掉了,one.txt文件虽然加了!过滤规则,也不会生效!

 

----------------------------------------------------------------------------------

还有一些规则如下:

fd1/*

说明:忽略目录 fd1 下的全部内容;注意,不管是根目录下的 /fd1/ 目录,还是某个子目录 /child/fd1/ 目录,都会被忽略;

 

/fd1/*

说明:忽略根目录下的 /fd1/ 目录的全部内容;

 

/*

!.gitignore

!/fw/ 

/fw/*

!/fw/bin/

!/fw/sf/

说明:忽略全部内容,但是不忽略 .gitignore 文件、根目录下的 /fw/bin/ 和 /fw/sf/ 目录;注意要先对bin/的父目录使用!规则,使其不被排除。