如何执行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

相关推荐

  • auto域名特价,现在入手划算吗?

    在数字化时代,域名作为企业线上身份的核心标识,其重要性不言而喻,.auto域名因其与汽车行业的强关联性,成为汽车制造商、经销商、服务平台以及相关从业者的首选,优质域名的注册成本往往较高,而“auto域名特价”活动则为行业参与者提供了以更低成本获取优质资源的机会,本文将围绕.auto域名的价值、特价活动的意义、如……

    2025年12月6日
    1900
  • 安全事件信息如何导致数据泄露?

    在数字化时代,安全事件与数据泄露已成为企业、组织乃至个人无法回避的严峻挑战,随着信息技术的飞速发展和数据价值的不断提升,网络攻击手段日益复杂隐蔽,安全事件频发,数据泄露规模与影响范围持续扩大,不仅对企业的经济利益和声誉造成重创,更可能威胁个人隐私、社会稳定乃至国家安全,深入理解安全事件信息与数据泄露的本质、成因……

    2025年11月28日
    2400
  • 命令提示符有什么用?

    命令提示符是操作系统的文本交互界面,用户通过输入指令执行任务,如管理文件或运行程序。

    2025年7月13日
    6900
  • 安全报文数据项的核心构成要素与主要作用有哪些?

    安全报文数据项是保障信息系统通信安全的核心要素,通过结构化的数据定义与规范,实现身份认证、数据完整性校验、防篡改等关键安全目标,其设计与应用直接关系到信息交互的可信度,是构建安全通信体系的基石,核心类型与功能安全报文数据项根据功能可分为六大类:身份标识类:用于验证通信主体身份,如数字证书(包含公钥、颁发机构、有……

    2025年11月7日
    3600
  • auto.js脚本怎么用?能实现什么功能?

    Auto.js脚本是一种基于JavaScript语言的自动化工具,主要用于Android平台的自动化操作,它通过模拟用户触摸、滑动、点击等行为,结合控件定位、界面识别等技术,实现了对手机应用的自动化控制,无论是重复性任务的批量处理,还是复杂流程的智能执行,Auto.js脚本都能显著提升效率,减少人工干预,Aut……

    2025年12月13日
    600

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信