将Mac Hudson从站连接到Linux主站时,SSH密钥身份验证失败
好吧,所以我让Hudson(v1.393)在Ubuntu VM中运行,一切正常。
但是我正在尝试将一个Mac奴隶添加到Ubuntu主服务器中,我遇到了一些问题。
我已经设置了SSH密钥,因此从命令行,Ubuntu VM可以使用密钥ssh到Mac上的一个名为hudson的用户。
在Hudson slave配置中,我选择了“通过SSH在Unix机器上启动从属代理”并输入了主机IP,从属用户的用户名以及我的私钥文件在主服务器上的位置(已添加到主服务器)奴隶上的授权密钥文件)。
但是,主站无法连接到从站。
查看日志(下面),它正在尝试使用密码进行身份验证。
这是基于密钥的SSH尝试失败的后退吗?
Hudson是否只尝试使用密码进行身份验证,我需要更改其他内容以使其使用配置中定义的密钥文件?
是不是可以通过mac上的ssh启动slave代理? (我知道这种类型的奴隶启动方法明确表示Unix的名称,但我正在考虑(阅读:希望)它也适用于OS X)
日志
[01/14/11 10:38:07] [SSH] Opening SSH connection to 10.0.1.188:22.
[01/14/11 10:38:07] [SSH] Authenticating as hudson/******.
java.io.IOException: Password authentication failed.
at com.trilead.ssh2.auth.AuthenticationManager.authenticatePassword(AuthenticationManager.java:319)
at com.trilead.ssh2.Connection.authenticateWithPassword(Connection.java:314)
at hudson.plugins.sshslaves.SSHLauncher.openConnection(SSHLauncher.java:565)
at hudson.plugins.sshslaves.SSHLauncher.launch(SSHLauncher.java:179)
at hudson.slaves.SlaveComputer$1.call(SlaveComputer.java:184)
at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:334)
at java.util.concurrent.FutureTask.run(FutureTask.java:166)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603)
at java.lang.Thread.run(Thread.java:636)
Caused by: java.io.IOException: Authentication method password not supported by the server at this stage.
at com.trilead.ssh2.auth.AuthenticationManager.authenticatePassword(AuthenticationManager.java:289)
... 9 more
[01/14/11 10:38:07] [SSH] Connection closed.
如果有人设法征服过这种类型的设置,或者有任何提示或想法,我将非常感激!
谢谢
没有找到相关结果
已邀请:
3 个回复
古擅坛犯
在Hudson仪表板中,使节点脱机,确保配置具有有效的用户名和密码,然后启动代理。还要确保远程FS根目录由您正在连接的构建用户拥有。 对于无密码的ssh身份验证,首先要检查Hudson主服务器正在运行的用户。让我们假设这是tomcat55。生成公钥/私钥SSH密钥对(使用空密码),然后验证Hudson用户是否可以连接。
在Hudson mac节点上,/ etc / sshd_config需要允许无密码访问。
在节点配置中清除密码字段,并设置私钥字段(在此示例中为/home/tomcat55/.ssh/id_rsa)。您现在应该能够启动代理:
翁茄口霉氖
谷靛