忽略特殊文件

为了在git status时不因为一些特殊文件显示 Untracked files .. ,在Git工作区的根目录下创建一个特殊的.gitignore文件,然后把要忽略的文件名填进去,Git就会自动忽略这些文件。

忽略文件的原则是:

  1. 忽略操作系统自动生成的文件,比如缩略图等;
  2. 忽略编译生成的中间文件、可执行文件等,也就是如果一个文件是通过另一个文件自动生成的,那自动生成的文件就没必要放进版本库,比如Java编译产生的.class文件;
  3. 忽略你自己的带有敏感信息的配置文件,比如存放口令的配置文件。
1
2
3
4
5
6
7
# 此为注释 – 将被 Git 忽略

*.db # 忽略所有 .db 结尾的文件
!ABC.db # 但 ABC.db 除外
/BLL # 仅仅忽略项目根目录下的 BLL 文件,不包括 subdir/BLL
build/ # 忽略 build/ 目录下的所有文件
doc/*.txt # 会忽略 doc/notes.txt 但不包括 doc/server/arch.txt

.gitignore也提交到Git,就完成了

有时候想添加一个文件到Git,但发现添加不了,原因是这个文件被.gitignore忽略了:

1
2
3
4
$ git add App.class
The following paths are ignored by one of your .gitignore files:
App.class
Use -f if you really want to add them.

如果你确实想添加该文件,可以用-f强制添加到Git:

1
$ git add -f App.class

如果发现.gitignore写得有问题,需要找出来到底哪个规则写错了,可以用git check-ignore命令检查:

1
2
$ git check-ignore -v App.class
.gitignore:3:*.class App.class

Git会告诉我们,.gitignore的第3行规则忽略了该文件,于是我们就可以知道应该修订哪个规则。

配置别名

--global参数是全局参数,也就是这些命令在这台电脑的所有Git仓库下都有用 ,键入下行命令:st就表示status

1
$ git config --global alias.st status

配置一个git last,让其显示最后一次提交信息:

1
$ git config --global alias.last 'log -1'

ci表示commitbr表示branch

1
2
$ git config --global alias.ci commit
$ git config --global alias.br branch

命令git reset HEAD file可以把暂存区的修改撤销掉(unstage),重新放回工作区。既然是一个unstage操作,就可以配置一个unstage别名:

1
$ git config --global alias.unstage 'reset HEAD'

lg配置成了:(git lg显示更清楚)

1
git config --global alias.lg "log --color --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit"

配置文件

每个仓库的Git配置文件都放在.git/config文件中。

当前用户的Git配置文件放在用户主目录下的一个隐藏文件.gitconfig中。 配置别名也可以直接修改这个文件,如果改错了,可以删掉文件重新通过命令配置。

搭建Git服务器

需要用 Ubuntu 在Linux环境下搭建。此事以后再议…(咕咕咕)