发现网上关于git的资料太多了,大家都在分别以不同的角度,图形来一步步讲解git的使用。我们也来自己敲几遍。
一、环境安装
本文是在Windows环境下,所以安装的Window客户端。关于下载可以通过《git windows客户端》这里分享的下载。
安装也就不多说了,安装后,右键就会显示 Git Bash Here 菜单。
二、初始化配置
安装完Git,我们需要先配置自己的身份信息,作为自己参与团队协作的一个身份标记,比如谁对某个文件进行了修改。这样就会在每一个Git
的提交中,使用这些信息,并且它会写入到你的每一次提交中,不可更改,键入下述命令:
git config --global user.name "Administrator"
git config --global user.email "admin@nideyuan.com"
注意 --global 选项,表示你这台机器上所有的Git仓库都会使用这个配置,当然也可以对某个仓库指定不同的用户名和Email地址,执行如下命令:
git config --local user.name "nideyuan"
git config --local user.email "1147659453@qq.com"
三、初始化仓库
如果你使用已经使用git管理的项目,你就可以略过这一步,直接从已经存在的git服务器上clone下来即可。
如果你还有建立项目或这个已经有本地项目,但未使用git管理时,才需要执行本步骤的操作。即在项目的根目录下执行:
$ git init
Initialized empty Git repository in E:/git4nideyuan/.git/
执行完,可以发现当前目录下多了一个.git的目录,这个目录是Git来跟踪管理版本库的,一般情况下,不需要改动目录中的文件,除非你非常有把握或指导某些配置是什么,建议不要修改。
四、添加文件到Git暂存区
既然我们已经初始化了项目的根目录,那我们就可以向项目中增加文件,Just do it!
4.1增加一个README.txt文件
$ vi README.txt
读读我,这可是项目中添加的第一个文件哦。
保存后。ls发现确实有这个文件了。
$ls README.txt
README.txt
我看看下获取当前工作区与缓存区的状态,使用git status ----实际使用中可以查看也可以不查看
$ git status
On branch master
Initial commit
Untracked files:
(use "git add <file>..." to include in what will be committed)
README.txt
nothing added to commit but untracked files present (use "git add" to track)
看到没,前文提到多git的文件假如文件未加入版本控制,那么该文件处于Untracked(未跟踪)的状态,我们可以通过git add指令将文件添加到暂存区中此时文件会变成Tracked(已跟踪)状态!我们可以使用下面的指令,将文件一个个添加到暂存区中:
$git add README.txt
再看下项目的状态:----实际使用中可以查看也可以不查看
$ git status
On branch master
Initial commit
Changes to be committed:
(use "git rm --cached <file>..." to unstage)
new file: README.txt
文件状态为 committed.
4.2批量增加文件到Git仓库
1)将所有tracked文件中被修改或已删除的文件信息添加到Git暂存区,不会处理untracked的文件!
git add -u
2)将所有tracked文件中被修改或已删除的文件信息添加到Git仓库,会把理untracked的文件信息也加入Git暂存区
git add -A
3)把当前工作区的所有文件全加入到Git暂存区
git add .
4.3交互模式将文件添加到Git仓库
除了上面三种外,git其实还为我们提供了交互界面模式,我们先增加两个文件:
$ touch git_add_i_001.txt
$ touch git_add_i_002.txt
我们再键入:
git add -i
上面的过程是这样的:
1.键入git add -i,进入后,键入4,选择添加untracked的文件
2.他给我们列出了untracked的文件,然后我们根据序号来添加文件,分别依次添加了我们刚才创建的两个文件
3.输入?会弹出相关提示,然后直接回车,弹出选择菜单!
4.我们再次输入1,选择了查看仓库状态。发现文件都已经在git暂存区了。
5.然后再次输入7,就退出了交互模式!
五、将暂存区文件提交到到Git仓库
使用命令git commit -m "这里是提交说明",提交到仓库中去
简单解释一下git commit
命令,-m
后面输入的是本次提交的说明,一般项目中会对这里的说明格式有所约束,当然如果自己的项目,可以随便录入,这样你就能从历史记录里方便地找到改动记录。
$ git commit -m "这是第一次提交了3个文件"
[master (root-commit) 1f66eca] 这是第一次提交了3个文件
3 files changed, 1 insertion(+)
create mode 100644 README.txt
create mode 100644 git_add_i_001.txt
create mode 100644 git_add_i_002.txt
我们再看项目当前工作区与缓存区的状态状态
$ git status
On branch master
nothing to commit, working tree clean
Git告诉我们当前没有需要提交的修改,而且,工作目录是干净(working directory clean)的。
六、将项目传到远程仓库中
对于新的项目来说我们需要这一步,同样如果你的是用其他平台中clone的项目,则可以省去该步骤。
首选需要先设置远程仓库的地址,因为我的是自己搭建的gitlab服务器,所以是可以是自己设置的地址,如果你没有自己搭建的服务器,也可以在coding或github中申请。
git remote add origin http://demo.nideyuan.com/root/test.git
这里注意要添加自己的sshkey,gitlab中添加方法可以见《gitlab之:使用手册-登录并添加SSHKeys》,其他平台的可以自行百度哦。
git push -u origin master
由于远程库是空的,我们第一次推送master分支时,加上了-u参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令
git push origin master
好了,到目前为止,我们已经完成了git客户端的安装,git项目的初始化,已经将文件添加的暂存区,并提交文件到版本库中,而且还将项目传到了自己的远程仓库中。
原文地址: http://www.nideyuan.com/?p=351