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

相关推荐

  • 如何详细掌握make命令的使用方法与操作步骤?

    make命令是Unix/Linux系统中广泛使用的自动化构建工具,主要用于根据源文件的依赖关系自动执行编译、链接等操作,通过读取Makefile文件中的规则来管理项目构建过程,掌握make命令的使用能显著提升开发效率,尤其对于包含多个源文件的项目,避免手动执行重复的编译命令,以下从基础概念、核心语法、实际操作到……

    2025年8月25日
    3800
  • Linux命令怎么打开?新手入门常用命令启动与使用方法

    在Linux操作系统中,“打开”是一个涵盖多种场景的操作,既包括启动命令行终端(即“黑窗口”),也包括通过命令打开文件、程序或目录,由于Linux的灵活性和多样性,不同场景下的“打开”方式略有差异,下面将从终端、文件、程序三个核心场景展开详细说明,打开Linux终端(命令行界面)终端是Linux命令行操作的核心……

    2025年8月31日
    4100
  • 如何查看当前 PS1 定义?

    问题现象描述:当您在 CentOS 7 系统的终端中,发现命令行提示符末尾出现异常的 后 字符(如 [user@host ~]后),这通常是由于 环境变量 PS1(主提示符字符串)被意外修改 导致的,PS1 控制着命令行的显示格式,错误配置会引发此类显示异常,原因分析PS1 变量污染:用户或程序修改了 PS1……

    2025年8月9日
    3900
  • 用命令怎么查看路由ip

    Windows系统下,可在命令提示符输入“ipconfig”;

    2025年8月17日
    3400
  • 如何正确include mex.h

    在MATLAB中,mex命令主要用于编译C/C++或Fortran源代码生成MATLAB可调用的MEX文件(动态链接库),若需直接调用已有的第三方DLL(非MEX文件),需通过loadlibrary和calllib函数实现,以下是详细操作指南:核心步骤:调用标准DLL准备工作确认DLL兼容性:32位MATLAB……

    2025年7月19日
    6600

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信