Linux的基本操作

Linux 系统基础操作完整指南

一、文件与目录操作

1. 导航与查看

  • pwd (Print Working Directory)

    • 作用:显示当前所在目录的完整路径
    • 示例:pwd → 输出 /home/user/documents
    • 使用场景:当你在多层目录中迷失时快速定位当前位置
  • ls (List)

    • 常用选项:
      • -l:长格式显示(包含权限、所有者、大小等信息)
      • -a:显示所有文件(包括隐藏文件)
      • -h:人类可读的文件大小(如KB、MB)
    • 示例:ls -lah /home → 详细列出/home目录下所有文件
  • cd (Change Directory)

    • 特殊路径:
      • cd ~:返回用户主目录
      • cd ..:返回上级目录
      • cd -:返回上次所在的目录
    • 示例:cd /var/log/nginx → 进入nginx日志目录
  • tree

    • 安装:sudo apt install tree (Debian/Ubuntu)
    • 常用选项:
      • -L:限制显示层级深度
      • -d:只显示目录
    • 示例:tree -L 2 /etc → 显示/etc目录下两层结构

2. 文件操作

  • cp (Copy)

    • 常用选项:
      • -r:递归复制目录
      • -i:覆盖前提示
      • -v:显示复制进度
    • 示例:cp -riv source_dir/ dest_dir/ → 安全复制目录
  • mv (Move)

    • 重命名示例:mv old_filename new_filename
    • 移动示例:mv *.jpg /path/to/images/
  • rm (Remove)

    • 危险操作警告:
      • rm -rf / → 系统毁灭性命令(绝对不要尝试)
      • 建议使用-i选项进行交互式删除
    • 安全示例:rm -i important_file.txt
  • 文件查看工具对比

    • cat:快速查看小文件内容
    • less:支持上下翻页查看大文件(推荐)
    • more:基本分页查看(功能少于less)
    • head/tail:查看文件开头/结尾部分

3. 文件查找

  • find 高级用法:

    # 查找7天内修改过的.log文件
    find /var/log -name "*.log" -mtime -7# 查找大于10MB的文件
    find / -size +10M# 查找并删除旧备份文件
    find /backups -name "*.tar.gz" -mtime +30 -delete
    
  • grep 文本搜索:

    # 递归搜索目录中包含"error"的行
    grep -r "error" /var/log/# 显示匹配行及前后3行内容
    grep -A 3 -B 3 "critical" system.log# 使用正则表达式搜索
    grep -E "[0-9]{3}-[0-9]{4}" contacts.txt
    
  • locate 使用注意:

    • 需要先更新数据库:sudo updatedb
    • 查找速度快但不实时(适合查找不变的系统文件)

二、权限与用户管理

1. 权限控制详解

  • 权限表示法

    • 字母表示:rwx r-x r-x
    • 数字表示:755(对应rwxr-xr-x)
    • 特殊权限:
      • SUID(4):chmod u+s file
      • SGID(2):chmod g+s dir
      • Sticky(1):chmod +t /tmp
  • chmod 实例:

    # 给脚本添加执行权限
    chmod +x backup.sh# 设置目录权限(目录通常需要执行权限才能进入)
    chmod 755 public_dir/# 递归修改目录下所有文件权限
    chmod -R 644 /var/www/html/
    
  • chown 高级用法:

    # 同时修改所有者和组
    chown user:group file.txt# 递归修改目录所有权
    chown -R www-data:www-data /var/www/# 只修改组而不改变所有者
    chown :developers project/
    

2. 用户管理实践

  • 用户创建选项

    # 创建用户并指定主目录
    sudo useradd -m -d /home/newuser -s /bin/bash newuser# 创建系统用户(无登录权限)
    sudo useradd -r -s /usr/sbin/nologin service_user# 设置用户密码策略
    sudo passwd -e newuser  # 强制下次登录修改密码
    
  • 用户组管理

    # 创建新组
    sudo groupadd developers# 将用户添加到附加组
    sudo usermod -aG sudo,developers newuser# 查看用户所属组
    groups username
    
  • sudo配置

    • 配置文件:/etc/sudoers(使用visudo命令编辑)
    • 示例配置:
      # 允许用户无需密码执行特定命令
      username ALL=(ALL) NOPASSWD: /usr/bin/apt update
      

三、进程管理

1. 进程监控工具

  • ps 输出解读:

    • USER:进程所有者
    • PID:进程ID
    • %CPU:CPU使用率
    • %MEM:内存使用率
    • COMMAND:启动命令
  • top 使用技巧:

    • 交互命令:
      • M:按内存排序
      • P:按CPU排序
      • k:终止进程
      • q:退出
    • 批处理模式:top -b -n 1 > processes.txt
  • htop 增强功能:

    • 鼠标支持
    • 树状视图(F5)
    • 进程搜索(F3)
    • 自定义显示列(F2)

2. 信号管理

信号编号信号名作用示例
1SIGHUP重新加载配置kill -1 1234
9SIGKILL强制终止(不可捕获)kill -9 1234
15SIGTERM优雅终止(默认信号)kill 1234
19SIGSTOP暂停进程(不可捕获)kill -19 1234

四、网络操作

1. 网络诊断工具

  • ping 高级用法:

    # 指定次数和间隔
    ping -c 5 -i 2 google.com# 测试MTU大小
    ping -M do -s 1472 example.com
    
  • traceroute 替代方案:

    • mtr:实时路由跟踪工具
    • tracepath:不需要root权限
  • ss 现代替代netstat:

    # 查看所有TCP连接
    ss -t# 查看监听端口和进程
    ss -tulnp# 显示socket统计
    ss -s
    

2. 安全文件传输

  • scp 安全复制:

    # 指定端口复制
    scp -P 2222 file.txt user@remote:/path/# 保留文件属性
    scp -p backup.tar.gz user@backup-server:/backups/
    
  • rsync 高效同步:

    # 增量备份(排除临时文件)
    rsync -avz --exclude='tmp/' --delete /data/ user@remote:/backups/# 带宽限制(100KB/s)
    rsync --bwlimit=100 -avz large_file user@remote:/destination/# 远程到本地恢复
    rsync -avz user@remote:/backups/ /local/restore/
    

五、系统管理

1. 磁盘管理进阶

  • df 实用选项:

    # 显示inode使用情况
    df -i# 只显示特定文件系统类型
    df -t ext4
    
  • du 深度分析:

    # 找出最大的10个目录
    du -h / | sort -rh | head -n 10# 排除特定目录
    du -h --exclude=".cache" /home/user
    

2. systemd 服务管理

  • 服务状态检查

    # 详细服务状态
    systemctl status nginx --no-pager# 验证服务是否启用
    systemctl is-enabled nginx# 列出所有失败的服务
    systemctl --failed
    
  • journalctl 日志查询:

    # 跟踪最新日志
    journalctl -f -u nginx# 按时间范围查询
    journalctl -u mysql --since "2023-01-01" --until "2023-01-02"# 显示内核日志
    journalctl -k
    

六、实用技巧进阶

1. 高效命令行

  • 历史命令

    # 搜索历史命令
    history | grep "apt install"# 快速执行历史命令
    !123        # 执行第123条历史命令
    !ssh        # 执行最近的ssh开头的命令
    
  • 命令组合

    # 统计当前目录文件数
    ls | wc -l# 查找并替换多个文件内容
    grep -rl "oldtext" . | xargs sed -i 's/oldtext/newtext/g'
    

2. 环境变量管理

  • 持久化配置

    • 用户级:~/.bashrc~/.bash_profile
    • 系统级:/etc/environment/etc/profile.d/
  • PATH管理示例

    # 添加多个路径
    export PATH=$PATH:/new/path1:/new/path2# 永久添加到bashrc
    echo 'export PATH=$PATH:/opt/myapp/bin' >> ~/.bashrc
    source ~/.bashrc
    

七、学习路径建议

1. 渐进式学习

  1. 基础阶段

    • 每天掌握5个常用命令
    • 在虚拟机中练习文件操作
    • 记录常用命令到备忘单
  2. 中级阶段

    • 学习shell脚本基础
    • 理解管道和重定向
    • 配置简单的cron任务
  3. 高级阶段

    • 编写复杂shell脚本
    • 学习sed/awk文本处理
    • 理解系统启动过程

2. 推荐资源

  • 在线学习

    • Linux Journey (https://linuxjourney.com/)
    • OverTheWire Bandit (实战游戏)
  • 书籍推荐

    • 《Linux命令行与shell脚本编程大全》
    • 《鸟哥的Linux私房菜》
  • 社区支持

    • Stack Overflow
    • Linux中国论坛
    • 官方文档和man pages

Linux 系统基础操作完整指南

一、文件与目录操作

1. 导航与查看

  • pwd (Print Working Directory)

    • 作用:显示当前所在目录的完整路径
    • 示例:pwd → 输出 /home/user/documents
    • 使用场景:当你在多层目录中迷失时快速定位当前位置
  • ls (List)

    • 常用选项:
      • -l:长格式显示(包含权限、所有者、大小等信息)
      • -a:显示所有文件(包括隐藏文件)
      • -h:人类可读的文件大小(如KB、MB)
    • 示例:ls -lah /home → 详细列出/home目录下所有文件
  • cd (Change Directory)

    • 特殊路径:
      • cd ~:返回用户主目录
      • cd ..:返回上级目录
      • cd -:返回上次所在的目录
    • 示例:cd /var/log/nginx → 进入nginx日志目录
  • tree

    • 安装:sudo apt install tree (Debian/Ubuntu)
    • 常用选项:
      • -L:限制显示层级深度
      • -d:只显示目录
    • 示例:tree -L 2 /etc → 显示/etc目录下两层结构

2. 文件操作

  • cp (Copy)

    • 常用选项:
      • -r:递归复制目录
      • -i:覆盖前提示
      • -v:显示复制进度
    • 示例:cp -riv source_dir/ dest_dir/ → 安全复制目录
  • mv (Move)

    • 重命名示例:mv old_filename new_filename
    • 移动示例:mv *.jpg /path/to/images/
  • rm (Remove)

    • 危险操作警告:
      • rm -rf / → 系统毁灭性命令(绝对不要尝试)
      • 建议使用-i选项进行交互式删除
    • 安全示例:rm -i important_file.txt
  • 文件查看工具对比

    • cat:快速查看小文件内容
    • less:支持上下翻页查看大文件(推荐)
    • more:基本分页查看(功能少于less)
    • head/tail:查看文件开头/结尾部分

3. 文件查找

  • find 高级用法:

    # 查找7天内修改过的.log文件
    find /var/log -name "*.log" -mtime -7# 查找大于10MB的文件
    find / -size +10M# 查找并删除旧备份文件
    find /backups -name "*.tar.gz" -mtime +30 -delete
    
  • grep 文本搜索:

    # 递归搜索目录中包含"error"的行
    grep -r "error" /var/log/# 显示匹配行及前后3行内容
    grep -A 3 -B 3 "critical" system.log# 使用正则表达式搜索
    grep -E "[0-9]{3}-[0-9]{4}" contacts.txt
    
  • locate 使用注意:

    • 需要先更新数据库:sudo updatedb
    • 查找速度快但不实时(适合查找不变的系统文件)

二、权限与用户管理

1. 权限控制详解

  • 权限表示法

    • 字母表示:rwx r-x r-x
    • 数字表示:755(对应rwxr-xr-x)
    • 特殊权限:
      • SUID(4):chmod u+s file
      • SGID(2):chmod g+s dir
      • Sticky(1):chmod +t /tmp
  • chmod 实例:

    # 给脚本添加执行权限
    chmod +x backup.sh# 设置目录权限(目录通常需要执行权限才能进入)
    chmod 755 public_dir/# 递归修改目录下所有文件权限
    chmod -R 644 /var/www/html/
    
  • chown 高级用法:

    # 同时修改所有者和组
    chown user:group file.txt# 递归修改目录所有权
    chown -R www-data:www-data /var/www/# 只修改组而不改变所有者
    chown :developers project/
    

2. 用户管理实践

  • 用户创建选项

    # 创建用户并指定主目录
    sudo useradd -m -d /home/newuser -s /bin/bash newuser# 创建系统用户(无登录权限)
    sudo useradd -r -s /usr/sbin/nologin service_user# 设置用户密码策略
    sudo passwd -e newuser  # 强制下次登录修改密码
    
  • 用户组管理

    # 创建新组
    sudo groupadd developers# 将用户添加到附加组
    sudo usermod -aG sudo,developers newuser# 查看用户所属组
    groups username
    
  • sudo配置

    • 配置文件:/etc/sudoers(使用visudo命令编辑)
    • 示例配置:
      # 允许用户无需密码执行特定命令
      username ALL=(ALL) NOPASSWD: /usr/bin/apt update
      

三、进程管理

1. 进程监控工具

  • ps 输出解读:

    • USER:进程所有者
    • PID:进程ID
    • %CPU:CPU使用率
    • %MEM:内存使用率
    • COMMAND:启动命令
  • top 使用技巧:

    • 交互命令:
      • M:按内存排序
      • P:按CPU排序
      • k:终止进程
      • q:退出
    • 批处理模式:top -b -n 1 > processes.txt
  • htop 增强功能:

    • 鼠标支持
    • 树状视图(F5)
    • 进程搜索(F3)
    • 自定义显示列(F2)

2. 信号管理

信号编号信号名作用示例
1SIGHUP重新加载配置kill -1 1234
9SIGKILL强制终止(不可捕获)kill -9 1234
15SIGTERM优雅终止(默认信号)kill 1234
19SIGSTOP暂停进程(不可捕获)kill -19 1234

四、网络操作

1. 网络诊断工具

  • ping 高级用法:

    # 指定次数和间隔
    ping -c 5 -i 2 google.com# 测试MTU大小
    ping -M do -s 1472 example.com
    
  • traceroute 替代方案:

    • mtr:实时路由跟踪工具
    • tracepath:不需要root权限
  • ss 现代替代netstat:

    # 查看所有TCP连接
    ss -t# 查看监听端口和进程
    ss -tulnp# 显示socket统计
    ss -s
    

2. 安全文件传输

  • scp 安全复制:

    # 指定端口复制
    scp -P 2222 file.txt user@remote:/path/# 保留文件属性
    scp -p backup.tar.gz user@backup-server:/backups/
    
  • rsync 高效同步:

    # 增量备份(排除临时文件)
    rsync -avz --exclude='tmp/' --delete /data/ user@remote:/backups/# 带宽限制(100KB/s)
    rsync --bwlimit=100 -avz large_file user@remote:/destination/# 远程到本地恢复
    rsync -avz user@remote:/backups/ /local/restore/
    

五、系统管理

1. 磁盘管理进阶

  • df 实用选项:

    # 显示inode使用情况
    df -i# 只显示特定文件系统类型
    df -t ext4
    
  • du 深度分析:

    # 找出最大的10个目录
    du -h / | sort -rh | head -n 10# 排除特定目录
    du -h --exclude=".cache" /home/user
    

2. systemd 服务管理

  • 服务状态检查

    # 详细服务状态
    systemctl status nginx --no-pager# 验证服务是否启用
    systemctl is-enabled nginx# 列出所有失败的服务
    systemctl --failed
    

  • journalctl 日志查询:

    # 跟踪最新日志
    journalctl -f -u nginx# 按时间范围查询
    journalctl -u mysql --since "2023-01-01" --until "2023-01-02"# 显示内核日志
    journalctl -k
    

六、实用技巧进阶

1. 高效命令行

  • 历史命令

    # 搜索历史命令
    history | grep "apt install"# 快速执行历史命令
    !123        # 执行第123条历史命令
    !ssh        # 执行最近的ssh开头的命令
    
  • 命令组合

    # 统计当前目录文件数
    ls | wc -l# 查找并替换多个文件内容
    grep -rl "oldtext" . | xargs sed -i 's/oldtext/newtext/g'
    

2. 环境变量管理

  • 持久化配置

    • 用户级:~/.bashrc~/.bash_profile
    • 系统级:/etc/environment/etc/profile.d/
  • PATH管理示例

    # 添加多个路径
    export PATH=$PATH:/new/path1:/new/path2# 永久添加到bashrc
    echo 'export PATH=$PATH:/opt/myapp/bin' >> ~/.bashrc
    source ~/.bashrc
    

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/pingmian/93658.shtml
繁体地址,请注明出处:http://hk.pswp.cn/pingmian/93658.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

npm设置了镜像 pnpm还需要设置镜像吗

npm配置镜像后是否需要为pnpm单独设置镜像? 是的,即使您已经为npm设置了镜像源(如淘宝镜像),仍然需要单独为pnpm配置镜像源。这是因为npm和pnpm是两个独立的包管理工具,它们的配置系统和环境变量是分离的&a…

Linux管道

预备知识:进程通信进程需要某种协同,协同的前提条件是通信。有些数据是用来通知就绪的,有些是单纯的传输数据,还有一些是控制相关信息。进程具有独立性,所以通信的成本可能稍微高一点;进程间通信前提是让不…

基于Spring Boot的快递物流仓库管理系统 商品库存管理系统

🔥作者:it毕设实战小研🔥 💖简介:java、微信小程序、安卓;定制开发,远程调试 代码讲解,文档指导,ppt制作💖 精彩专栏推荐订阅:在下方专栏&#x1…

脚手架开发-Common封装基础通用工具类<基础工具类>

书接上文 java一个脚手架搭建_redission java脚手架-CSDN博客 以微服务为基础搭建一套脚手架开始前的介绍-CSDN博客 脚手架开发-准备配置-进行数据初始化-配置文件的准备-CSDN博客 脚手架开发-准备配置-配置文件的准备项目的一些中间件-CSDN博客 脚手架开发-Nacos集成-CSD…

软件系统运维常见问题

系统部署常见问题 环境配置、兼容性问题。生产与测试环境的操作系统、库版本、中间件版本不一致,运行环境软件版本不匹配。新旧版本代码/依赖不兼容。依赖缺失或冲突问题。后端包启动失败,提示类/方法/第三方依赖库找不到或者版本冲突。配置错误。系统启…

2021 IEEE【论文精读】用GAN让音频隐写术骗过AI检测器 - 对抗深度学习的音频信息隐藏

使用GAN生成音频隐写术的隐写载体 本文为个人阅读GAN音频隐写论文,部分内容注解,由于原文篇幅较长这里就不再一一粘贴,仅对原文部分内容做注解,仅供参考详情参考原文链接 原文链接:https://ieeexplore.ieee.org/abstra…

PWA技术》》渐进式Web应用 Push API 和 WebSocket 、webworker 、serviceworker

PWA # 可离线 # 高性能 # 无需安装 # 原生体验Manifest {"name": "天气助手", // 应用全名"short_name": "天气", // 短名称(主屏幕显示)"start_url": "/index.html&…

数据结构——栈和队列oj练习

225. 用队列实现栈 - 力扣(LeetCode) 这一题需要我们充分理解队列和栈的特点。 队列:队头出数据,队尾入数据。 栈:栈顶出数据和入数据。 我们可以用两个队列实现栈,在这过程中,我们总要保持其…

Java基础 8.19

目录 1.局部内部类的使用 总结 1.局部内部类的使用 说明:局部内部类是定义在外部类的局部位置,比如方法中,并且有类名可以直接访问外部类的所有成员,包含私有的不能添加访问修饰符,因为它的地位就是一个局部变量。局…

从父类到子类:C++ 继承的奇妙旅程(2)

前言:各位代码航海家,欢迎回到C继承宇宙!上回我们解锁了继承的「基础装备包」,成功驯服了public、protected和花式成员隐藏术。但——⚠️前方高能预警: 继承世界的暗流涌动远不止于此!今天我们将勇闯三大神…

【图像算法 - 16】庖丁解牛:基于YOLO12与OpenCV的车辆部件级实例分割实战(附完整代码)

庖丁解牛:基于YOLO12与OpenCV的车辆部件级实例分割实战(附完整代码) 摘要: 告别“只见整车不见细节”!本文将带您深入实战,利用YOLO12-seg训练实例分割模型,结合OpenCV的强大图像处理能力&…

ubuntu22.04配置远程桌面

文章目录前言检查桌面类型xorg远程桌面(xrdp)安装xrdpxrdp添加到ssl-certwayland远程桌面(gnome-remote-desktop)检查安装开启开启状况检查自动登录奇技淫巧前言 在windows上使用远程桌面服务,连接ubuntu主机的远程桌面 检查桌面类型 查看桌面类型、协议 echo $…

SQL Server 中子查询、临时表与 CTE 的选择与对比

在 SQL Server 的实际开发过程中,我们常常需要将复杂的查询逻辑分解为多个阶段进行处理。实现这一目标的常见手段有 子查询 (Subquery)、临时表 (Temporary Table) 和 CTE (Common Table Expression)。这三者在语法、执行效率以及可维护性方面各有优势与局限。如何选…

肖臻《区块链技术与应用》第20-22讲 - 以太坊难度调整、权益证明和智能合约

以太坊的“冰河时代”:详解难度调整算法与“难度炸弹” 摘要: 为了实现远快于比特币的十几秒出块速度,以太坊必须设计一套更为灵敏和复杂的挖矿难度调整算法。本文基于北京大学肖臻老师的公开课内容,深入剖析了以太坊独特的逐块难度调整机制。文章首先解释了其维持15秒平均…

C++中内存池(Memory Pool)详解和完整示例

1. 什么是内存池? 内存池(Memory Pool / Pool Allocator) 是一种内存管理机制,提前向系统申请一大块内存,再在这块内存里切分、分配和回收。 它相当于在用户空间建立了一层 “小型堆管理器”,避免频繁调用系…

测试 Next.js 应用:工具与策略

1. 引言 Next.js 作为一个基于 React 的全栈框架,在构建复杂 Web 应用时,测试是确保代码质量、功能稳定性和用户体验的关键步骤。测试可以分为单元测试、集成测试和端到端测试三种类型,每种类型针对不同的层面:单元测试验证单个组…

IP 分片和组装的具体过程

IP 分片和组装的具体过程 在这里插入图片描述 • 16 位标识(id): 唯一的标识主机发送的报文. 如果 IP 报文在数据链路层被分片了, 那么每一个片里面的这个 id 都是相同的. • 3 位标志字段: 第一位保留(保留的意思是现在不用, 但是还没想好说不定以后要用到). 第二位置为 1 表示…

数据仓库OLTPOLAP维度讲解

✨博客主页: https://blog.csdn.net/m0_63815035?typeblog 💗《博客内容》:大数据、Java、测试开发、Python、Android、Go、Node、Android前端小程序等相关领域知识 📢博客专栏: https://blog.csdn.net/m0_63815035/…

OpenHarmony之编译配置白名单机制深度解析:构建系统的安全防线

一、白名单机制概述 在OpenHarmony的构建系统中,compile_standard_whitelist.json是一个关键的安全验证机制,它作为编译过程中的"守门人",确保只有经过验证的组件和依赖关系才能被纳入最终构建产物。这个机制是OpenHarmony构建系统…

backward怎么计算的是torch.tensor(2.0, requires_grad=True)变量的梯度

import torch import torch.nn as nn import torch.optim as optim# 一个参数 w 2 w torch.tensor(2.0, requires_gradTrue) # 预测值 y_pred w * 3 # 6 # 真实值 y_true torch.tensor(10.0) # 损失 (预测 - 真实)^2 loss (y_pred - y_true) ** 2 # (6-10)^2 16loss.b…