不少朋友在用 github 管理项目的时候,都是直接使用 https url 克隆到本地,固然也有些人使用 SSH url 克隆到本地。然而,为何绝大多数人会使用 https url 克隆呢?
这是由于,使用 https url 克隆对初学者来讲会比较方便,复制 https url 而后到 git Bash 里面直接用 clone 命令克隆到本地就行了。而使用 SSH url 克隆却须要在克隆以前先配置和添加好 SSH key 。
所以,若是你想要使用 SSH url 克隆的话,你必须是这个项目的拥有者。不然你是没法添加 SSH key 的。git
运行 git Bash 客户端,输入以下代码:github
1 |
$ cd ~/.ssh |
这两个命令就是检查是否已经存在 id_rsa.pub 或 id_dsa.pub 文件,若是文件已经存在,那么你能够跳过步骤 2,直接进入步骤 3。shell
$ ssh-keygen -t rsa -C "your_email@example.com"
代码参数含义:ssh
-t 指定密钥类型,默认是 rsa ,能够省略。
-C 设置注释文字,好比邮箱。
-f 指定密钥文件存储文件名。编辑器
以上代码省略了 -f 参数,所以,运行上面那条命令后会让你输入一个文件名,用于保存刚才生成的 SSH key 代码,如:分布式
Generating public/private rsa key pair.
Enter file in which to save the key (/c/Users/you/.ssh/id_rsa): [Press enter]ide
固然,你也能够按 enter 不输入文件名,使用默认文件名(推荐),那么就会生成 id_rsa 和 id_rsa.pub 两个秘钥文件。测试
接着又会提示你输入两次密码(该密码是你 push 文件的时候要输入的密码,而不是 github 管理者的密码),url
固然,你也能够不输入密码,直接按回车。那么 push 的时候就不须要输入密码,直接提交到 github 上了,如:spa
Enter passphrase (empty for no passphrase):
Enter same passphrase again:
接下来,就会显示以下代码提示,如:
1 |
Your identification has been saved in /c/Users/you/.ssh/id_rsa. |
当你看到上面这段代码的时候,那就说明,你的 SSH key 已经建立成功,你只须要添加到 github 的 SSH key 上就能够了。
$ clip < ~/.ssh/id_rsa.pub
登陆你的 github 帐号,从又上角的设置( Account Settings )进入,而后点击菜单栏的 SSH key 进入页面添加 SSH key。
点击 Add SSH key 按钮添加一个 SSH key 。把你复制的 SSH key 代码粘贴到 key 所对应的输入框中,记得 SSH key 代码的先后不要留有空格或者回车。固然,上面的 Title 所对应的输入框你也能够输入一个该 SSH key 显示在 github 上的一个别名。默认的会使用你的邮件名称。
在 git Bash 中输入如下代码
$ ssh -T git@github.com
当你输入以上代码时,会有一段警告代码,如:
1 |
The authenticity of host 'github.com (207.97.227.239)' can't be established. |
这是正常的,你输入 yes 回车既可。若是你建立 SSH key 的时候设置了密码,接下来就会提示你输入密码,如:
Enter passphrase for key '/c/Users/Administrator/.ssh/id_rsa':
固然若是你密码输错了,会再要求你输入,知道对了为止。
注意:输入密码时若是输错一个字就会不正确,使用删除键是没法更正的。
密码正确后你会看到下面这段话,如:
1 |
Hi username! You've successfully authenticated, but GitHub does not |
若是用户名是正确的,你已经成功设置 SSH 密钥。若是你看到 “access denied” ,者表示拒绝访问,那么你就须要使用 https 去访问,而不是 SSH 。
如今的情景是:咱们已经在本地建立了一个 Git 仓库后,又想在 github 建立一个 Git 仓库,而且但愿这两个仓库进行远程同步,这样 github 的仓库能够做为备份,又能够其余人经过该仓库来协做。
首先,登陆 github 上,而后在右上角找到 “create a new repo” 建立一个新的仓库。
在 Repository name 填入 testgit,其余保持默认设置,点击 “Create repository” 按钮,就成功地建立了一个新的 Git 仓库:
目前,在 GitHub 上的这个 testgit 仓库仍是空的,GitHub 告诉咱们,能够从这个仓库克隆出新的仓库,也能够把一个已有的本地仓库与之关联,而后,把本地仓库的内容推送到 GitHub 仓库。
如今,咱们根据 GitHub 的提示,在本地的 testgit 仓库下运行命令:$ git remote add origin https://github.com/username/testgit.git
把本地库的内容推送到远程,使用命令:$ git push -u origin master
若是本地仓库没有过 commit, 那么此时就会报错:
1 |
$ git push -u origin master |
缘由:
本地仓库为空
解决方法:
git push 命令其实是把当前分支 master 推送到远程。因为远程库是空的,咱们第一次推送 master 分支时,加上了 –u 参数,Git 不但会把本地的 master 分支内容推送的远程新的 master 分支,还会把本地的 master 分支和远程的 master 分支关联起来,在之后的推送或者拉取时就能够简化命令。
推送成功后,能够马上在 github 页面中看到远程库的内容已经和本地如出一辙了。
从如今起,只要本地做了提交,就能够经过以下命令:$ git push origin master
把本地 master 分支的最新修改推送到 github 上了,如今你就拥有了真正的分布式版本库了。
上面咱们了解了先有本地库,后有远程库时候,如何关联远程库。
如今咱们想,假如远程库有新的内容了,我想克隆到本地来 如何克隆呢?
首先,登陆 github,建立一个新的仓库,名字叫 testgit2. 以下:
如今,远程库已经准备好了,下一步是使用命令 git clone 克隆一个本地库了。以下所示:$ git clone git@github.com:username/testgit2.git
接着在我本地目录下 生成 testgit2 目录了,以下所示:
接下来在本地上对 testgit2 的修改就能够经过命令 git push 推送到远程仓库。