终于要正面学习Git版本控制系统了,好激动啊
2008年Github网站才上线,至今才12年呢,但是已经是妥的不能更妥的分布式开源版本管理系统,世界最流行的,没有之一
2005年linus就写出来了,但是08年网站才上线。当时他只花了两周,,就用C写出来了Git,一个月内,Linux系统的源代码就已经用Git来管理上了,不再用02年到05年免费让linux开源社区使用的商业版本管理系统BitKeeper。(当时主要是因为linux社区里有人试图破解bitkeeper的协议,所以bitmover公司就怒了,本来就是出于人道主义精神让你们免费用的,你们还乱七八糟搞破坏。。。于是就收回了linux社区的免费使用权。谁知道linus真是神一样的牛人,两周就写出来一个Git,一个月就用上了。。。)
怎么感觉大牛写代码跟玩儿似的,想写个啥就能立刻呼呼呼写出来
其实除了免费让他们用得bitkeeper外,还有svs, svn等版本控制系统,但是后两个是集中式的版本控制系统,所以linus非常不喜欢。
最早Git是在Linux上开发的,很长一段时间内,Git也只能在Linux和Unix系统上跑。不过,慢慢地有人把它移植到了Windows上。现在,Git可以在Linux、Unix、Mac和Windows这几大平台上正常运行了。
版本库是集中存放在中央服务器的,而干活的时候,用的都是自己的电脑,所以要先从中央服务器取得最新的版本,然后开始干活,干完活了,再把自己的活推送给中央服务器。中央服务器就好比是一个图书馆,你要改一本书,必须先从图书馆借出来,然后回到家自己改,改完了,再放回图书馆。
最大的毛病就是必须联网才能工作,依赖网速
分布式版本控制系统根本没有“中央服务器”,每个人的电脑上都是一个完整的版本库,这样,你工作的时候,就不需要联网了,因为版本库就在你自己的电脑上。既然每个人电脑上都有一个完整的版本库,那多个人如何协作呢?比方说你在自己电脑上改了文件A,你的同事也在他的电脑上改了文件A,这时,你们俩之间只需把各自的修改推送给对方,就可以互相看到对方的修改了。
在实际使用分布式版本控制系统的时候,其实很少在两人之间的电脑上推送版本库的修改,因为可能你们俩不在一个局域网内,两台电脑互相访问不了,也可能今天你的同事病了,他的电脑压根没有开机。因此,分布式版本控制系统通常也有一台充当“中央服务器”的电脑,但这个服务器的作用仅仅是用来方便“交换”大家的修改,没有它大家也一样干活,只是交换修改不方便而已。
和集中式版本控制系统相比,分布式版本控制系统的安全性要高很多,因为每个人电脑里都有完整的版本库,某一个人的电脑坏掉了不要紧,随便从其他人那里复制一个就可以了。而集中式版本控制系统的中央服务器要是出了问题,所有人都没法干活了。
Git的优势不单是不必联网这么简单,Git还有极其强大的分支管理,把SVN等远远抛在了后面。
CVS作为最早的开源而且免费的集中式版本控制系统,直到现在还有不少人在用。由于CVS自身设计的问题,会造成提交文件不完整,版本库莫名其妙损坏的情况。
同样是开源而且免费的SVN修正了CVS的一些稳定性问题,是目前用得最多的集中式版本库控制系统。
除了免费的外,还有收费的集中式版本控制系统,比如IBM的ClearCase(以前是Rational公司的,被IBM收购了),特点是安装比Windows还大,运行比蜗牛还慢,能用ClearCase的一般是世界500强,他们有个共同的特点是财大气粗,或者人傻钱多。
微软自己也有一个集中式版本控制系统叫VSS,集成在Visual Studio中。由于其反人类的设计,连微软自己都不好意思用了。
分布式版本控制系统除了Git以及促使Git诞生的BitKeeper外,还有类似Git的Mercurial和Bazaar等。这些分布式版本控制系统各有特点,但最快、最简单也最流行的依然是Git
看廖雪峰老师的教程就好啦,超级简单
因为Git是分布式版本管理系统,所以每个机器都必须自报家门:你的名字和Email地址。
$ git config --global user.name "wudidamanman"
$ git config --global user.email "[email protected]"
安装的这个git bash软件用的是bash脚本语言,所以和linux命令差不多,下面这些步骤都是用命令完成的,我按照顺序写的
$ pwd
/c/Users/Administrator
$ cd /f/myGithub
$ mkdir CurveOfVehicleDrivingCondition
创建一个本地git仓库,这个命令执行后会在文件夹里有一个.git文件,不要去修改它,不然容易出幺蛾子错误。
注意这里创建的只是本地仓库,和GitHub没有任何关系哦。要想用github,需要在GitHub网站上new一个repo,即库,然后用本地的Git bash软件连接到你的GitHub账户(需要用SSH协议,GitHub网站需要知道你的公钥,以以确认更新的版本确实是你发的)
$ git init
Initialized empty Git repository in F:/myGithub/CurveOfVehicleDrivingCondition/.git/
添加文件到本地库。先把这些文件放在本地的你的这个库的路径下,然后再用这个命令。不然git再牛逼,也找不到你的文件到底在哪。
文件名可以是中文哦,路径名最好不要有中文
$ git add 工况曲线
把git add命令添加的所有文件全部提交到本地库,即git add并没有真正提交,所以这个命令执行速度很快的,你可以执行多条git add命令后,再写一条git commit一次性地提交到本地库,提交到库需要文件拷贝,所以文件大则会花点时间,命令执行的就慢一点。
横杠和m之间不要有空格,否则会报错
$ git commit -m "add more files"
Administrator@PC-20190617YNTF MINGW64 /f/myGithub/CurveOfVehicleDrivingCondition (master)
$ ssh-keygen -t rsa -C "[email protected]"
Generating public/private rsa key pair.
Enter file in which to save the key (/c/Users/Administrator/.ssh/id_rsa):
Created directory '/c/Users/Administrator/.ssh'.
Enter passphrase (empty for no passphrase):
Enter same passphrase again:
Your identification has been saved in /c/Users/Administrator/.ssh/id_rsa
Your public key has been saved in /c/Users/Administrator/.ssh/id_rsa.pub
The key fingerprint is:
SHA256:0U7iswV2AtIG4AsLoR1jwxwHl9tzvyi2iTuV85M/YgU wuman4@outlook.com
The key's randomart image is:
+---[RSA 3072]----+
|.oO+=+. |
|.=o*..o. . |
|+ o + * + |
|.o .. ooEO |
|. . +Soo |
| + +o |
| . o.+ . |
| ..o.B o |
| o+o+ +.. |
+----[SHA256]-----+
一路回车就好,就会在你的主目录下生成一个.ssh文件,里面就是你的私钥和公钥
.pub的是公钥,public嘛,注意这和publisher软件没啥关系,用notepad++打开观看就好了。
你要用几个电脑就要几个SSH公钥哈,git才知道都是合法身份推送给他的
一般是origin,我这次叫做origi,因为我前面用origin这个名字作为一个远程库的名字了,再用就提示fatal: remote origin already exists.
其实随便叫啥都行
$ git remote add origi git@github.com:wudidamanman/Curve.git
注意要保证自己从本地的Git库上传到GitHub的远程库时,远程库是空的,什么都没有,才能传成功。
哈哈,终于上传啦
$ git push -u origi master
Warning: Permanently added the RSA host key for IP address '13.229.188.59' to the list of known hosts.
Enumerating objects: 2761, done.
Counting objects: 100% (2761/2761), done.
Delta compression using up to 6 threads
Compressing objects: 100% (2760/2760), done.
Writing objects: 100% (2761/2761), 38.41 MiB | 415.00 KiB/s, done.
Total 2761 (delta 889), reused 0 (delta 0), pack-reused 0
remote: Resolving deltas: 100% (889/889), done.
To github.com:wudidamanman/Curve.git
* [new branch] master -> master
Branch 'master' set up to track remote branch 'master' from 'origi'.