
一、实现原理使用一种被称为"公私钥"认证的方式来进行ssh登录。"公私钥"认证方式简单的解释是:首先在客户端上创建一对公私钥(公钥文件:~/.ssh/id_rsa.pub私钥文件:~/.ssh/id_rsa),然后把公钥放到服务器上(~/.ssh/authorized_keys),自己保留好私钥。当ssh登录时,ssh程序会发送私钥去和服务器上的公钥做匹配。如果匹配成功就可以登录了。二、实验环境A机:TS-DEV/10.0.0.163B机:CS-DEV/10.0.0.188三、Linux/Unix双机建立
信任3.1在A机生成
证书在A机root用户下执行ssh-keygen命令,在需要输入的地方,直接回车,生成建立安全信任关系的证书。#ssh-keygen-trsa注意:在程序提示输入passphrase时直接输入回车,表示无证书密码。上述命令将生成私钥证书id_rsa和公钥证书id_rsa.pub,存放在用户家目录的.ssh子目录中。3.2查看~/.ssh生成密钥的文件#cd~/.ssh#ll3.3A对B建立信任关系将公钥证书id_rsa.pub复制到机器B的root家目录的.ssh子目录中,同时将文件名更换为authorized_keys,此时需要输入B机的root用户密码(还未建立信任关系)。建立了客户端到服务器端的信任关系后,客户端就可以不用再输入密码,就可以从服务器端拷贝数据了。#scp-rid_rsa.pub10.0.0.188:/root/.ssh/authorized_keys3.4B对A建立信任关系在B机上执行同样的 *** 作,建立B对A的信任关系。#ssh-keygen-trsa#cd~/.ssh/#ll#scp-rid_rsa.pub10.0.0.163:/root/.ssh/authorized_keys如果想让B,C同时可以scp不输入密码,传输A中的数据则要把B、C的公钥都给A *** 作步骤:把两机器的id_rsa.pub中的数据都拷贝到A的/root/.ssh/authorized_keys文件中,一行表示一条A:scp-rid_rsa.pub10.0.0.163:/root/.ssh/authorized_keysB:scp-rid_rsa.pub10.0.0.188:/root/.ssh/authorized_keys测试sshroot@10.0.0.188'hostname'///sshroot@10.0.0.163'hostname'如果连接反应慢,请修改以下两参数/etc/ssh/sshd_configGSSAPIAuthenticationnoUseDNSno然后重启servicesshdrestart一般来说linux系统都会有网络防火墙设置,如果防火墙关闭,那么只要linux上某个
端口起了某个服务,那这个端口就能telnet的通,telnet某个端口能通的前提是这个端口起了服务,并且防火墙允许该端口的访问。要确定你的linux机子ip和与其他的连接网络的机子的ip在同一个网段,还有一般linux默认ssh是不充许用root连接的。要到/etc/ssh/里面有个sshd文件字样的文件里设置,还有要确定sshd服务已经开启。
评论列表(0条)