RedHat9 | SSH远程登陆系统

ssh的基本用法

ssh hostname/IP    # 如果没有指定用什么用户进行连接,默认使用当前用户登录
ssh –l username hostname/IP
ssh username@hostname
ssh username@IP

在第一次连接到服务器时,会自动记录服务器的公钥指纹信息

如果出现密钥变更导致错误可以直接删除known_hosts文件

在这里插入图片描述

Linux和MacOS系统的known_hosts文件所在位置

~/.ssh/known_hosts

在这里插入图片描述

Windows系统的known_hosts文件所在位置

%username%\.ssh\known_hosts

在这里插入图片描述

打开远程图形化界面

ssh建立的连接默认只允许字符传输,不允许Xclient进行传输

如果使用普通的ssh连接,我们无法使用远程主机的图形化工具,如gedit、Firefox等

ssh -X root@192.168.110.1 # 添加-X选项,使用Xclient建立ssh连接

在这里插入图片描述

ssh无密登录

配置密钥登陆,远程登录时不需要密码即可直接登录

  • 实现Client的root以sshuser用户登录Server
标识ServerClient
IP地址192.168.110.1/24192.168.110.2/24
用户root+sshuserroot
操作生成密钥对,将公钥传输到Server的用户家目录下

在Server新建用户sshuser,用于后续无密登录

useradd sshuser
echo user@123 | passwd --stdin sshuser

在Client生成密钥对

ssh-keygen -f ~/.ssh/id_rsa -N ""
# ssh-keygen 生成SSH密钥文件
# -f ~/.ssh/id_rsa 指定生成私钥的路径及名称,默认保存位置这里(此选项可忽略)
# -N “” :不对生成的私钥加密

在这里插入图片描述

查看密钥对

ll .ssh/

在这里插入图片描述

将Client的公钥传输到Server的sshuser家目录下

ssh-copy-id sshuser@192.168.110.1

在这里插入图片描述

在Server上查看传输的公钥

su – sshuser
ll .ssh/

在这里插入图片描述

验证无密登录

ssh sshuser@192.168.110.1

在这里插入图片描述

SSH安全设置

ssh存在两种认证方式:密钥认证和密码认证

禁用密钥登录

在上面操作中,我们允许Client的root用户通过Server的sshuser无密登录,这里我们在Server上禁用密钥登录

vim /etc/ssh/sshd_config

# 修改下列内容
PubkeyAuthentication no

在这里插入图片描述

重启sshd服务

systemctl restart sshd

验证

ssh sshuser@192.168.110.1

在这里插入图片描述

禁用密码登录

我们先不开启密钥登录,修改配置文件禁止密码登录

vim /etc/ssh/sshd.config

# 修改以下内容
PasswordAuthentication no

在这里插入图片描述

重启sshd服务

systemctl restart sshd

验证

ssh sshuser@192.168.110.1	# 测试密钥登录,被拒绝
ssh root@192.168.110.1		# 测试密码登录,被拒绝

在这里插入图片描述

开启密钥登录

vim /etc/ssh/sshd.config

# 注释选项
#PubkeyAuthentication no

再次测试

ssh sshuser@192.168.110.1	# 测试密钥登录,成功
ssh root@192.168.110.1		# 测试密码登录,被拒绝

在这里插入图片描述

SSH限制用户

禁用root账户登录

首先开启ssh密码登录

vim /etc/ssh/sshd.config

# 注释选项
#PasswordAuthentication no	# 注释

重启sshd服务

systemctl restart sshd

首先我们是可以通过root账户连接Server

ssh root@192.168.110.1

在这里插入图片描述

修改配置文件,禁止root连接

vim /etc/ssh/sshd.config

# 修改以下内容
PermitRootLogin no	
# 默认情况下为:PermitRootLogin prohibit-passwd [私钥认证]
禁止普通用户登录

在Server上新建用户user1

useradd user1
echo user@123 | passwd--stdin user1

测试ssh登录Server

ssh user1@192.168.110.1

在这里插入图片描述

修改配置文件,禁止user1用户登录

vim /etc/ssh/sshd.config

# 添加下列内容
DenyUsers user1
# AllowUsers xx 只允许xx用户登录
# AllowUsers xx yy		只允许xx和yy用户登录
# DenyGroups xx	禁止xx用户组登录
# 如果同时出现Allow和Deny,只生效Deny

验证

ssh user1@192.168.110.1

在这里插入图片描述

  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Meaauf

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值