当前位置: 首页 > article >正文

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

文章目录

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

引言

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


正文

一、什么是 SSH?

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


二、安装 SSH 服务器

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

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

三、验证 SSH 服务是否运行

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

  1. 检查 SSH 服务状态
sudo systemctl status ssh 

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

  1. 查看 SSH 端口监听情况
sudo netstat -tuln | grep ssh 

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


四、配置 SSH 服务器

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

  1. 修改 SSH 配置文件
    SSH 的主配置文件位于 /etc/ssh/sshd_config。我们可以使用文本编辑器(如 vimnano)打开该文件:
sudo nano /etc/ssh/sshd_config 
  1. 常见配置选项
  • 修改默认端口
    如果希望更改默认的 SSH 端口(22),可以找到以下行并修改:
    #Port 22 
    Port 2222 
    
  • 禁用 root 登录
    为了提高安全性,建议禁用 root 用户通过 SSH 登录:
    PermitRootLogin no 
    
  • 启用公钥认证
    公钥认证比密码认证更安全。确保以下行未被注释:
    PubkeyAuthentication yes 
    
  • 限制允许登录的用户
    如果只想允许特定用户登录,可以添加以下行:
    AllowUsers username 
    
  1. 保存并应用配置
    修改完配置文件后,保存并退出编辑器。然后重启 SSH 服务以使更改生效:
sudo systemctl restart ssh 

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

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

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

其中:

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

六、安全优化

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

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

将公钥复制到服务器:

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

七、常见问题及解决方法

  1. 连接被拒绝
  • 检查 SSH 服务是否正在运行:
    sudo systemctl status ssh 
    
  • 确保防火墙允许 SSH 端口通过。
  1. 密码错误
  • 确保输入的用户名和密码正确。
  • 检查 /var/log/auth.log 文件以获取更多信息。
  1. 端口冲突
  • 确保没有其他程序占用 SSH 端口。

总结

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


http://www.kler.cn/a/543488.html

相关文章:

  • AI前端开发:赋能开发者,提升解决实际问题的能力
  • 8K样本在DeepSeek-R1-7B模型上的复现效果
  • 题解 洛谷 Luogu P1828 [USACO3.2] 香甜的黄油 Sweet Butter 最短路 堆优化Dijkstra Floyd C++
  • vue-点击生成动态值,动态渲染回显输入框
  • 【Obsidian】当笔记接入AI,Copilot插件推荐
  • 算法04-希尔排序
  • TypeScript 中的 reduce计算统计之和
  • 【VASP】VASP结合Phonopy计算自由能、热容和熵
  • A002基于SpringBoot实现的幼儿园管理系统
  • SMART原则
  • 机器学习: 逻辑回归
  • HiveQL命令(三)- Hive函数
  • go语言简单快速的按顺序遍历kv结构(map)
  • Kotlin Lambda
  • Mybatis快速入门与核心知识总结
  • 【如何掌握CSP-J 信奥赛中的分治算法】
  • 鸿蒙开发-显示提示框用法
  • 如何实现华为云+deepseek?
  • pytorch 模型的参数查看函数介绍
  • 管式超滤膜分离技术都可以应用到哪些行业?
  • 新一代SCADA: 宏集Panorama Suite 2025 正式发布,提供更灵活、符合人体工学且安全的应用体验
  • Springboot Bean创建流程、三种Bean注入方式(构造器注入、字段注入、setter注入)、循坏依赖问题
  • flutter isolate到底是啥
  • Python练习(5)
  • mydb:TM实现
  • 微信小程序 - 组件和样式