Git初阶整理
谈起开源,相信很多人就会想到Linux系统。Linux也在全世界热心的志愿者的参与下,不断壮大为全世界最大的系统软件,但是Linux却存在不同的版本分支,不同的Linux代码的管理是一个很让人头疼的问题。
一些机缘巧合之下,Linux的创建者Linus用C写了两周时间的时间,完成了一个分布式版本控制系统,就是Git。在它出现的一个月后,Linux的源代码就已经由Git管理了。至今,世界许多的开源项目都由其托管,Git也迅速成为世界上最为流行的分布式版本控制系统。
简单地理解一下,Git就是一个代码管理仓库,它可以帮你的项目管理你的项目伊始到后期维护的代码。同时,全部的代码还可以克隆给团队的任何一个人,其他人所做的任何修改,你也能够知道。当然,因为是分布式管理,当你的电脑上坏掉了,其他人是有完整的版本库的,直接重新复制一份即可,这相较于集中式版本控制自然安全很多。
Git安装
Git的发明本身是为了Linux源代码管理的,但是随着它的发展,常见的系统平台已经能够很好支持了的。
这里简单介绍一下Git在Linux、Mac和Windows下的安装。
-
在不同的发型版本的Linux下,打开系统下的Terminal终端环境,输入命令即可。下面是不同Linux版本系统下的安装命令:
Debian/Ubuntu:
$ apt-get install git
Fedora:
$ yum install git (up to Fedora 21)
$ dnf install git (Fedora 22 and later)
Gentoo:
$ emerge --ask --verbose dev-vcs/git
Arch Linux:
$ pacman -S git
openSUSE:
$ zypper install git
Mageia:
$ urpmi git
FreeBSD:
$ pkg install git
Solaris 9/10/11 (OpenCSW):
$ pkgutil -i git
Solaris 11 Express:
$ pkg install developer/versioning/git
OpenBSD:
$ pkg_add git
Alpine:
$ apk add git
-
在Mac下,打开这个网址 https://git-scm.com/download/mac ,将Git的dmg安装包下载下来,安装即可。
(图片来源网上)
-
在Windows下,从这个网址 https://git-for-windows.github.io/ ,将Git的安装包下载下来,按照默认选项一直NEXT下去,安装完成即可。
安装完成之后,以Windows为例,在开始菜单找到"Git" > "Git Bash",或者打开命令提示符,输入git,回车后出现命令选项即安装成功。
安装完成之后,这里需要进一步设置你的Git,在Git Bash命令行下,输入以下命令:
$ git config --global user.name "Your Name"
$ git config --global user.email "email@example.com"
这里需要注意的是,需要你在 https://github.com/ 下先注册属于你的帐号。
创建版本库
以 F:\MyGit\PY_ML 文件夹为例,在 F:\MyGit\ 路径下新建文件夹 PY_ML,做为版本库。打开该新建目录,右键菜单,出现箭头所指选项,点击后出现Git Bash命令行窗口,输入命令 git init
,即初始化该版本库。
此时该目录下即出现一个隐藏的名字为".git"的文件夹
添加文件
在添加文件之前,强调一点,Git无法对二进制文件进行版本跟踪,这里需要以纯文本方式编写文件。所以建议以'UTF-8'的编码格式编写文件。
这里推荐使用Notepad++软件进行文件的编写。打开安装好的Notepad++软件,新建文件后,输入你对自己这个版本库的介绍或者任意内容,以readme.txt的文件名保存在版本库目录下。
这时在命令行下输入
git status
,回车后出现此时Git已经识别到了该版本库下出现了新的文件,但是此时版本库还未添加该文件。
输入git add readme.txt
命令,即可添加该文件。
但是,文件是已经添加了,但是还需要一步,即提交到仓库中去,否则文件如果更改了,Git不会有记录的,这时候输入一下命令
git commit -m "这里输入你的提交说明"
,即可完成提交。
版本控制
我们已经成功提交了readme.txt,后来,我们对这个文件进行了修改,这时候如果输入git status
命令,会出现一下情况:
Git发现了文件的变动,那么文件发生了那些变动呢?
输入git diff
后,出现了变动的情况:
Bash告诉了我们,在readme.txt文件中,在“JasonJe的Python机器学习代码仓库”行下,添加了两行,一行为空行,另一行内容为“123”的修改。此时我们如果需要更新该文件,重新输入命令
git add readme.txt
和git commit -m "修改说明"
即可。
在上述的操作中,我们从创建readme.txt到修改它,共进行了两次版本更新,通过git log
命令,可以看到你的操作情况:
这时候,我们希望将文件恢复到上一版本的时候,需要输入命令
git reset --hard HEAD^
即可。这时候我们查看一下文件,输入cat readme.txt
命令进行查看。可以看到,文件已经恢复到前一版本的时候。
如果我们希望回复到任意版本的时候,就需要使用上述的
git log
命令,寻找需要回复的版本号(commit id),我们输入以下命令git reset --hard 915b342a58198d8e018dab08709df4bff187cc19
,即可恢复到id为915b342a58198d8e018dab08709df4bff187cc19的版本。
这里我们将readme.txt文件修改到最初的时候,输入命令
git status
,会出现我们修改过该文件的提示,此时我们需要撤销该修改,使用git checkout -- readme.txt
即可。
我们在版本库中再添加和提交一个"removeme.txt"文件,如果直接删除该文件
rm remove.txt
,此时Git会提示你该文件被删除了。这时候,你需要使用git checkout -- removeme.txt
来撤销删除;或者你需要使用git rm removeme.txt
和git commit -m "删除说明"
来真正删除该文件。提交远程库
一开始你已经注册了自己的GitHub帐号,这时候你可能需要将代码文件上传到自己的GitHub仓库中,以便不同地点进行你的文件同步管理。
在这开始,你需要进行一些设置,在Git Bash下,输入命令ssh-keygen -t rsa -C "youremail@example.com"
,如果不需要处于安全过多的考虑,一直回车即可。
这时候,在你的用户目录下C:\Users\Username\.ssh就产生了id_rsa和id_rsa.pub这两个文件,其中id_rsa是私钥,不能泄露出去,id_rsa.pub是公钥,可以放心地告诉任何人。
这时候利用记事本文件打开id_rsa.pub文件,复制里面的内容,进入你的GitHub,设置你的SSH keys
"Title"的内容随意设置即可,在"Key"下粘贴刚刚复制的内容后,点击"Add SSH key"即可。
此时需要在你的GitHub下添加你的仓库。在你的GitHub界面下,在右上角点击"+"号,选择"New repository"新建一个仓库,在新建仓库页面下进行如下设置。
需要注意的是,仓库的名字需要设置为你本地仓库的名字。
这时候回到Bash界面,输入一下命令即可git remote add origin git@github.com:yourname/repositoryname.git
和git push -u origin master
即可。
待到上传完成,重新回到你的GitHub,刷新即可看到你的仓库已经提交成功。