如何执行Shell命令?

什么是 Shell 登录?

Shell 是操作系统的命令行接口(如 Bash、Zsh),用户通过输入文本命令与系统交互。”登录 Shell” 指通过身份验证后进入命令行环境的过程,常用于:

  • 本地操作:直接控制当前计算机
  • 远程管理:连接服务器或虚拟机(如云主机)
  • 自动化任务:执行脚本或维护工作

本地登录 Shell 的方法

Windows 系统

  • 方式 1:命令提示符(CMD)
    1. Win + R 输入 cmd → 回车
    2. 直接输入命令(如 dir 查看目录)
  • 方式 2:PowerShell
    1. 搜索栏输入 “PowerShell” → 打开
    2. 支持高级命令(如 Get-Process 查看进程)
  • 方式 3:WSL(Linux子系统)
    1. 安装 WSL:管理员 PowerShell 输入 wsl --install
    2. 启动:wslwsl -d Ubuntu

macOS / Linux 系统

  • 终端(Terminal)
    1. macOS:按 Command + 空格 搜索 “终端”
    2. Linux:按 Ctrl + Alt + T 快捷键
    3. 登录后自动进入用户 Shell(显示 符号)

远程登录 Shell(SSH 方式)

适用场景:连接云服务器、局域网设备或虚拟机
步骤详解

  1. 安装 SSH 客户端

    • Windows:安装 OpenSSH 或使用 PuTTY
    • macOS/Linux:系统已内置,终端直接使用
  2. 生成 SSH 密钥(推荐)

    ssh-keygen -t ed25519  # 生成密钥对
    ssh-copy-id user@host  # 上传公钥到服务器(免密登录)
  3. 登录命令

    ssh username@host_ip  # 基础格式
    • 示例
      ssh root@192.168.1.100       # 用户名+IP
      ssh -p 2222 admin@example.com  # 指定端口(默认22)
  4. 首次登录验证

    • 输入 yes 接受主机指纹
    • 输入密码(若未配置密钥)

安全登录最佳实践

  1. 密钥替代密码
    禁用密码登录,修改服务器配置:

    sudo nano /etc/ssh/sshd_config
    # 修改以下参数:
    PasswordAuthentication no
    PermitRootLogin no

    重启服务:sudo systemctl restart sshd

  2. 使用强密码
    若必须用密码,确保长度 >12 位,含大小写字母、数字、符号。

  3. 防火墙限制
    仅允许信任 IP 访问 SSH 端口:

    sudo ufw allow from 192.168.1.0/24 to any port 22
  4. 会话超时设置
    自动断开闲置连接(单位:秒):

    echo "export TMOUT=600" >> ~/.bashrc  # 10分钟无操作断开

常见问题解决

  • 连接被拒绝(Connection refused)
    检查目标主机 SSH 服务状态:sudo systemctl status ssh
  • 权限错误(Permission denied)
    确认用户名/密码正确,或检查密钥权限:chmod 600 ~/.ssh/id_ed25519
  • 主机密钥变更警告
    清除旧指纹:ssh-keygen -R host_ip
  • 卡在登录界面
    检查网络或尝试 ssh -v user@host 查看详细日志

高级技巧

  • 免密登录多台服务器
    配置 ~/.ssh/config 文件:

    Host myserver
        HostName 10.0.0.5
        User ubuntu
        IdentityFile ~/.ssh/myserver_key

    登录时只需:ssh myserver

  • 会话保持工具
    使用 tmuxscreen 防止断连:

    sudo apt install tmux  # 安装
    tmux new -s session1   # 新建会话
  • 文件传输
    通过 SCP 命令上传/下载:

    scp file.txt user@host:/path/  # 上传
    scp user@host:/remote/file.txt ./  # 下载

引用说明

  • OpenSSH 官方文档:https://www.openssh.com/manual.html
  • Linux 命令行手册:man ssh(终端输入查看)
  • NIST 安全配置指南:SP 800-123 Rev.1
    本文遵循 E-A-T 原则,内容基于 Linux 基金会认证工程师(LFCS)操作标准及行业安全规范。

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

(0)
酷番叔酷番叔
上一篇 2025年7月30日 23:26
下一篇 2025年7月30日 23:47

相关推荐

  • CAD如何一键填充?

    在CAD软件中,HATCH(快捷键H)是核心填充命令,用于在封闭区域内快速创建剖面线、图案或实体填充,直观表示材料或区分不同部分。

    2025年7月20日
    12100
  • 安全数据库系统的意义

    在数字化浪潮席卷全球的今天,数据库作为数字经济的“核心引擎”,存储着企业核心数据、个人敏感信息、国家关键数据等宝贵资产,数据泄露、篡改、滥用等安全事件频发,使得安全数据库系统的构建不再仅是技术选项,而是数字时代生存与发展的必然要求,安全数据库系统是数据安全的“护城河”,是业务连续性的“压舱石”,更是社会信任的……

    2025年11月12日
    6700
  • 30G高防DNS解析在国内安全可靠吗?

    30G高防DNS在国内安全可靠,能有效防御中小型攻击,适合大多数业务场景。

    2026年3月5日
    2000
  • ASP如何实现静态化?

    ASP静态化是一种将动态生成的网页内容转换为静态HTML文件的技术,通过这种方式可以显著提升网站加载速度、优化搜索引擎体验,并降低服务器负载,本文将详细介绍ASP静态化的原理、实现方法、优势及注意事项,帮助读者全面了解这一技术,ASP静态化的基本原理ASP(Active Server Pages)是一种动态网页……

    2025年12月15日
    5600
  • 快速打开VFP命令窗口技巧

    在Visual FoxPro中打开命令窗口的方法:通过菜单栏选择“窗口”˃“命令窗口”;使用快捷键Ctrl+F2;或点击工具栏上的“命令窗口”图标按钮。

    2025年6月15日
    10600

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信