前言
本文介绍主控端如何通过SSH方式远程连接Linux被控端(服务器),并介绍如何解决连接失败问题。
此方法同样适用于SSH连接Docker容器。
被控端
被控端一般为Linux,默认已安装openssh-client,但需要手动安装openssh-server。
需要通过显示器和键鼠直接登录Linux被控端进行安装,因为此时无法通过SSH进行远程连接。
设置用户密码
若没有设置用户密码可先设置密码:
sudo passwd [user_name]
安装openssh-server
sudo apt install openssh-server
检验是否安装成功
ssh localhost
连接成功则代表安装成功。
若连接失败可参考下文的 连接失败 章节进行问题排查并解决问题。
查看被控端IP
ifconfig
其中,inet
便是IP地址。
主控端
Linux被控端安装openssh-server后,主控端即可通过SSH连接被控端。
主控端可以是Linux或Windows。
Linux系统
Linux系统默认已安装openssh-client,若未安装则运行以下命令安装:
sudo apt install openssh-client
运行以下命令即可连接被控端SSH:
ssh [-p port] user@ip
其中,port
为端口号,默认为22,可省略;user
为被控端用户名;ip
为被控端IP地址。
Windows系统
在主控端安装SSH连接软件后,例如MobaXterm。
打开SSH连接软件,新建会话,输入被控端IP,用户名,密码,端口号默认为22,连接即可。
连接失败
若连接不成功,可尝试以下步骤解决:
步骤1:确保ssh服务开启
运行shell命令筛选ssh进程:
ps -e | grep ssh
结果应有 ssh-agent 和 sshd,如下图:
若缺少相关进程,则需手动开启:
# 开启ssh-agent
eval ssh-agent
# 开启sshd
sudo service ssh start
# or
/etc/init.d/ssh start
服务开启后,再次尝试连接ssh。
若仍然无法连接ssh,则进行步骤2。
步骤2:修改sshd配置
编辑sshd配置文件,按照下方配置取消注释或添加新行即可。
# 使用vim编辑sshd配置文件
vim /etc/ssh/sshd_config
# 允许root用户登录
PermitRootLogin yes
# 允许密码验证
PasswordAuthentication yes
# 允许公钥验证
PubkeyAuthentication yes
保存文件后,重启sshd服务:
sudo service ssh restart
重启服务后,再次尝试连接ssh。
至此问题应已得到解决。