TranslateProject/published/20140818 What are useful CLI tools for Linux system admins.md

13 KiB
Raw Blame History

Linux系统管理员的命令行工具箱目录

系统管理员sysadmins负责日常维护生产系统和服务。其中一个关键任务就是保证功能性服务能24小时工作。为了这个他们得很小心地计划备份方式灾难管理策略定时维护安全审查等等。和任意其他管理一样系统管理员也有他们的必备工具。在正确的时间正确的情况下使用合适的工具可以帮助维护操作系统的健壮达到最小的服务中断时间和最大的运行时间。

这篇文章会介绍一些系统管理员日常活动中最常用和有效的命令行工具。如果你想推荐其他没在这里列出来的好用的工具,别忘了在评论区里分享一下。

网络工具

  1. ping通过ICMP回应/回复报文来检查远端主机的端到端连接性RTT延时抖动丢包。用来检查系统状态和可连接性很不错。

  2. phping网络扫描和检测工具可以产生ICMP/TCP/UDP ping数据包。常常用于高级端口扫描防火墙测试手动MTU路径发现和碎片测试。

  3. traceroute通过TTL限定的ICMP/UDP/TCP侦测包来发现从本地主机到远端目标主机之间的第三层转发路径。用来调试网络连接性和路由问题。

  4. mtrtraceroute的一个变种能根据运行时统计数据整理出每一跳的包丢失/抖动。用来评估路由路径延时很不错。

  5. netcat/socatTCP/IP网络里的瑞士军刀可以读/写 TCP/UDP 协议字节流。用来调试防火墙策略和服务可用性很不错。

  6. digDNS调试工具可以生成正向查询反向查询搜索域名服务器检查CNAMEMX和其他DNS记录。可以在侦错的时候查询特定的DNS服务器。

  7. nslookup另外一个DNS检查/调试工具。支持所有DNS查询和记录。可以查询特定DNS服务器。

  8. dnsyo一个DNS测试工具通过对全世界1500个不同网络中的大量开放解析器执行DNS查询来测试DNS传输。

  9. lsof:显示进程打开的文件信息(例如,普通文件,管道或套接字)。用来监视网络连接很不错。

  10. iftop一个基于ncurses的命令行界面应用可以实时监视各个网络物理接口上的网络连接和带宽占用。用来记录霸占带宽的应用、用户、目的地和端口等很不错。

  11. netstat一个网络统计工具可以显示状态以及统计信息当前网络连接TCP/UDP端口IP地址、路由表、TX/RX traffic以及网络协议。用来做网络相关诊断和性能调试很不错。

  12. tcpdump一个常用的基于libpcap抓包库的包侦测工具。可以按伯克利包过滤器格式定义抓包条件。

  13. tshark另一个命令行抓包工具和它的GUI版本Wireshark完全兼容。支持1000种协议而且这个列表还在增加。用来调试、分析和保存实时网络封包信息很不错。

  14. ip一个多功能的命令行网络工具是iproute2包的一部分。可以检查和修改路由表、网络设备状态以及IP隧道设置。用来查看路由表、增加/删除静态路由、配置网络接口、以及调试路由问题很有用。

  15. ifup/ifdown:用来激活和关闭特定的网络接口。经常用于重启整个网络服务。

  16. autossh一个能建立SSH连接并在断线后自动重新连接的程序。用来创建长时间保持的穿越严格企业网络的SSH隧道很有用。

  17. iperf一个网络测试工具通过在发送自定义TCP/UDP数据流来衡量主机间双向最大吞吐量。

  18. elinks/lynx:为基于命令行的服务器环境下使用的基于文字的网页浏览器。

安全工具

  1. iptables一个用户空间下的命令行工具用于配置Linux内核防火墙。可以创建和修改Linux内核空间的网络包接收、转发和发送规则。

  2. nmap:一个常用的为了安全审查目的的端口扫描和网络发现工具。用来在本地网络中找出哪些主机开机并运行起来了以及某台特定主机打开了哪些端口很有用。

  3. TCP Wrappers:一个主机端的网络访问控制列表工具,可以过滤进入/出去的网络请求/回复。经常配合iptables一起使用作为额外一层安全保护。

  4. getfacl/setfacl:查看和定制文件和目录的访问控制列表,作为传统文件权限的扩展。

  5. cryptsetup用于创建和管理LUKS加密磁盘分区。

  6. lynis一个命令行的漏洞扫描工具。可以扫描整个Linux系统并汇报潜在的漏洞以及相关可能解决方案。

  7. maldet:一个恶意软件扫描命令行工具,可以检测和隔离潜在的感染文件。可以在后台运行长期监视。

  8. rkhunter/chkrootkit:一个命令行工具,可以扫描本地系统里的潜在木马、隐藏后门和可疑利用,并禁用它们。

存储工具

  1. fdisk:一个磁盘分区编辑工具。用于查看、创建和修改本地磁盘或可移动磁盘的分区。

  2. sfdiskfdisk的一个变种能用一种非交互的方式访问或更新磁盘分区表。用来自动化备份和恢复过程中的磁盘分区很有用。

  3. parted另一个磁盘分区编辑器支持超过2TB的磁盘的GPTGUID分区表格式。gparted是parted的一个前端GTK+图形界面。

  4. df:用来查看不同分区或文件路径的已用/可用存储空间和挂载点。还有一个更易用的变种dfc。

  5. du用来查看不同文件和目录的当前磁盘占用情况例如du -sh *)。

  6. mkfs一个磁盘格式化命令用来在独立磁盘分区上建立文件系统。有多个文件系统相关的版本ext2、ext3、ext4、bfs、ntfs、vfat/fat。

  7. fsck:一个命令行工具,用来检查文件系统错误并尝试可能的修复。通常在启动时自动运行,但是在卸载一个分区后也可以根据需要手动运行。

  8. mount:用来映射一个物理磁盘分区、网络共享或远程存储到一个本地挂载点。任何对挂载点里的读/写操作都是对应实际存储的实际数据读/写。

  9. mdadm一个命令行工具用来管理物理块设备上的软件RAID设备。可以创建、构造、增长或监视RAID阵列。

  10. lvm:一套命令行工具集,用来管理卷分组和物理/逻辑卷,可以用最小的停机时间在多个物理磁盘上创建、调整大小、拆分和合并卷。

日志访问工具

  1. tail用来查看一个增长中的日志文件的尾部。有几个变种包括multitail多窗口查看ztail支持inotify和正则表达式过滤以及颜色

  2. logrotate:一个命令行工具,可以在根据设定的时间段拆分、压缩并通过邮件发送旧的/大的日志文件。用来管理可能产生大量日志文件的繁忙主机很有用。

  3. grep/egrep可以通过特定的模式或正则表达式过滤日志内容。变种包括用户更友好的ack和速度更快的ag。

  4. awk:一个多功能的文本扫描和处理工具。常用于从文本/日志文件中找出特定的列或内容,并输出给其他工具。

  5. sed:一个文本流编辑工具,可以过滤和改变(例如,删除行/空格、替换/转换单词、增加计数文本流并通过管道连接到stdout/stderr或者其他工具。

备份工具

  1. rsync一个快速的单向增量备份和镜像工具LCTT 译注rsync 应是双向的。常用于复制一个数据仓库到线下存储可以选择通过SSH或stunnel的加密连接。

  2. rdiff-backup:另一个有效利用带宽的增量备份工具。管理两个连续快照之间的差分。

  3. duplicity一个加密的增量备份工具。使用GnuPG加密备份并通过SSH上传到远程服务器。

性能监视工具

  1. top一个命令行的进程查看程序。可以监视系统负载、进程状态、CPU和内存占用。有一个更易用的变种htop。

  2. ps显示系统所有运行中进程的一个快照。输出可以定制成显示PID、PPID、用户、负载、内存、积累的用户/系统时间、启动时间、以及更多。有一个变种pstree可以用树结构显示进程。

  3. nethogs:一个带宽监视工具,按进程来分组显示活动网络连接,实时汇报每个进程占用的(上传/下载)带宽。

  4. ngxtop一个网页服务器访问日志解析和监视工具界面受到了top命令启发。它可以实时汇报整理过的页面请求列表包括频率、大小、HTTP返回值、IP地址等等。

  5. vmstat一个简单的命令行工具可以显示多个实时系统特征例如进程数、剩余内存、分页状态、CPU占用、块设备I/O活动、中断/上下文切换统计、等等。

  6. iotop一个基于ncurses的I/O监视工具可以实时排序显示所有运行中进程的磁盘I/O活动。

  7. iostat一个命令行工具可以汇报当前CPU使用情况以及设备I/O使用情况这里的I/O使用情况例如块传输速度、字节读/写速度)是按设备或分区来汇报的。

效率工具

  1. screen用来把一个单一的终端拆分成多个持久的虚拟终端也支持远程用户访问类似teamviewer的屏幕分享功能。

  2. tmux:另一个终端复用工具,可以支持多个长期会话,还可以横向/纵向拆分终端。

  3. cheat一个简单的命令行工具可以让你查看多个常用Linux命令的备忘录就在手边非常方便。内建的备忘录也可以完全定制。

  4. apropos:用来在帮助手册里查找描述或关键字很有用。

包管理工具

  1. apt基于Debian系统的事实上的包管理工具例如Debian、Ubuntu或Backtrack。一个救生圈。

  2. apt-fastapt-get的一个支撑应用可以通过多个并行连接明显提高apt-get的下载速度。

  3. apt-file:用来查看某个特定文件属于哪个.deb包或者显示一个特定.deb包里的所有文件。已安装和未安装的包都能支持。

  4. dpkg:一个用来手动安装.deb包的命令行工具。强烈建议尽可能的使用apt。

  5. yum用于基于红帽的系统的自动包管理工具比如RHEL、CentOS或Fedora。这是另一个救生圈

  6. rpm:通常我都是使用 rpm 来配合 yum 使用。有很多有用的参数,比如-q、-f、-l可以分别用来查询、指定文件和路径。

硬件工具

  1. lspci一个命令行工具可以显示已安装的PCI设备的各种信息比如型号名称、设备驱动、设备功能、内存地址、PCI总线地址。

  2. lshw一个命令行工具可以查询和显示不同分类下的硬件配置的详细信息例如处理器、内存、主板、网络、存储。支持多重输出格式html、xml、json、text。

  3. inxi一个综合硬件查看工具可以提供不同硬件模块的总览例如CPU显卡声卡网卡温度/风扇传感器,等等。

如果你希望推荐没有列在这里的好用的工具,不要客气,在评论区里分享一下。


via: http://xmodulo.com/2014/08/useful-cli-tools-linux-system-admins.html

作者:Sarmed Rahman 译者:zpl1025 校对:wxy

本文由 LCTT 原创翻译,Linux中国 荣誉推出