首页 > 其他分享 >搭建ssh服务实战

搭建ssh服务实战

时间:2024-09-15 17:56:25浏览次数:15  
标签:实战 sshd 登录 61 master ssh root 搭建

目录

1. 关闭防火墙和selinux

2. 配置网络yum源

3. 软件安装

安装openssh和openssh-server

4. ssh基本安全配置

设置ssh免密登录

实战

ssh安全防御

隐患因素

优化方案


1. 关闭防火墙和selinux

2. 配置网络yum源

3. 软件安装

安装openssh和openssh-server
安装openssh服务端和客户端,默认装机时都已安装
安装openssh服务,提供远程sshd服务,因为都可以使用ssh登录到服务器
yum可以进行安装,也可以进行升级操作
[root@master-61 ~]# rpm -qa openssh*
openssh-clients-7.4p1-21.el7.x86_64
openssh-7.4p1-21.el7.x86_64
openssh-server-7.4p1-21.el7.x86_64
[root@master-61 ~]# yum -y install openssh-server openssh
[root@master-61 ~]# rpm -qa openssh*
openssh-7.4p1-23.el7_9.x86_64
openssh-server-7.4p1-23.el7_9.x86_64
openssh-clients-7.4p1-23.el7_9.x86_64

4. ssh基本安全配置

为了提升ssh安全性,会通过修改配置文件中的参数(例如:端口号、禁止root登录等)

1.禁用root用户登录、降低权限(只能通过普通用户登录,提前创建好可登录的普通普通户)

修改
#PermitRootLogin yes
PermitRootLogin no
[root@master-61 ~]# sed -rin 's/^#PermitRootLogin yes/PermitRootLogin no/' /etc/ssh/sshd_config
[root@master-61 ~]# grep -Ei '^Per' /etc/ssh/sshd_config
PermitRootLogin no
#下载随机密码生成工具pwgen,生成安全(-s)加数字(-n)形式的密码
[root@master-61 ~]# yum -y install pwgen
[root@master-61 ~]# pwgen -sn | head -1
mCkYUp6t
[root@master-61 ~]# pwgen -sn | head -1 > xiaopi.passwd
[root@master-61 ~]# cat xiaopi.passwd
74cDizTS
[root@master-61 ~]# useradd xiaopi
[root@master-61 ~]# cat xiaopi.passwd | passwd --stdin xiaopi
Changing password for user xiaopi.
passwd: all authentication tokens updated successfully.
#此刻重启sshd服务重新连接就会出现root无法登陆,使用普通用户正常登录,
但是可以普通用户连接后通过su命令切换用户

2.修改端口,22999
[root@master-61 ~]# grep -Ei '^(per|port)' /etc/ssh/sshd_config
PermitRootLogin no
[root@master-61 ~]# sed -rin 's/^#Port 22/Port 22999/' /etc/ssh/sshd_config
[root@master-61 ~]# grep -Ei '^(per|port)' /etc/ssh/sshd_config
Port 22999
PermitRootLogin no

[root@master-61 ~]# systemctl restart sshd
[root@master-61 ~]# netstat -tnlp | grep sshd
tcp        0      0 0.0.0.0:22999           0.0.0.0:*               LISTEN      1461/sshd
tcp6       0      0 :::22999                :::*                    LISTEN      1461/sshd


3.测试登录
使用其他服务器尝试登录,无法正常登录,修改端口后添加公钥和root密码,但是权限仍是拒绝
由于添加了禁止root远程登录的原因,使用普通用户加修改后的端口即可登录

测试完成后恢复默认设置
[root@master-61 ~]# sed -rin 's/^Port 22999/#Port 22/' /etc/ssh/sshd_config
[root@master-61 ~]# sed -rin 's/^PermitRootLogin no/#PermitRootLogin yes/' /etc/ssh/sshd_config
[root@master-61 ~]# grep -Ei '^#(per|port)' /etc/ssh/sshd_config
#Port 22
#PermitRootLogin yes
[root@master-61 ~]# systemctl restart sshd

看到该参数
I参数是忽略大小写,然后再进行p打印
sed -e '/^permitRootLogin/Ip'   -e '/^port/Ip'  /etc/ssh/sshd_config -n
Port 22
PermitRootLogin yes

替换参数
将原文件备份,并将匹配到的整行内容替换,写入文件内容
方法1:
sed -i.ori   -e '/^permitRootLogin/Ic PermitRootLogin yes'   -e '/^port/Ic Port 22'  /etc/ssh/sshd_config

方法2:
sed -i.bak  -e 's#PermitRootLogin no#PermitRootLogin yes#' -e 's#Port 22999#Port 22#' /etc/ssh/sshd_config 

设置ssh免密登录

  1. 在客户机上利用ssh-keygen生成公私钥
  2. 将公钥发送到目标机器上,首次连接时需要进行输入指纹验证以及目标机器的用户密码;ssh-copy-id root@10.0.0.61
  3. 密码验证完成后,目标机器会将客户机的公钥写入到被信任的主机~/.ssh/authorized_keys文件中
  4. 以后如果再通过客户机去登录目标机器的话,只需要使用ssh root@10.0.0.61,用于认证的信息是客户机器上的私钥
  5. 原理是通过ssh root@10.0.0.61登录目标机器时,目标机器接收到客户端发过来的请求,回去扫描被信任的主机文件,查询到有客户端61这台主机公钥,则会随机生成一个字符串通过客户端61的公钥进行加密发送到客户端
  6. 由于是使用客户端61主机公钥进行加密,所以也只能通过该机器的私钥进行解密,其他机器解不开
  7. 待客户端61解开后将结果发送回目标主机后,目标主机进行比对,如果对得上就可以直接登录,这就实现了免密的原理

注:与直接通过命令连接不同点在于如果直接连接的话是目标主机发送公钥到客户端,客户端输入密码进行公钥加密返回目标主机达到登录的效果;而免密是目标主机直接利用公钥加密返回随机口令,让客户端进行解密返回结果

实战

1.客户端61生成公私钥
敲回车即可
[root@master-61 ~]# ssh-keygen
Generating public/private rsa key pair.
Enter file in which to save the key (/root/.ssh/id_rsa):
Created directory '/root/.ssh'.
Enter passphrase (empty for no passphrase):
Enter same passphrase again:
Your identification has been saved in /root/.ssh/id_rsa.
Your public key has been saved in /root/.ssh/id_rsa.pub.
The key fingerprint is:
SHA256:7pWaFJgDSIDmZw2mD/742hA1UA/ac248GTOc+pAdnr0 root@master-61
The key's randomart image is:
+---[RSA 2048]----+
|oooo             |
|.o+++ .          |
|o.+=+X           |
| +.o@oOo         |
|..=+ X+.S        |
| ...+ .o.. .     |
| .o  . Eo o      |
| .o.   o +       |
| .oo    +        |
+----[SHA256]-----+

2.将公钥发送到目标主机
[root@master-61 ~]# ssh-copy-id root@10.0.0.7
-bash: ssh-copy-id: command not found
#由于未安装openssh-clients导致,进行安装即可使用
[root@master-61 ~]# yum -y install openssh-clients
[root@master-61 ~]# ssh-copy-id root@10.0.0.7
/usr/bin/ssh-copy-id: INFO: Source of key(s) to be installed: "/root/.ssh/id_rsa.pub"
The authenticity of host '10.0.0.7 (10.0.0.7)' can't be established.
ECDSA key fingerprint is SHA256:n2plckensSskXuHp9+lbb/0AI0m94Entkenm36U6v38.
ECDSA key fingerprint is MD5:99:2a:9f:33:5b:c5:32:5a:46:d3:28:69:89:6f:3f:bd.
Are you sure you want to continue connecting (yes/no)? yes
/usr/bin/ssh-copy-id: INFO: attempting to log in with the new key(s), to filter out any that are already installed
/usr/bin/ssh-copy-id: INFO: 1 key(s) remain to be installed -- if you are prompted now it is to install the new keys
root@10.0.0.7's password:				#输入对应的密码

Number of key(s) added: 1

Now try logging into the machine, with:   "ssh 'root@10.0.0.7'"
and check to make sure that only the key(s) you wanted were added.
#完成发送,可以在10.0.0.7目标主机上进行查看公钥文件

3.比对客户端61机器上的公钥和目标主机上的被信任的主机key文件是否一致
客户端61
[root@master-61 ~]# ll ~/.ssh/
total 12
-rw------- 1 root root 1679 Sep 13 22:42 id_rsa
-rw-r--r-- 1 root root  396 Sep 13 22:42 id_rsa.pub
-rw-r--r-- 1 root root  170 Sep 13 22:50 known_hosts
[root@master-61 ~]# cat ~/.ssh/id_rsa.pub
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDA67k2iUrYRUe8H8xSdWIRNJDSVP2n8W0pYjvdTURrpccQMDrEP+OwpucYlQMR+wR3aYyU3z7e2nZC1B8nSpedF+A080kvsgWeMTy0HCcnDujJEn1eUPXM7py+S+sE58iOTr6zvzfrvEKfJA+mX2gtht1kt2W9+ahLB/SdaCfu4nA0gpnvaLTR69d6+4iBX6wn1aqu+dAyy+YxFCMzVwAHpcdzxdAtvJEjuP3z5eLldh96Hz85bwe1xto4MSP3y2BNav59q+eFL/656IS7HGu0CYSxsm7utQPC5TdcnKBi4xrDCEtfR5Vc6eJFEtNC/N9xFKgSQ1zV6A+KVLddh1It root@master-61

目标主机
[root@web-7 ~]# ll ~/.ssh/authorized_keys
-rw------- 1 root root 396 Sep 13 22:50 /root/.ssh/authorized_keys
[root@web-7 ~]# cat ~/.ssh/authorized_keys
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDA67k2iUrYRUe8H8xSdWIRNJDSVP2n8W0pYjvdTURrpccQMDrEP+OwpucYlQMR+wR3aYyU3z7e2nZC1B8nSpedF+A080kvsgWeMTy0HCcnDujJEn1eUPXM7py+S+sE58iOTr6zvzfrvEKfJA+mX2gtht1kt2W9+ahLB/SdaCfu4nA0gpnvaLTR69d6+4iBX6wn1aqu+dAyy+YxFCMzVwAHpcdzxdAtvJEjuP3z5eLldh96Hz85bwe1xto4MSP3y2BNav59q+eFL/656IS7HGu0CYSxsm7utQPC5TdcnKBi4xrDCEtfR5Vc6eJFEtNC/N9xFKgSQ1zV6A+KVLddh1It root@master-61
#文件内容是一致的

[root@master-61 ~]# ssh root@10.0.0.7
Last login: Fri Sep 13 22:41:56 2024 from 10.0.0.1
[root@web-7 ~]#


如果无法发送的话也可以自行创建对应的.ssh/authorized_keys文件
将客户端主机公钥粘贴进去也可以实现免密登录

ssh安全防御

隐患因素

1.ssh支持密码连接、秘钥连接两个方式,为了密码别泄露,你得关闭密码登录

2.默认端口号全世界都知道是22,你得改掉端口号

3.如果客户端私钥被窃取,root服务器也就危险了

优化方案
1.目标主机需要关闭密码登录,提前配置好公钥登录
禁止密码登录,只允许公钥登录
[root@web-7 ~]#grep -Ei '^(pub|password)'  /etc/ssh/sshd_config 
PubkeyAuthentication yes
PasswordAuthentication no

2.修改端口号为22999
[root@web-7 ~]#grep -Ei '^(pub|password|port)'  /etc/ssh/sshd_config 
Port 22999
PubkeyAuthentication yes
PasswordAuthentication no

[root@web-7 ~]#systemctl restart sshd
[root@master-61 ~]# ssh root@10.0.0.7
Last login: Fri Sep 13 22:59:56 2024 from 10.0.0.1
[root@web-7 ~]#

3.添加防火墙iptables规则,使得目标主机只能通过跳板机登录
针对web-7限定只允许 master-61访问
限制主机登录条件、设定iptables规则,只允许跳板机的流量(172.16.1.61)登录
其他机器的流量全部禁止。(只限定ssh的服务,限制22999的流量,由于还提供有网页服务和nfs等服务运行)
[root@web-7 ~]#iptables -A INPUT ! -s 172.16.1.61 -p tcp --dport 22999 -j DROP

iptables -A添加,input是服务器流入的流量
-s	source源ip地址,这个流量从哪来
!	排除这个地址以外的所有ip
!	-s	172.16.1.61排除172.16.1.61机器以外的流量
p	tcp指定tcp协议
dport	目标端口这个流量想访问当前机器的么端口22999
-j	指定防火墙的动作drop拒绝,丢弃

[root@web-7 ~]#iptables -L
Chain INPUT (policy ACCEPT)
target     prot opt source               destination         
DROP       tcp  -- !172.16.1.61          anywhere             tcp dpt:22999

Chain FORWARD (policy ACCEPT)
target     prot opt source               destination         

Chain OUTPUT (policy ACCEPT)
target     prot opt source               destination       

标签:实战,sshd,登录,61,master,ssh,root,搭建
From: https://blog.csdn.net/m0_73192692/article/details/142236113

相关文章

  • 如何利用帝国CMS搭建多个网站?
    使用帝国CMS搭建多个网站可以通过多站点功能来实现。帝国CMS支持在一个主系统中管理多个独立的网站,这种方式不仅节省了服务器资源,还便于集中管理。以下是使用帝国CMS搭建多个网站的步骤:1.安装帝国CMS主系统下载安装包:从帝国CMS官方网站下载最新版本的安装包。上传文件:将安装......
  • VPS Ubuntu22.04 安装WordPress 搭建网站 详细全流程(基于Apache+MySQL+PHP)(二)
    VPSUbuntu22.04安装WordPress搭建网站详细全流程(基于Apache+MySQL+PHP)(二)简介在网站处理和网络管理方面,WordPress是用户可以采取的最明智的选择。由于WordPress的巨大优势,它在网页设计师中广受欢迎。统计数据显示,访问量最大的1000个网站中约有35%是WordPress。......
  • AI商业广告与智能办公实战【技术驱动下的变革】(好书推荐)
    文章目录AI商业广告与智能办公实战【技术驱动下的变革】(好书推荐)AI在商业广告中的应用AI在智能办公中的应用AI商业广告设计实战108招:ChatGPT+Photoshop+Firefly+Midjour【书籍推荐】AI智能办公实战108招:ChatGPT+Word+PowerPoint+WPS【书籍推荐】AI数据处理实战108招:Ch......
  • GitLab CI_CD 从入门到实战笔记
    第1章认识GitLabCI/CD1.3GitLabCI/CD的几个基本概念GitLabCI/CD由以下两部分构成。(1)运行流水线的环境。它是由GitLabRunner提供的,这是一个由GitLab开发的开源软件包,要搭建GitLabCI/CD就必须安装它,因为它是流水线的运行环境。(2)定义流水线内容的.gitlab-ci.yml文......
  • MVC项目实战-基于JSP的MVC设计模式实现投票系统
    前言本博客将介绍基于JSP的MVC设计模式实现投票系统,实现两个功能:功能一:投票功能二:查看投票结果 第一步:设计数据库,创建JavaWeb项目,配置pom.xml文件,创建实体类数据库: 数据库中的t_vote包含三个字段:id,v_name,v_numid:主键,一行数据的唯一标识v_name:参与投票的对象名......
  • 9、【实战中提升自己】华为 华三中小型企业网络架构搭建 【无线架构之低速率限制与负
     1 拓扑与说明         某公司的网络架构,这样的架构在目前的网络中是在常见的,假设您接收一个这样的网络,应该如何部署,该实战系列,就是一步一步讲解,如何规划、设计、部署这样一个环境,这里会针对不同的情况给出不同的讲解,比如拓扑中有2个ISP,假设客户需求是,想实现主备的......
  • 关于鸿蒙开发框架,页面搭建样式语法总结
    鸿蒙中的变量/常量创建采用了ts语法我们在声明变量的同时需要指定变量类型,定义变量时也是要遵守变量命名规范:    1.只能包含数字、字母、下划线、$,不能以数字开头…重点    2.不能使用内置关键字或保留字,比如let、const    3.严格区分大小写1.变......
  • 实战13-搜索模块滑动效果01
    import{getHomeDataApi}from'../api/home';import{BannerListDataSource,INavList,IPlanList,ITitleList}from'../api/models/HomeData';importSwiperLayoutfrom'../views/Home/SwiperLayout';import{window}from'......
  • Docker-Compose搭建RustDesk服务器
    前置条件:电脑安装RustDesk客户端,服务器安装Docker及docker-compose官方文档:安装::RustDesk文档操作流程:使用Vim编写docker-compose.yml文件,修改需要的端口,最好按照官方对应的端口来操作,<>内替换成服务器对外的端口。记住挂载文件路径,容器运行后会生成密钥保存在挂载......
  • 构建高效稳定的并发处理系统:从理论到实战的全面优化指南
    目录引言引入问题背景:高并发场景下的线程管理挑战。说明本文的目标:探讨如何使用定时任务、线程池、消息队列、Redis等技术优化线程管理。高并发场景中的线程管理问题介绍高并发环境中的常见挑战。具体说明线程资源耗尽可能导致的问题。用通俗易懂的语言描述场景:例如,在......