Ubuntu服务器上SSH Server的安装和设置


昨天的文章里,我记录了搭建一个小型Ubuntu 服务器的过程,相信如果各位按照我写的做了,您的Ubuntu Server 已经可以跑起来了。不过,现在这个系统只是个基本的系统,算不上服务器,因为什么都没法做。如果需要让它行使服务器的职能,还需要给它装一些软件。
 
因为我需要的服务器最终会被“抛弃”在实验室的某个角落,无论是后期设置还是维护的需要,都必须安装一个远程管理的工具。在Linux 系统中,不二的选择就是openssh 了。在Ubuntu 中安装openssh 实在是再简单不过的一件事情了,下面的内容也只是纯记录,给我这个菜鸟备个份。如果是高手直接绕过就好。
 
安装前的准备
Ubuntu 之所以好用,就是因为它继承了debian 的apt 系统,这一点相信您在昨天装系统的教程中已经感受到了。但是apt 需要依赖网络,昨天我们装好的系统是暂时上不了网的,我们需要先设置一下。
 
首先,激活服务器的网卡,命令如下:
 
sudo nano /etc/network/interfaces
 
在interfaces 中添加以下内容:
 
auto eth0
iface eth0 inet static
address 202.113.235.181
netmask 255.255.255.0
gateway 202.113.235.1这其中,斜体部分标注的IP 地址是我服务器的设置,您需要根据您的具体情况修改。当然,如果您的服务器使用的是DHCP 来分配IP 地址,只需要写上iface eth0 inet dhcp 就可以了,无需设置address/netmask/gateway。
 
然后,修改resolv.conf 配置DNS 服务器:
 
sudo nano /etc/resolv.conf
 
添加您的DNS 服务器地址:
 
nameserver 202.113.16.10
nameserver 202.113.16.11完成后,重新启动networking 服务:
 
sudo /etc/init.d/networking restart
 
这样应该就可以连通网络了。如果您使用的是ADSL,可能还需要装上pppoe 之类的东西,考虑到服务器很少用这样的配置,这里就不讨论了,需要的话可以在网上查找。
 
安装和设置OpenSSH Server
Ubuntu 下安装OpenSSH Server 是无比轻松的一件事情,需要的命令只有一条:
 
sudo apt-get install openssh-server
 
随后,Ubuntu 会自动下载并安装openssh server,并一并解决所有的依赖关系。当您完成这一操作后,您可以找另一台计算机,然后使用一个SSH 客户端软件(强烈推荐PuTTy),输入您服务器的IP 地址。如果一切正常的话,等一会儿就可以连接上了。并且使用现有的用户名和密码应该就可以登录了。
 
事实上如果没什么特别需求,到这里OpenSSH Server 就算安装好了。但是进一步设置一下,可以让OpenSSH 登录时间更短,并且更加安全。这一切都是通过修改openssh 的配置文件sshd_config 实现的。
 
首先,您刚才实验远程登录的时候可能会发现,在输入完用户名后需要等很长一段时间才会提示输入密码。其实这是由于sshd 需要反查客户端的dns 信息导致的。我们可以通过禁用这个特性来大幅提高登录的速度。首先,打开sshd_config 文件:
 
sudo nano /etc/ssh/sshd_config
 
找到GSSAPI options 这一节,将下面两行注释掉:
 
#GSSAPIAuthentication yes
#GSSAPIDelegateCredentials no然后重新启动ssh 服务即可:
 
sudo /etc/init.d/ssh restart
 
再登录试试,应该非常快了吧 
 
利用PuTTy 通过证书认证登录服务器
SSH 服务中,所有的内容都是加密传输的,安全性基本有保证。但是如果能使用证书认证的话,安全性将会更上一层楼,而且经过一定的设置,还能实现证书认证自动登录的效果。
 
首先修改sshd_config 文件,开启证书认证选项:
 
RSAAuthentication yes
PubkeyAuthentication yes
AuthorizedKeysFile %h/.ssh/authorized_keys修改完成后重新启动ssh 服务。
 
下一步我们需要为SSH 用户建立私钥和公钥。首先要登录到需要建立密钥的账户下,这里注意退出root 用户,需要的话用su 命令切换到其它用户下。然后运行:
 
ssh-keygen
 
这里,我们将生成的key 存放在默认目录下即可。建立的过程中会提示输入passphrase,这相当于给证书加个密码,也是提高安全性的措施,这样即使证书不小心被人拷走也不怕了。当然如果这个留空的话,后面即可实现PuTTy 通过证书认证的自动登录。
 
ssh-keygen 命令会生成两个密钥,首先我们需要将公钥改名留在服务器上:
 
cd ~/.ssh
mv id_rsa.pub authorized_keys然后将私钥id_rsa 从服务器上复制出来,并删除掉服务器上的id_rsa 文件。
 
服务器上的设置就做完了,下面的步骤需要在客户端电脑上来做。首先,我们需要将id_rsa 文件转化为PuTTy 支持的格式。这里我们需要利用PuTTyGEN 这个工具:
 
点击PuTTyGen 界面中的Load 按钮,选择id_rsa 文件,输入passphrase(如果有的话),然后再点击Save PrivateKey 按钮,这样PuTTy 接受的私钥就做好了。
 
打开PuTTy,在Session 中输入服务器的IP 地址,在Connection->SSH->Auth 下点击Browse 按钮,选择刚才生成好的私钥。然后回到Connection 选项,在Auto-login username 中输入证书所属的用户名。回到Session 选项卡,输入个名字点Save 保存下这个Session。点击底部的Open 应该就可以通过证书认证登录到服务器了。如果有passphrase 的话,登录过程中会要求输入passphrase,否则将会直接登录到服务器上,非常的方便。
 
好了,今天就写到这,以后逐步再写AMP,Proftpd 和Squid 的安装和设置。
 
原文链接**:花儿开了- Ubuntu 服务器上SSH Server 的安装和设置
 

相关内容

    暂无相关文章