Bitbucket上使用SSH协作
【说明】此文因样式原因,图片显示不全,点击图片可查看完整图片 。
【场景】在bitbucket上,firstbit拥有版本仓库(名为:prisshop);为方便开发,他邀请了jscon共同维护这个仓库,可又不想让jscon使用Fork方式,而是像这个仓库的管理员那样自由操作这个版本库。
换言之,这个版本仓库的拥有者是firstbit,管理者是firstbit与jscon。
>>操作<<
Fork方式是针对普遍的协作,如果你就是团队中的人员,上面的方式无疑会拖项目的后腿。这就需要使用仓库共享模式,让项目拥有者把你加入团队成员,这样你就能直接把修改的内容push到项目中了。
为了方便以后的使用,应当使用SSH方式,这样既可以不输入密码,也可以辨认提交的用户名。
Bitbucket文档里提供了一个非常详尽的的教程: Set up SSH for Git 。现翻译如下:
(以下步骤同时适用于用户 firstbit 与 jscon )
1、生成公钥与私密
首先就是你的电脑上创建一个ssh key。
关于SSH原理可参看阮一峰的博文《 SSH原理与运用 》,讲的非常详尽,推荐:
使用密码登录,每次都必须输入密码,非常麻烦。好在SSH还提供了公钥登录,可以省去输入密码的步骤。所谓"公钥登录",原理很简单,就是用户将自己的公钥储存在远程主机上。登录的时候,远程主机会向用户发送一段随机字符串,用户用自己的私钥加密后,再发回来。远程主机用事先储存的公钥进行解密,如果成功,就证明用户是可信的,直接允许登录shell,不再要求密码。这种方法要求用户必须提供自己的公钥。如果没有现成的,可以直接用ssh-keygen生成一个
我们打开Git Bash,然后输入:
ssh-keygen
提示让你输入密钥的地址与名字,默认是 ~/.ssh/id_rsa,这里我们使用 ~/.ssh/bitbucket_id_rsa,一路回车得到两个文件(期间会让你输入passphass用来加密私钥,这里为简单起见就为空,所以直接回车):
黄底标记的文件是自动生成的密钥,config文件需要自己创建
2、创建config文件
如上图所示,在创建一个config文件(没有后缀名),在里面输入:
Host bitbucket.org IdentityFile ~/. ssh /bitbucket_id_rsa注意第二行是有缩进(也可以是一个空格)是非常重要的,不要省略。里面的“~/.ssh/bitbucket_id_rsa”就是刚才生成的私钥路径。
3、更新.bashrc文件
SSH认证前提是开启认证代理,这个代理的信息可通过以下命令查看:
$ eval ' ssh-agent ' SSH_AUTH_SOCK =/tmp/ ssh -GDRrxm2136/agent. 2136 ; export SSH_AUTH_SOCK; SSH_AGENT_PID = 5492 ; export SSH_AGENT_PID; echo Agent pid 5492 ;每次开启Git Bash窗口前需要开启这个代理,显得有些麻烦——一个有效的解决方法就是当启动Shell时启动开启这个代理,这就用到吧.bashrc文件。
这个文件可以从 a post by Joseph M. Reagle Jr. from MIT 里Copy来,内容如下:
SSH_ENV=$HOME/. ssh / environment function start_agent { echo " Initialising new SSH agent... " /usr/bin/ ssh-agent | sed ' s/^echo/#echo/ ' > ${SSH_ENV} echo succeeded chmod 600 ${SSH_ENV} . ${SSH_ENV} > /dev/ null /usr/bin/ ssh-add ; } # Source SSH settings, if applicable if [ -f " ${SSH_ENV} " ]; then . ${SSH_ENV} > /dev/ null # ps ${SSH_AGENT_PID} doesn ' t work under cywgin ps -ef | grep ${SSH_AGENT_PID} | grep ssh-agent $ > /dev/ null || { start_agent; } else start_agent; fi将上面的内容直接保存到 ~/.bashrc文件中即可。
注意: 这个文件一定要保存到home路径下,可以在shell 中输入:
touch ~/.bashrc创建之后,再用其他编辑器(比如Notepad++等)打开把上面的内容拷贝进去即可。
重启Git Bash!
然后提示输入passphase(只有第一次启动输入,之后的不会再输入了)后,验证在代理里注册成功:
$ ssh-add - l 2048 0f: 37 : 21 :af:1b: 31 :d5:cd: 65 : 58 :b2: 68 :4a:ba:a2: 46 /Users/manthony/. ssh /id_rsa (RSA)由于默认是添加id_rsa的,而我们自己创建了一个bitbucket_id_rsa,所以得手动添加:
ssh-add bitbucket_id_rsa4、在Bitbucket账号中添加公钥
1) 在Git Bash中使用cat命令获得公钥信息:
cat ~/. ssh /bitbucket_id_rsa.pub将获得的代码复制下来,供后面使用:
获取公钥信息
2) 打开浏览器,进入主页的账号管理(Manage Account):
账号管理
3) 点击SSH Keys选项卡,粘贴入刚才复制的公钥即可:
粘入公钥
4) 回到命令行,输入下面命令确认能与Bitbucket网站SSH通信:
ssh -T git@bitbucket.org如果出现下面的信息:
conq: logged in as jscon.
You can use git or hg to connect to Bitbucket. Shell access is disabled.
则说明你已经能用这个key与bitbucket网站SSH通信了。5、更新远程服务器
之前使用https跟远程服务器通信,现在更新成ssh方式通信即可。Git工作原理还是一致的,只是格式上有所区别,主要体现在账号出现的位置上:
SSH与HTTPS格式上的区别
比如clone :
git clone git@bitbucket.org:firstbit/prisshop.git使用SSH方式clone版本库
比如push :
先注册远程SSH服务器:
git remote add bitbucket git@bitbucket.org:firstbit/prisshop.git再push即可:
git push bitbucket
6、邀请入伙
firstbit与jscon两个人现在都按上面的五步分别在自己的机器上完成跟自己bitbucket账号的SSH通信的配置后,之后一起协作就非常简单了。
1) 首先,firstbit发起邀请。firstbit到版本库首页点击发送请求按钮,邀请jscon:点击发送邀请按钮
输入用户名jscon后,按share按钮即可
同时在仓库管理面板中定义jscon对该版本库的使用权限:
给JSCON用户定义管理(读、写、管理)权限
2) jscon登录自己的首页,系统提示Inbox(收件箱)收到firstbit的邀请信:
jscon收到的要邀请信
现在jscon就可以在自己的机器上管理prisshop版本仓库了(就像自己创建的版本仓库那样,唯一的区别是该版本的所有权归firstbit)。
【后记】好久没有在cnblogs上面写博客了,因为去年整了一个wordpress( http://HdhCmsTestjanscon测试数据 ),基本在上面发的。
另外有微博 http://weibo测试数据/boychenney 欢迎关注。
分类: 展露头角
标签: git , ssh , 技巧 , 教程 , bitbucket
绿色通道: 好文要顶 关注我 收藏该文 与我联系
Bitbucket上使用SSH协作
0
0
(请您对文章做出评价)
? 博主上一篇: (matlab)对某一序列进行Huffman编码
? 首页上一篇: 使用 Lambda 表达式编写递归一:前言及基础
? 首页下一篇: (翻译)使用Cocos2D 2.X制作一个简单iPhone游戏教程——第1部分posted @ 2013-04-09 16:47 简时空-jscon 阅读(204) 评论( 1 ) 编辑 收藏
作者: Leo_wl
出处: http://HdhCmsTestcnblogs测试数据/Leo_wl/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
版权信息查看更多关于Bitbucket上使用SSH协作的详细内容...
声明:本文来自网络,不代表【好得很程序员自学网】立场,转载请注明出处:http://haodehen.cn/did46296