一 放在前面
My stupid boss still prefers SVN.
这是引自廖雪峰老师的一句话。在学习了Github的基本操作之后,不得不说分布式版本控制系统比SVN等高明太多。而关于Git诞生更是极富传奇色彩的,不得不感叹Linus本人技艺之高超。
二 在Windows环境下安装Git
众所周知Windows是最烂的开发平台,但它可能也是入门最快的开发平台。
首先我们需要下载Git专门为Windows开发的简易图形界面,下载地址:Git for Windows按照默认安装好以后。在开始菜单中找到Git bash,打开之后输入以下命令自报家门:
$ git config --global user.name "Your Name"
$ git config --global user.email "email@example.com"
三 创建版本库
其实版本库就相当于一个文件夹,我们可以通过Git对这个文件夹进行管理,包括修改、删除,甚至是在我们不小心删除文件之后也能通过Git来恢复。
- 1 如何创建版本库?首先在Git bash下输入以下命令:
mkdir learngit
cd learngit
- 2 再输入以下代码查看创建的
learngit
目录在哪里:
pwd
- 3 再将此目录变成版本库:
git init
四 添加文件到版本库
这里要提的是,我们一般要以以纯文本方式编写文件,才能正常的使用版本控制系统,但最好不要使用微软的记事本之类的,不然会遇到问题的,推荐使用Notepad++
- 1 使用Notepad++创建一个名为
readme
的txt
文件(此文件必须存在创建的learngit
目录下),输入以下内容:
Git is a version control system.
Git is free software.
- 2 使用以下命令将文件添加到暂存区:
git add readme.txt
- 3 使用命令将暂存区中的文件提交到分支(master):
git commit -m "wrote a readme file"
这里要补充说明一下,在使用git commit
命令时,我们一般要对本次提交做一个说明:
git commit -m "wrote a readme file"
引号中的内容就是我们对本次提交的说明。
还要简单介绍一下的是,工作区就是我们开始建立的learngit
目录,这样的一个文件夹里有我们刚刚存进去的readme.txt
文件,当我们使用git add readme.txt
命令的时候,readme.txt
文件就被提交到一个叫做暂存区的地方,再使用命令git commit
命令才将提交到当前分支。
还需要说明的是,如果不add
到暂存区,那就不会加入到commit
中。
下图可能会利于你的理解:
五 查看文件的修改状况以及当前版本库状态
- 我们用Notepad++d对
readme.txt
文件做以下修改:
Git is a distributed version control system.
Git is free software.
- 运行
git status
查看结果。这个时候,一般命令会告诉我们readme.txt
被修改过了,但还没有准备提交的修改。我们可以用git diff
很直观明确的查看文件到底是被做了什么修改。 - 在知道文件被做了什么修改之后,我们就可以用
git add
和git commit
放心提交文件到版本库了。
六 恢复到以前的版本
下面我们再次用Notepad++对readme.txt
的内容进行修改,再提交到版本库。再实际工作中,我们往往会多次提交修改,但有的时候难免会出问题,所以为了避免全部砍掉重练的悲剧发生,我们可以将当前文件恢复到之前的状态。
- 1 使用
git log
命令显示从最近到最远的提交日志(加上--pretty=oneline
可使界面更简洁)。
- 2 我们可以看到
commit
后面有一串数字,这个相当于是我们重载的入口。输入以下命令:
git reset --hard 25e1467
就可以回到git tracks changes
时的版本。这里得说解释一下,我们并不需要输入完整的commit id
,只需要能够与其他ID区别的部分即可。 - 3 但有时候我们不小心关机失去了
commit id
,我们可以用git reflog
查找我们每次的操作记录,从而恢复到以前的版本。
七 如何放弃对文件的修改
- 1 在提交之前,我们可以先用
git status
命令查看当前版本状态,一般情况下,Git会告诉我们,使用git checkout -- file
可以丢弃工作区的修改:
$ git status
# On branch master
# Changes not staged for commit:
# (use "git add <file>..." to update what will be committed)
# (use "git checkout -- <file>..." to discard changes in working directory)
#
# modified: readme.txt
#
no changes added to commit (use "git add" and/or "git commit -a")
很明确的,Git告诉我们,使用git checkout -- readme.txt
命令可以放弃我们对于工作区文件的修改。 - 2 如果
git add
到暂存区时的修改:
我们同样可以使用命令git reset HEAD file
把暂存区的修改撤销掉,重新放回工作区。
八 删除文件
- 1 我们可以手动将不要的文件删除,或者使用
rm
命令,如:
rm test.txt
- 2 以上操作之后,版本库依旧存在刚才删除的
test.txt
文件,如果我们需要把它从版本库里删除,那就需要用到以下命令:
git rm test.txt
之后用git commit
提交本次操作。 - 3 但如果是误删的话,我们依旧可以用
git checkout -- test.txt
命令还原。
九 将文件添加到远程仓库
首先,我们需要在Github官网上申请一个账号,这里就不详细展开了。将文件添加到远程仓库的操作与将本地文件上传到百度云的实质是相类似的。有了Github账号之后,我们即可免费获得远程仓库。
但和百度云不同的是,我们自己Github下的远程仓库是完全公开的,如果我们不想公开,就得付费。
注册账号之后,我们还得做一些必要的准备。
- 1 创建SSH Key:
在Git Bash下输入命令ssh-keygen -t rsa -C "youremail@example.com"
,在接下来出现的一系列“:
”后面点击回车即可。
在创建完成之后,我们可以在可以在用户主目录里找到.ssh目录,里面的id_rsa.pub
文件是我们所需要输入的SSH Key秘钥。用Notepad++将id_rsa.pub
打开并复制里面的内容,打开主界面中的设置
点选SSH and GPG keys选项,点击New SSH key
在title栏中输入SSH key1
(可以随便取),将刚才复制的密钥粘贴到key栏中创建即可。
- 2 在Github上完成配置
登陆到Github账号,在主页面找到New Repository
按钮,如下图
这里的Repository name
填写最初我们创建的learngit
即可,最后点击Creat repository
- 3 一切准备就绪,在本地的
learngit
目录下运行以下命令
git remote add origin git@github.com:GitHub的账户名/learngit.git
运行以下命令,将把本地库的所有内容推送到远程库上
git push -u origin master
十 从远程库克隆到本地
当我们在公司修改了文件并push
到远程库之后,如果我们要在家用自己的PC对文件进行修改时,我们可以用命令git clone
克隆一个本地库:
$ git clone git@github.com:你的Github用户名/gitskills.git
这里的gitskills
是我们登陆到GitHub所创建的一个新的仓库,当我们运行以上命令之后,进入本地的gitskills
目录查看,会发现里面已经有我们在公司更改的文件了,所以我们就能够继续工作了。