git学习 GitHub远程仓库 / 使用GitHub(第五天)

菜鸟在亲戚家,做作业受阻呀!现在改变作息,只为每天一更!

文章目录

  • GitHub远程仓库
    • GitHub添加ssh
    • GitHub创建仓库
      • SSH警告
      • 小结
    • 远程克隆
      • 小结
    • 使用github(2020/7/15补)

GitHub远程仓库

GitHub添加ssh

这里读者自己注册GitHub账号

第一步:创建SSH Key。在用户主目录下(一般是:c://Users/asus/ 或者 自己全盘搜一下),看看有没有.ssh目录,如果有,再看看这个目录下有没有 id_rsaid_rsa.pub 这两个文件,如果已经有了,可直接跳到下一步。如果没有,在git仓库处打开Git Bash,创建SSH Key:

ssh-keygen -t rsa -C "[email protected]"

你需要把邮件地址换成你自己的邮件地址,然后一路回车,使用默认值即可,由于这个Key也不是用于军事目的,所以也无需设置密码 (Enter passphrase (empty for no passphrase): 不需要打密码) 。

第二步:打开GitHub
git学习 GitHub远程仓库 / 使用GitHub(第五天)_第1张图片
git学习 GitHub远程仓库 / 使用GitHub(第五天)_第2张图片
在这里插入图片描述
添加title,随便什么都可以;

填写key,自己的.ssh里面的id_rsa.pub文件的内容。

为什么GitHub需要SSH Key呢?因为GitHub需要识别出你推送的提交确实是你推送的,而不是别人冒充的,而Git支持SSH协议,所以,GitHub只要知道了你的公钥,就可以确认只有你自己才能推送。


当然,GitHub允许你添加多个Key。假定你有若干电脑,你一会儿在公司提交,一会儿在家里提交,只要把每台电脑的Key都添加到GitHub,就可以在每台电脑上往GitHub推送了。


最后友情提示,在GitHub上免费托管的Git仓库,任何人都可以看到喔(但只有你自己才能改)。所以,不要把敏感信息放进去


如果你不想让别人看到Git库,有两个办法,一个是交点保护费,让GitHub把公开的仓库变成私有的,这样别人就看不见了(不可读更不可写)。另一个办法是自己动手,搭一个Git服务器,因为是你自己的Git服务器,所以别人也是看不见的。这个方法我们后面会讲到的,相当简单,公司内部开发必备

确保你拥有一个GitHub账号后,我们就即将开始远程仓库的学习。

GitHub创建仓库

git学习 GitHub远程仓库 / 使用GitHub(第五天)_第3张图片
git学习 GitHub远程仓库 / 使用GitHub(第五天)_第4张图片
只写一个,Repository name按照自己的git仓库起名就好,其它默认,然后确定。
git学习 GitHub远程仓库 / 使用GitHub(第五天)_第5张图片
目前,在GitHub上的这个Git_warehouse仓库还是空的,GitHub告诉我们,可以从这个仓库克隆出新的仓库(当然这个是空的,克隆也没意义,但是你克隆可以省去在电脑上 git init 这个步骤,克隆下面会讲),也可以把一个已有的本地仓库与之关联,然后,把本地仓库的内容推送到GitHub仓库

现在,我们根据GitHub的提示,在本地的Git_warehouse仓库下运行命令:

git remote add origin https://github.com/pbw-langwang/Git_warehouse.git  或
git remote add origin git@github.com:pbw-langwang/Git_warehouse.git

注意:把上面的pbw-langwang替换成你自己的GitHub账户名,否则,你在本地关联的就是我的远程库,关联没有问题,但是你以后推送是推不上去的,因为你的SSH Key公钥不在我的账户列表中。

添加后,远程库的名字就是origin,这是Git默认的叫法,也可以改成别的,但是origin这个名字一看就知道是远程库。

不会有反应,然后执行:

git push -u origin master

出现输入GitHub用户名和密码界面(https是这样,ssh菜鸟没试,如果有警告可以看看下面的SSH警告),成功后,
git学习 GitHub远程仓库 / 使用GitHub(第五天)_第6张图片
把本地库的内容推送到远程,用 git push 命令,实际上是把当前分支master推送到远程(分支暂时不管,后面讲分支再说)。

由于远程库是空的,我们第一次推送master分支时,加上了 -u 参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令。

刷新GitHub页面,看到远程库的内容已经和本地一模一样:
git学习 GitHub远程仓库 / 使用GitHub(第五天)_第7张图片
从现在起,只要本地作了提交,就可以通过命令:

git push origin master

把本地master分支的最新修改推送至GitHub,现在,你就拥有了真正的分布式版本库!

SSH警告

当你第一次使用Git的clone或者push命令连接GitHub时,会得到一个警告:

The authenticity of host 'github.com (xx.xx.xx.xx)' can't be established.
RSA key fingerprint is xx.xx.xx.xx.xx.
Are you sure you want to continue connecting (yes/no)?

这是因为Git使用SSH连接,而SSH连接在第一次验证GitHub服务器的Key时,需要你确认GitHub的Key的指纹信息是否真的来自GitHub的服务器,输入yes回车即可。(如果你是用的https的一个,则不会警告这个)

Git会输出一个警告,告诉你已经把GitHub的Key添加到本机的一个信任列表里了:

Warning: Permanently added 'github.com' (RSA) to the list of known hosts

这个警告只会出现一次,后面的操作就不会有任何警告了。

如果你实在担心有人冒充GitHub服务器,输入yes前可以对照GitHub的RSA Key的指纹信息是否与SSH连接给出的一致。

小结

要关联一个远程库,使用命令 git remote add origin git@server-name:path/repo-name.git;

关联后,使用命令git push -u origin master第一次推送master分支的所有内容;

此后,每次本地提交后,只要有必要,就可以使用命令git push origin master推送最新修改;

分布式版本系统的最大好处之一是在本地工作完全不需要考虑远程库的存在,也就是有没有联网都可以正常工作,而SVN在没有联网的时候是拒绝干活的!当有网络的时候,再把本地提交推送一下就完成了同步,真是太方便了!

远程克隆

先创建一个仓库(按上一个的步骤,不过要勾选Initialize this repository with a README)

勾选Initialize this repository with a README,这样GitHub会自动为我们创建一个README.md文件。创建完毕后,可以看到README.md文件。(菜鸟搜索了一下README.md是干什么的?有什么作用?但是网上没有答案,菜鸟猜测,只是以免你这个仓库是空的,你克隆后没有实质的意义,所以加上去的,菜鸟已经在知乎发问了,如果有好的回答,菜鸟会来补充)

现在,远程库已经准备好了,下一步是用命令git clone克隆一个本地库:

git clone git@github.com:pbw-langwang/gitskills.git    或
git clone https://github.com/pbw-langwang/gitskills.git

你也许还注意到,GitHub给出的地址不止一个,还可以用https://github.com/michaelliao/gitskills.git这样的地址。实际上,Git支持多种协议,默认的git://使用ssh,但也可以使用https等其他协议。

使用https除了速度慢以外,还有个最大的麻烦是每次推送都必须输入口令,但是在某些只开放http端口的公司内部就无法使用ssh协议而只能用https。

小结

克隆一个仓库,首先必须知道仓库的地址,然后使用 git clone 命令克隆。

Git支持多种协议,包括https,但ssh协议速度最快

克隆时,直接在原来的git仓库打开 git bush ,克隆后,直接一整个到了原来的git仓库了,并一起管理
git学习 GitHub远程仓库 / 使用GitHub(第五天)_第8张图片
菜鸟修改了gitskills里面的东西,然后 git status

On branch master
Your branch is up to date with 'origin/master'.

Untracked files:
  (use "git add ..." to include in what will be committed)
        gitskills/

nothing added to commit but untracked files present (use "git add" to track)

使用github(2020/7/15补)

我们一直用GitHub作为免费的远程仓库,如果是个人的开源项目,放到GitHub上是完全没有问题的。其实GitHub还是一个开源协作社区,通过GitHub,既可以让别人参与你的开源项目,也可以参与别人的开源项目。

在GitHub出现以前,开源项目开源容易,但让广大人民群众参与进来比较困难,因为要参与,就要提交代码,而给每个想提交代码的群众都开一个账号那是不现实的,因此,群众也仅限于报个bug,即使能改掉bug,也只能把diff文件用邮件发过去,很不方便。

但是在GitHub上,利用Git极其强大的克隆和分支功能,广大人民群众真正可以第一次自由参与各种开源项目了。

如何参与一个开源项目呢?比如人气极高的bootstrap项目,这是一个非常强大的CSS框架,你可以访问它的项目主页https://github.com/twbs/bootstrap,点“Fork”就在自己的账号下克隆了一个bootstrap仓库,然后,从自己的账号下clone。

一定要从自己的账号下clone仓库,这样你才能推送修改。如果从bootstrap的作者的仓库地址[email protected]:twbs/bootstrap.git克隆,因为没有权限,你将不能推送修改。

Bootstrap的官方仓库twbs/bootstrap、你在GitHub上克隆的仓库my/bootstrap,以及你自己克隆到本地电脑的仓库,他们的关系就像下图显示的那样:
git学习 GitHub远程仓库 / 使用GitHub(第五天)_第9张图片
如果你想修复bootstrap的一个bug,或者新增一个功能,立刻就可以开始干活,干完后,往自己的仓库推送。

如果你希望bootstrap的官方库能接受你的修改,你就可以在GitHub上发起一个pull request。当然,对方是否接受你的pull request就不一定了。

如果你没能力修改bootstrap,但又想要试一把pull request,那就Fork一下我的仓库:https://github.com/pbw-langwang/gitskills,创建一个your-github-id.txt的文本文件,写点自己学习Git的心得,然后推送一个pull request给我,我会看内容而定是否接受。

你可能感兴趣的:(git,git,GitHub远程仓库,使用GitHub,GitHub添加ssh,git克隆远程仓库)