CentOS SSH配置及安全设置指南

SSH(Secure Shell)是一种加密网络协议,它可以在不安全的网络中为网络服务提供安全的数据传输以及远程登录终端进行管理。在CentOS中,通过配置SSH并进行安全设置,可以提高系统的安全性。

一、安装和启动SSH服务

1、安装ssh-server包:

sudo yum install openssh-server

2、启动SSH服务:

sudo systemctl start sshd.service

3、设置SSH服务开机自启:

sudo systemctl enable sshd.service

二、配置SSH服务

1、修改SSH端口号

为了防止常用的22端口被攻击者利用,建议修改SSH的默认端口号。修改方法如下:

1)编辑SSH配置文件:

sudo vi /etc/ssh/sshd_config

2)找到“#Port 22”这一行,去掉行首井号并修改为其它不冲突的端口号(如:2233):

Port 2233

3)保存修改后的配置文件并重启ssh服务:

sudo systemctl restart sshd.service

2、禁止root用户登录

为了加强SSH服务的安全性,建议禁止使用root用户直接登录SSH。修改方法如下:

1)编辑SSH配置文件:

sudo vi /etc/ssh/sshd_config

2)找到“#PermitRootLogin yes”这一行,去掉行首井号并修改为“PermitRootLogin no”:

PermitRootLogin no

3)保存修改后的配置文件并重启ssh服务:

sudo systemctl restart sshd.service

三、SSH登录安全设置

为了增强SSH登录的安全性,可以采用一些方法来防止未经授权的用户登录系统。

1、使用公钥认证登录SSH

使用公钥认证可以有效地防止SSH登录被黑客攻击,这里以在本地生成RSA公钥和私钥为例进行介绍:

1)在本地生成RSA公钥和私钥:

ssh-keygen -t rsa -b 4096 -C "your_email@example.com"

2)在服务器上创建新用户并添加公钥:

sudo adduser newuser
sudo mkdir /home/newuser/.ssh
sudo chmod 700 /home/newuser/.ssh
sudo touch /home/newuser/.ssh/authorized_keys
sudo chmod 600 /home/newuser/.ssh/authorized_keys

将本地的公钥文件~/.ssh/id_rsa.pub复制到服务器的/home/newuser/.ssh/authorized_keys文件中:

scp ~/.ssh/id_rsa.pub newuser@your_server_ip:/home/newuser/.ssh/authorized_keys

3)修改SSH配置文件,启用公钥认证:

找到“#PubkeyAuthentication yes”这一行,去掉行首井号并修改为“PubkeyAuthentication yes”:

PubkeyAuthentication yes

4)保存修改后的配置文件并重启ssh服务:

sudo systemctl restart sshd.service

2、使用密码登录SSH

如果不能使用公钥认证或者希望同时使用密码认证和公钥认证,则需要设置密码登录SSH时强制要求使用复杂密码。

在SSH配置文件中,找到“#PasswordAuthentication yes”这一行,去掉行首井号并修改为“PasswordAuthentication yes”:

PasswordAuthentication yes

然后在同一文件中找到“#PermitEmptyPasswords no”这一行,去掉行首井号并修改为“PermitEmptyPasswords no”:

PermitEmptyPasswords no

最后重启ssh服务:

sudo systemctl restart sshd.service

四、SSH故障解决

1、SSH连接被拒绝

可能原因是ssh服务没有开启或者被防火墙拦截了请求。可以通过以下命令检查ssh服务是否在运行:

sudo systemctl status sshd

如果出现“active (running)”字样,则说明ssh服务在运行。

解决方法:

1)如果ssh服务没有运行,则需要启动ssh服务:

sudo systemctl start sshd.service

2)如果ssh服务已经启动但是无法连接,则可能被防火墙拦截了请求:

使用以下命令检查防火墙是否开启:

sudo firewall-cmd --state

如果状态为“running”说明防火墙已经开启,可以通过添加策略来放行ssh请求:

sudo firewall-cmd --permanent --add-service=ssh

然后重启防火墙:

sudo firewall-cmd --reload

2、SSH登录速度较慢

这个问题可能是由于DNS反向解析造成的,如果服务器不能正确地解析客户端的DNS信息,则登录速度会变得非常慢。

解决方法如下:

在SSH配置文件中找到“#UseDNS yes”这一行,去掉行首井号并修改为“UseDNS no”:

UseDNS no

保存修改后的配置文件并重启ssh服务:

sudo systemctl restart sshd.service

总结

通过对CentOS SSH服务配置和安全的设置,可以有效地提高系统的安全性。具体方法包括安装和启动SSH服务,修改SSH端口号、禁止root用户登录,使用公钥认证登录SSH、使用密码登录SSH等。同时,还需要注意解决SSH故障,如SSH连接被拒绝、SSH登录速度较慢等问题。

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/258430.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-12-15 12:49
下一篇 2024-12-15 12:49

相关推荐

  • Java JsonPath 效率优化指南

    本篇文章将深入探讨Java JsonPath的效率问题,并提供一些优化方案。 一、JsonPath 简介 JsonPath是一个可用于从JSON数据中获取信息的库。它提供了一种DS…

    编程 2025-04-29
  • 运维Python和GO应用实践指南

    本文将从多个角度详细阐述运维Python和GO的实际应用,包括监控、管理、自动化、部署、持续集成等方面。 一、监控 运维中的监控是保证系统稳定性的重要手段。Python和GO都有强…

    编程 2025-04-29
  • Python wordcloud入门指南

    如何在Python中使用wordcloud库生成文字云? 一、安装和导入wordcloud库 在使用wordcloud前,需要保证库已经安装并导入: !pip install wo…

    编程 2025-04-29
  • Python应用程序的全面指南

    Python是一种功能强大而简单易学的编程语言,适用于多种应用场景。本篇文章将从多个方面介绍Python如何应用于开发应用程序。 一、Web应用程序 目前,基于Python的Web…

    编程 2025-04-29
  • Python小波分解入门指南

    本文将介绍Python小波分解的概念、基本原理和实现方法,帮助初学者掌握相关技能。 一、小波变换概述 小波分解是一种广泛应用于数字信号处理和图像处理的方法,可以将信号分解成多个具有…

    编程 2025-04-29
  • Python字符转列表指南

    Python是一个极为流行的脚本语言,在数据处理、数据分析、人工智能等领域广泛应用。在很多场景下需要将字符串转换为列表,以便于操作和处理,本篇文章将从多个方面对Python字符转列…

    编程 2025-04-29
  • Git secbit:一种新型的安全Git版本

    Git secbit是一种新型的安全Git版本,它在保持Git原有功能的同时,针对Git存在的安全漏洞做出了很大的改进。下面我们将从多个方面对Git secbit做详细地阐述。 一…

    编程 2025-04-29
  • Python初学者指南:第一个Python程序安装步骤

    在本篇指南中,我们将通过以下方式来详细讲解第一个Python程序安装步骤: Python的安装和环境配置 在命令行中编写和运行第一个Python程序 使用IDE编写和运行第一个Py…

    编程 2025-04-29
  • Python起笔落笔全能开发指南

    Python起笔落笔是指在编写Python代码时的编写习惯。一个好的起笔落笔习惯可以提高代码的可读性、可维护性和可扩展性,本文将从多个方面进行详细阐述。 一、变量命名 变量命名是起…

    编程 2025-04-29
  • FusionMaps应用指南

    FusionMaps是一款基于JavaScript和Flash的交互式地图可视化工具。它提供了一种简单易用的方式,将复杂的数据可视化为地图。本文将从基础的配置开始讲解,到如何定制和…

    编程 2025-04-29

发表回复

登录后才能评论