Ubuntu下SSH安装或设置
Ubuntu下安装OpenSSHServer是无比轻松的一件事情,需要的命令只有一条:
sudoapt-getinstallopenssh-server
(查看返回的结果,如果没有出错,则用putty、SecureCRT、SSHSecureShellClient等SSH客户端软件,输入您服务器的IP地址。如果一切正常的话,等一会儿就可以连接上了。并且使用现有的用户名和密码应该就可以登录了。)
然后确认sshserver是否启动了:(或用“netstat-tlp”命令)
ps-e|grepssh
如果只有ssh-agent那ssh-server还没有启动,需要/etc/init.d/sshstart,如果看到sshd那说明ssh-server已经启动了。
ssh-server配置文件位于/etc/ssh/sshd_config,在这里可以定义SSH的服务端口,默认端口是22,你可以自己定义成其他端口号,如222。然后重启SSH服务:
sudo/etc/init.d/sshresart
事实上如果没什么特别需求,到这里OpenSSHServer就算安装好了。但是进一步设置一下,可以让OpenSSH登录时间更短,并且更加安全。这一切都是通过修改openssh的配置文件sshd_config实现的。
首先,您刚才实验远程登录的时候可能会发现,在输入完用户名后需要等很长一段时间才会提示输入密码。其实这是由于sshd需要反查客户端的dns信息导致的。我们可以通过禁用这个特性来大幅提高登录的速度。首先,打开sshd_config文件:
sudonano/etc/ssh/sshd_config
找到GSSAPIoptions这一节,将下面两行注释掉:
#GSSAPIAuthenticationyes#GSSAPIDelegateCredentialsno然后重新启动ssh服务即可:
sudo/etc/init.d/sshrestart
再登录试试,应该非常快了吧
利用PuTTy通过证书认证登录服务器
SSH服务中,所有的内容都是加密传输的,安全性基本有保证。但是如果能使用证书认证的话,安全性将会更上一层楼,而且经过一定的设置,还能实现证书认证自动登录的效果。
首先修改sshd_config文件,开启证书认证选项:
RSAAuthenticationyesPubkeyAuthenticationyesAuthorizedKeysFile%h/.ssh/authorized_keys修改完成后重新启动ssh服务。
下一步我们需要为SSH用户建立私钥和公钥。首先要登录到需要建立密钥的账户下,这里注意退出root用户,需要的话用su命令切换到其它用户下。然后运行:
ssh-keygen
这里,我们将生成的key存放在默认目录下即可。建立的过程中会提示输入passphrase,这相当于给证书加个密码,也是提高安全性的措施,这样即使证书不小心被人拷走也不怕了。当然如果这个留空的话,后面即可实现PuTTy通过证书认证的自动登录。
ssh-keygen命令会生成两个密钥,首先我们需要将公钥改名留在服务器上:
cd~/.sshmvid_rsa.pubauthorized_keys然后将私钥id_rsa从服务器上复制出来,并删除掉服务器上的id_rsa文件。
服务器上的设置就做完了,下面的步骤需要在客户端电脑上来做。首先,我们需要将id_rsa文件转化为PuTTy支持的格式。这里我们需要利用PuTTyGEN这个工具:
点击PuTTyGen界面中的Load按钮,选择id_rsa文件,输入passphrase(如果有的话),然后再点击SavePrivateKey按钮,这样PuTTy接受的私钥就做好了。
打开PuTTy,在Session中输入服务器的IP地址,在Connection->SSH->Auth下点击Browse按钮,选择刚才生成好的私钥。然后回到Connection选项,在Auto-loginusername中输入证书所属的用户名。回到Session选项卡,输入个名字点Save保存下这个Session。点击底部的Open应该就可以通过证书认证登录到服务器了。如果有passphrase的话,登录过程中会要求输入passphrase,否则将会直接登录到服务器上,非常的方便。[size=large][/size]