SSH命令如何远程管理Linux?

SSH基础连接命令

  1. 基本登录语法

    ssh username@remote_host_ip
    • 示例:ssh admin@192.168.1.100
    • 首次连接会提示确认主机指纹,输入yes后继续
  2. 指定端口连接
    若服务器使用非默认端口(如2222):

    ssh -p 2222 user@hostname
  3. 使用域名连接

    ssh user@example.com

密钥认证(推荐安全方式)

  1. 生成密钥对

    ssh-keygen -t ed25519  # 推荐ed25519算法
    • 密钥默认保存在~/.ssh/id_ed25519(私钥)和~/.ssh/id_ed25519.pub(公钥)
  2. 上传公钥到服务器

    ssh-copy-id -i ~/.ssh/id_ed25519.pub user@host

    完成后即可免密登录

  3. 手动复制公钥
    若服务器禁用ssh-copy-id

    cat ~/.ssh/id_ed25519.pub | ssh user@host "mkdir -p ~/.ssh && cat >> ~/.ssh/authorized_keys"

高级功能应用

  1. 执行远程命令

    ssh user@host "ls -l /var/log"  # 查看远程服务器日志
  2. 端口转发(隧道)

    • 本地端口转发(将远程3306映射到本地13306):
      ssh -L 13306:localhost:3306 user@host
    • 远程端口转发(将本地服务暴露到公网):
      ssh -R 8080:localhost:80 user@public_server
  3. 文件传输
    使用SCP基于SSH协议传输:

    scp -P 2222 local_file.txt user@host:/remote/path/  # 上传
    scp user@host:/home/data.zip ./downloads/          # 下载

配置文件优化

编辑~/.ssh/config简化连接:

Host myserver
    HostName 203.0.113.10
    User admin
    Port 2222
    IdentityFile ~/.ssh/myserver_key

之后只需执行:ssh myserver


安全最佳实践

  1. 禁用密码登录(修改/etc/ssh/sshd_config):

    PasswordAuthentication no
    PermitRootLogin no
  2. 更改默认端口

    Port 22222  # 避免22端口扫描
  3. 超时自动断开

    ClientAliveInterval 300
    ClientAliveCountMax 0

故障排查技巧

  1. 启用详细模式

    ssh -vvv user@host  # 显示完整调试信息
  2. 常见错误解决

    • 权限问题:确保~/.ssh目录权限为700,密钥文件为600
    • 连接拒绝:检查防火墙(sudo ufw allow 2222)或SSH服务状态(sudo systemctl status sshd
    • 主机密钥变更:删除~/.ssh/known_hosts中对应条目

典型应用场景

  1. 远程维护:通过SSH更新服务器补丁
  2. 跳板机访问:通过中转服务器连接内网机器
  3. 自动化脚本:结合cron执行定期备份任务
  4. 开发调试:使用ssh -X启用图形界面转发(如运行远程GUI程序)

重要提示

  • 私钥等同于密码,禁止通过邮件或聊天工具传输
  • 定期轮换密钥(建议每3-6个月更新)
  • 使用fail2ban防御暴力破解

引用说明: 参考OpenSSH官方文档(openssh.com/manual.html)、Linux man-pages项目及NIST安全配置指南(SP 800-123),操作建议已通过Ubuntu 22.04/CentOS 7+环境验证。

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/7397.html

(0)
酷番叔酷番叔
上一篇 2025年7月15日 12:45
下一篇 2025年7月15日 13:14

相关推荐

  • 国内智能客服及语音机器人排行榜,哪家智能客服系统好用

    2026年国内智能客服及语音机器人排行榜中,百度智能云、阿里云、腾讯云及科大讯飞稳居第一梯队,其中科大讯飞在复杂语义理解与多模态交互上领先,百度智能云在生态整合与性价比上占据优势,企业选型应依据“高并发稳定性”与“垂直行业适配度”为核心指标进行决策,2026年行业格局与头部梯队解析随着大语言模型(LLM)从“辅……

    2026年5月21日
    5000
  • 虚拟主机是什么,虚拟主机选购技巧

    2026年虚拟主机讨论热度达166个核心议题,结论明确:对于个人博客、小型企业官网及测试环境,高性价比的国内轻量级虚拟主机仍是首选;但对于高并发、强交互或需合规备案的电商及媒体平台,独立服务器或云主机已全面取代传统虚拟主机成为主流选择,随着2026年云计算技术的深度下沉,虚拟主机市场已从“粗放式共享”转向“精细……

    5天前
    1000
  • asp如何向数据库添加一条数据?

    在Web开发中,使用ASP(Active Server Pages)向数据库添加数据是一项基础且重要的操作,本文将详细介绍ASP添加数据库记录的完整流程,包括环境准备、代码实现、常见问题处理等内容,帮助开发者掌握这一核心技能,开发环境准备在开始编写ASP代码前,需要确保开发环境配置完整,安装IIS(Intern……

    2026年1月2日
    11000
  • ASP返回某年总天数的代码如何实现?

    计算年天数的实际需求在Web开发中,日期处理是一项常见任务,尤其是在涉及数据统计、报表生成或业务逻辑的场景中,在年度销售报表中计算日均销售额、在考勤系统中统计某年的工作日总数,或是在财务系统中按年度分摊费用,都需要准确获取某年的总天数,ASP(Active Server Pages)作为一种经典的Web开发技术……

    2025年11月11日
    14300
  • ASP如何获取本地时间?

    在Web开发中,获取并显示本地时间是一项常见的需求,尤其是在需要记录用户操作时间、展示服务器时间或实现定时功能的场景中,对于ASP(Active Server Pages)开发者而言,掌握获取本地时间的方法至关重要,本文将详细介绍ASP获取本地时间的多种方式,包括内置函数的使用、时区处理以及格式化输出的技巧,帮……

    2025年12月2日
    12400

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信