git config --global user.name "你在github上的用户名" git config --global user.email 注册的邮件地址 mkdir ~/.ssh cd ~/.ssh ssh-keygen -t rsa -C "注册的邮件地址" cat id_rsa.pub
然后把内容贴到github网站ssh keys中
详细
首先在github上注册一个账号,创建一个“自定义名称”的版本库
创建完成之后,github会提供一个简易的操作指南
Global setup: Set up git git config --global user.name "user_name" git config --global user.email ×××@×××.com Add your public key Next steps: mkdir project_name cd project_name git init touch README git add README git commit -m 'first commit' git remote add origin [email protected]:user_name/project_name.git git push -u origin master Existing Git Repo? cd existing_git_repo git remote add origin [email protected]:user_name/project_name.git git push -u origin master Importing a Subversion Repo? Click here When you're done: Continue
按照这个步骤来,我乎略来第一步的
Add your public key,以为他仅仅是一个帮助链接
但是在我提交代码的时候,出现了错误提示
“Permission denied (publickey). fatal: The remote end hung up unexpectedly ”
这个错误的意思无非就是权限验证失误
造成没有权限的主要原因就是我漏掉的一步
于是我去补充,点击那个帮助链接就可以看到内容
http://help.github.com/linux-set-up-git/
按照步骤首先是
第一步 检查 SSH keys
$ cd ~/.ssh
检查是否有".ssh"这个目录,如果没有则直接跳转到第三步,其他情况进入第二步
第二步 备份 并 删除已经存在的ssh key
如果你的目录文件中已经存在了ssh文件,那么你最好是备份并删除这些旧文件
操作步骤如下:
$ ls # 显示来当前目录下的所有子目录 # config id_rsa id_rsa.pub known_hosts $ mkdir key_backup # 在当前目录下创建一个叫做"key_backup"的子目录 $ cp id_rsa* key_backup # 备份以前的key文件到上面新建的文件夹中 $ rm id_rsa* # 删除旧的key文件
第三部 生成一个新的ssh key
按照下面的代码操作,即可生成一个新的ssh key。当你被要求输入保存key的文件目录时,可以直接按enter键使用默认设置
$ ssh-keygen -t rsa -C "[email protected]" # 使用一个私人的email地址,来生成一个ssh key # 生成 公开/私有 的一对key(Generating public/private rsa key pair.) # 输入要保存key文件的目录(enter键 使用括弧里面的默认设置) (/Users/your_user_directory/.ssh/id_rsa):<press enter> # 然后输入一个密码(passphrases)这个密码可以不用输入,直接回车就可以了,要不然每次提交代码都要输入密码 Enter passphrase (empty for no passphrase):<enter a passphrase> Enter same passphrase again:<enter passphrase again>
然后它会给你返回这些东西:
Your identification has been saved in /Users/your_user_directory/.ssh/id_rsa. Your public key has been saved in /Users/your_user_directory/.ssh/id_rsa.pub. The key fingerprint is: 01:0f:f4:3b:ca:85:d6:17:a1:7d:f0:68:9d:f0:a2:db [email protected] The key's randomart image is: +--[ RSA 2032]----+ | .+ + | | ssssssss | | = * * | | o = + | | ssss . | | o oss | | o .sE | | | | | +-----------------+
最后 就是把你的SSH添加到你的GitHub账号中
访问网站并按照下列顺序访问 “Account Settings” > Click “SSH Public Keys” > Click “Add another public key”
打开上面生成的id_rsa.pub文件 (Notepad, TextEdit, or gedit will do just fine). 这个是你的公开的 SSH key. 你可能需要打开“查看隐藏目录文件”选项,才能找到他,因为这个 .ssh 是隐藏文件目录. 接下来就是非常重要的是,复制文件中的key内容(不要添加任意空格或者空行),复制到网站中弹出的文本框中,点击确定就大功告成了。
接下来测试一下
$ ssh -T [email protected] to ssh to github Which should give you this: The authenticity of host 'github.com (207.97.227.239)' can't be established. RSA key fingerprint is 16:27:ac:a5:76:28:2d:36:63:1b:56:4d:eb:df:a6:48. Are you sure you want to continue connecting (yes/no)? Don’t worry, this is supposed to happen. Type “yes”. Hi username! You've successfully authenticated, but GitHub does not provide shell access. Having problems?