如何启动 Linux Debian/Ubuntu 等 SSH 服务器

文章目录

  • 引言
  • 正文
    • [一、什么是 SSH?](#一、什么是 SSH?)
    • [二、安装 SSH 服务器](#二、安装 SSH 服务器)
    • [三、验证 SSH 服务是否运行](#三、验证 SSH 服务是否运行)
    • [四、配置 SSH 服务器](#四、配置 SSH 服务器)
    • [五、使用 SSH 客户端连接到服务器](#五、使用 SSH 客户端连接到服务器)
    • 六、安全优化
    • 七、常见问题及解决方法
  • 总结

引言

SSH(Secure Shell)是一种用于远程登录和执行命令的安全协议。它是 Linux 系统管理员和开发者常用的工具之一。本文将详细介绍如何在 Debian 和 Ubuntu 等 Linux 发行版上安装、配置和启动 SSH 服务器。


正文

一、什么是 SSH?

SSH 是一种网络协议,用于在不安全的网络中安全地传输数据。它通过加密通信通道来保护用户的密码和数据不被窃取。SSH 服务器允许用户通过网络远程登录到 Linux 系统,并执行各种命令。


二、安装 SSH 服务器

在 Debian/Ubuntu 系统上,默认情况下可能没有安装 SSH 服务器。我们需要手动安装它。

  1. 更新软件包列表
    在安装任何软件之前,建议先更新软件包列表:
bash 复制代码
sudo apt update 
  1. 安装 OpenSSH 服务器
    OpenSSH 是一个广泛使用的 SSH 实现。我们可以使用以下命令安装 OpenSSH 服务器:
bash 复制代码
sudo apt install openssh-server 
  1. 启动 SSH 服务
    安装完成后,SSH 服务会自动启动。如果需要手动启动,可以使用以下命令:
bash 复制代码
sudo systemctl start ssh 
  1. 设置 SSH 服务开机自启动
    为了确保 SSH 服务在系统重启后自动启动,可以启用开机自启动:
bash 复制代码
sudo systemctl enable ssh 

三、验证 SSH 服务是否运行

安装并启动 SSH 服务后,可以通过以下方法验证其是否正常运行:

  1. 检查 SSH 服务状态
bash 复制代码
sudo systemctl status ssh 

如果显示 active (running),则表示 SSH 服务正在运行。

  1. 查看 SSH 端口监听情况
bash 复制代码
sudo netstat -tuln | grep ssh 

正常情况下,会看到 tcp 端口 22(默认 SSH 端口)正在监听。


四、配置 SSH 服务器

默认情况下,SSH 服务器已经可以使用,但为了安全性和功能性,我们可能需要对其进行一些配置。

  1. 修改 SSH 配置文件
    SSH 的主配置文件位于 /etc/ssh/sshd_config。我们可以使用文本编辑器(如 vimnano)打开该文件:
bash 复制代码
sudo nano /etc/ssh/sshd_config 
  1. 常见配置选项
  • 修改默认端口
    如果希望更改默认的 SSH 端口(22),可以找到以下行并修改:

    bash 复制代码
    #Port 22 
    Port 2222 
  • 禁用 root 登录
    为了提高安全性,建议禁用 root 用户通过 SSH 登录:

    bash 复制代码
    PermitRootLogin no 
  • 启用公钥认证
    公钥认证比密码认证更安全。确保以下行未被注释:

    bash 复制代码
    PubkeyAuthentication yes 
  • 限制允许登录的用户
    如果只想允许特定用户登录,可以添加以下行:

    bash 复制代码
    AllowUsers username 
  1. 保存并应用配置
    修改完配置文件后,保存并退出编辑器。然后重启 SSH 服务以使更改生效:
bash 复制代码
sudo systemctl restart ssh 

五、使用 SSH 客户端连接到服务器

安装并配置好 SSH 服务器后,可以通过 SSH 客户端(如 TerminalPuTTY)连接到服务器。

  1. 使用命令行连接
    在终端中输入以下命令:
bash 复制代码
ssh username@server_ip -p port_number 

其中:

  • username 是服务器上的用户名。
  • server_ip 是服务器的 IP 地址。
  • port_number 是 SSH 端口(默认为 22)。
  1. 示例
    假设服务器的 IP 地址是 192.168.1.100,用户名是 user,端口是 2222,则命令如下:
bash 复制代码
ssh [email protected] -p 2222 

六、安全优化

为了进一步提高 SSH 服务器的安全性,可以采取以下措施:

  1. 使用密钥认证
    生成 SSH 密钥对并将其分发到客户端:
bash 复制代码
ssh-keygen -t rsa 

将公钥复制到服务器:

bash 复制代码
ssh-copy-id username@server_ip 
  1. 禁用密码认证
    /etc/ssh/sshd_config 中添加以下行:
bash 复制代码
PasswordAuthentication no 
  1. 配置防火墙
    使用 ufwiptables 防火墙限制对 SSH 端口的访问。例如:
bash 复制代码
sudo ufw allow 2222/tcp 

七、常见问题及解决方法

  1. 连接被拒绝
  • 检查 SSH 服务是否正在运行:

    bash 复制代码
    sudo systemctl status ssh 
  • 确保防火墙允许 SSH 端口通过。

  1. 密码错误
  • 确保输入的用户名和密码正确。
  • 检查 /var/log/auth.log 文件以获取更多信息。
  1. 端口冲突
  • 确保没有其他程序占用 SSH 端口。

总结

通过本文的介绍,您应该能够轻松地在 Debian/Ubuntu 系统上安装、配置和启动 SSH 服务器。SSH 是一个强大而灵活的工具,掌握它的基本使用和配置将极大提升您的工作效率和系统的安全性。

相关推荐
Kaede63 分钟前
如何应对Linux云服务器磁盘空间不足的情况
linux·运维·服务器
apocelipes6 小时前
Linux c 运行时获取动态库所在路径
linux·c语言·linux编程
努力学习的小廉6 小时前
深入了解linux系统—— 进程池
linux·运维·服务器
秃头菜狗7 小时前
各个主要目录的功能 / Linux 常见指令
linux·运维·服务器
2301_793102497 小时前
Linux——MySql数据库
linux·数据库
jiunian_cn8 小时前
【Linux】centos软件安装
linux·运维·centos
程序员JerrySUN8 小时前
[特殊字符] 深入理解 Linux 内核进程管理:架构、核心函数与调度机制
java·linux·架构
孤寂大仙v8 小时前
【计算机网络】非阻塞IO——select实现多路转接
linux·计算机网络
派阿喵搞电子9 小时前
Ubuntu下有关UDP网络通信的指令
linux·服务器·网络
Evan_ZGYF丶9 小时前
【PCIe总线】 -- PCI、PCIe相关实现
linux·嵌入式·pcie·pci