Git初识,建本地git库,把本地库传到GitHub远程库

文章目录

  • 历史(linus开挂)
  • 集中式 VS 分布式
    • 集中式
    • 分布式
    • battle
  • 安装
  • 创建本地git仓库
  • 把本地库传到GitHub远程库中

今天终于要把一些项目搬上GitHub了,,,,拖延了一年多的计划诶

终于要正面学习Git版本控制系统了,好激动啊

历史(linus开挂)

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这几大平台上正常运行了。

集中式 VS 分布式

集中式

版本库是集中存放在中央服务器的,而干活的时候,用的都是自己的电脑,所以要先从中央服务器取得最新的版本,然后开始干活,干完活了,再把自己的活推送给中央服务器。中央服务器就好比是一个图书馆,你要改一本书,必须先从图书馆借出来,然后回到家自己改,改完了,再放回图书馆。

最大的毛病就是必须联网才能工作,依赖网速

分布式

分布式版本控制系统根本没有“中央服务器”,每个人的电脑上都是一个完整的版本库,这样,你工作的时候,就不需要联网了,因为版本库就在你自己的电脑上。既然每个人电脑上都有一个完整的版本库,那多个人如何协作呢?比方说你在自己电脑上改了文件A,你的同事也在他的电脑上改了文件A,这时,你们俩之间只需把各自的修改推送给对方,就可以互相看到对方的修改了。

在实际使用分布式版本控制系统的时候,其实很少在两人之间的电脑上推送版本库的修改,因为可能你们俩不在一个局域网内,两台电脑互相访问不了,也可能今天你的同事病了,他的电脑压根没有开机。因此,分布式版本控制系统通常也有一台充当“中央服务器”的电脑,但这个服务器的作用仅仅是用来方便“交换”大家的修改,没有它大家也一样干活,只是交换修改不方便而已。

battle

  • 和集中式版本控制系统相比,分布式版本控制系统的安全性要高很多,因为每个人电脑里都有完整的版本库,某一个人的电脑坏掉了不要紧,随便从其他人那里复制一个就可以了。而集中式版本控制系统的中央服务器要是出了问题,所有人都没法干活了。

  • 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初识,建本地git库,把本地库传到GitHub远程库_第1张图片
因为Git是分布式版本管理系统,所以每个机器都必须自报家门:你的名字和Email地址。

$ git config --global user.name "wudidamanman"
$ git config --global user.email "[email protected]"

创建本地git仓库

安装的这个git bash软件用的是bash脚本语言,所以和linux命令差不多,下面这些步骤都是用命令完成的,我按照顺序写的

  • pwd命令显示当前目录
$ pwd
/c/Users/Administrator
  • cd命令切换目录
$ cd /f/myGithub
  • mkdir 创建目录
$ mkdir CurveOfVehicleDrivingCondition
  • git init命令

创建一个本地git仓库,这个命令执行后会在文件夹里有一个.git文件,不要去修改它,不然容易出幺蛾子错误。

注意这里创建的只是本地仓库,和GitHub没有任何关系哦。要想用github,需要在GitHub网站上new一个repo,即库,然后用本地的Git bash软件连接到你的GitHub账户(需要用SSH协议,GitHub网站需要知道你的公钥,以以确认更新的版本确实是你发的)

$ git init
Initialized empty Git repository in F:/myGithub/CurveOfVehicleDrivingCondition/.git/
  • git add命令

添加文件到本地库。先把这些文件放在本地的你的这个库的路径下,然后再用这个命令。不然git再牛逼,也找不到你的文件到底在哪。

文件名可以是中文哦,路径名最好不要有中文

$ git add 工况曲线
  • git commit命令

把git add命令添加的所有文件全部提交到本地库,即git add并没有真正提交,所以这个命令执行速度很快的,你可以执行多条git add命令后,再写一条git commit一次性地提交到本地库,提交到库需要文件拷贝,所以文件大则会花点时间,命令执行的就慢一点。

横杠和m之间不要有空格,否则会报错

$ git commit -m "add more files"

把本地库传到GitHub远程库中

  • 在GitHub网站注册账号并登录
  • 在git bash软件创建SSH密钥
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++打开观看就好了。

  • 在GitHub网站添加SSH key
    就是把你的公钥添加进去,跟着廖雪峰老师教程就好了

你要用几个电脑就要几个SSH公钥哈,git才知道都是合法身份推送给他的

  • 在GitHub网站新建一个库
    在这里插入图片描述
    建库为public就网友都可以看到

  • 给GitHub的库起个远程名字

一般是origin,我这次叫做origi,因为我前面用origin这个名字作为一个远程库的名字了,再用就提示fatal: remote origin already exists.

其实随便叫啥都行

$ git remote add origi git@github.com:wudidamanman/Curve.git

注意要保证自己从本地的Git库上传到GitHub的远程库时,远程库是空的,什么都没有,才能传成功。

  • 把本地库上传到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'.

就可以在GitHub网站看到啦
Git初识,建本地git库,把本地库传到GitHub远程库_第2张图片

你可能感兴趣的:(Git)