由于Windows上的Git仓库存在一些严重问题,我们正在将我们的Git'服务器'移植到Linux。
假设我已经安装了msysgit for Windows和Putty,那么在克隆,拉取和推送时如何验证SSH连接?
答案 0 :(得分:3)
如果是SSH:
.ssh
文件夹中,例如C:\Users\Name\.ssh
,就像在unix上一样。您仍然可以使用HTTP,它将(1)始终询问用户名和密码,或者(2)您还可以将用户名和密码放入网址:https://username:password@git.mydomain.com/...
答案 1 :(得分:2)
This page涵盖了使用PuTTy进行Git公钥认证的所有内容。 简而言之:
答案 2 :(得分:0)
我建议您完成this tutorial。
需要注意的是,它是关于github的,所以告诉服务器你的SSH密钥的故事是不同的。
您还打算如何管理开发人员,这也有所不同。 “问题”是SSH与真正的远程(服务器端,我的意思)用户一起运行,这些用户必须拥有常规的Unix系统帐户。
如果您只有少数开发人员,这没关系。然后,您只需要将它们全部添加到一个特殊组(例如devel
),并确保使用git init --bare --shared=group
初始化服务器端裸存储库,并使它们成为可写组并属于该组devel
(也可以通过在"group sticky bit" set并且属于该组devel
的目录下创建所有存储库来帮助解决这个问题。
要在这样的设置中将开发人员密钥的公共部分分发到服务器,您必须将该关键部分(从开发人员的id_rsa.pub
文件,它的ASCII)复制并粘贴到文件{{1}文件。如果该文件不存在,请创建它。
如果密钥是在安装了OpenSSH客户端的计算机上生成的,则可以一步使用/home/developer/.ssh/authorized_keys
程序传输密钥。
这可能会变得混乱,因此您可能会考虑实施一个虚拟化Git用户的解决方案(如github)。有很多可供选择: