连接到Linux服务器时首先要运行的5个命令

简介:

作为一个系统管理员/SRE 工作 5 年后,我知道当我连接到一台 Linux 服务器时我首先应该做什么。这里有一系列关于服务器你必须了解的信息,以便你可以(在大部分时间里)更好的调试该服务器。

连接到Linux服务器时首先要运行的5个命令

连上 Linux 服务器的第一分钟

这些命令对于有经验的软件工程师来说都非常熟悉,但我意识到对于一个刚开始接触 Linux 系统的初学者来说,例如我在 Holberton 学校任教的学生,却并非如此。这也是我为什么决定分享当我连上 Linux 服务器首先要运行的前 5 个命令的原因。

 
 
  1. history 
  2. top 
  3. df 
  4. netstat 

这 5 个命令在任何一个 Linux 发行版中都有,因此不需要额外的安装步骤你就可以直接使用它们。

w:

 
 
  1. [ubuntu@ip-172-31-48-251 ~]$ w 
  2. 23:40:25 up 273 days, 20:52,  2 users,  load average: 0.33, 0.14, 0.12 
  3. USER     TTY      FROM              LOGIN@   IDLE   JCPU   PCPU WHAT 
  4. ubuntu pts/0    104-7-14-91.ligh 23:39    0.00s  0.02s  0.00s w 
  5. root pts/1    104-7-14-91.ligh 23:40    5.00s  0.01s  0.03s sshd: root [priv] 
  6. [ubuntu@ip-172-31-48-251 ~]$  

这里列出了很多有用的信息。首先,你可以看到服务器运行时间 uptime,也就是服务器持续运行的时间。然后你可以看到有哪些用户连接到了服务器,当你要确认你没有影响你同事工作的时候这非常有用。最后 load average 能很好的向你展示服务器的健康状态。

history

 
 
  1. [ubuntu@ip-172-31-48-251 ~]$ history 
  2.    1  cd /var/app/current/log/ 
  3.    2  ls -al 
  4.    3  tail -n 3000 production.log  
  5.    4  service apache2 status 
  6.    5  cat ../../app/services/discourse_service.rb  

history 能告诉你当前连接的用户之前运行了什么命令。你可以看到很多关于这台机器之前在执行什么类型的任务、可能出现了什么错误、可以从哪里开始调试工作等信息。

top

 
 
  1. top - 23:47:54 up 273 days, 21:00,  2 users,  load average: 0.02, 0.07, 0.10 
  2. Tasks:  79 total,   2 running,  77 sleeping,   0 stopped,   0 zombie 
  3. Cpu(s):  1.0%us,  0.0%sy,  0.0%ni, 98.7%id,  0.0%wa,  0.0%hi,  0.0%si,  0.3%st 
  4. Mem:   3842624k total,  3128036k used,   714588k free,   148860k buffers 
  5. Swap:        0k total,        0k used,        0k free,  1052320k cached 
  6.  PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND                                                                                                                                                                                                                       
  7. 21095 root      20   0  513m  21m 4980 S  1.0  0.6   1237:05 python                                                                                                                                                                                                                         
  8. 1380 healthd   20   0  669m  36m 5712 S  0.3  1.0 265:43.82 ruby                                                                                                                                                                                                                           
  9. 19703 dd-agent  20   0  142m  25m 4912 S  0.3  0.7  11:32.32 python                                                                                                                                                                                                                         
  10.    1 root      20   0 19596 1628 1284 S  0.0  0.0   0:10.64 init                                                                                                                                                                                                                           
  11.    2 root      20   0     0    0    0 S  0.0  0.0   0:00.00 kthreadd                                                                                                                                                                                                                       
  12.    3 root      20   0     0    0    0 S  0.0  0.0  27:31.42 ksoftirqd/0                                                                                                                                                                                                                    
  13.    4 root      20   0     0    0    0 S  0.0  0.0   0:00.00 kworker/0:0                                                                                                                                                                                                                    
  14.    5 root       0 -20     0    0    0 S  0.0  0.0   0:00.00 kworker/0:0H                                                                                                                                                                                                                   
  15.    7 root      20   0     0    0    0 S  0.0  0.0  42:51.60 rcu_sched                                                                                                                                                                                                                      
  16.    8 root      20   0     0    0    0 S  0.0  0.0   0:00.00 rcu_bh 

你想知道的下一个信息:服务器当前在执行什么工作。使用 top 命令你可以看到所有正在执行的进程,然后可以按照 CPU、内存使用进行排序,并找到占用资源的进程。

df

 
 
  1. [ubuntu@ip-172-31-48-251 ~]$ df -h 
  2. Filesystem      Size  Used Avail Use% Mounted on 
  3. /dev/xvda1      7.8G  4.5G  3.3G  58% / 
  4. devtmpfs        1.9G   12K  1.9G   1% /dev 
  5. tmpfs           1.9G     0  1.9G   0% /dev/shm 

你服务器正常工作需要的下一个重要资源就是磁盘空间。磁盘空间消耗完是非常典型的问题。

netstat

 
 
  1. [ubuntu@ip-172-31-48-251 ec2-user]# netstat -lp 
  2. Active Internet connections (only servers) 
  3. Proto Recv-Q Send-Q Local Address               Foreign Address             State       PID/Program name    
  4. tcp        0      0 *:http                      *:*                         LISTEN      1637/nginx           
  5. tcp        0      0 *:ssh                       *:*                         LISTEN      1209/sshd            
  6. tcp        0      0 localhost:smtp              *:*                         LISTEN      1241/sendmail        
  7. tcp        0      0 localhost:17123             *:*                         LISTEN      19703/python         
  8. tcp        0      0 localhost:22221             *:*                         LISTEN      1380/puma 2.11.1 (t  
  9. tcp        0      0 *:4242                      *:*                         LISTEN      18904/jsvc.exec      
  10. tcp        0      0 *:ssh                       *:*                         LISTEN      1209/sshd            

计算机已成为我们世界的重要一部分,因为它们有通过网络进行相互交流的能力。知道你的服务器正在监听什么端口、IP地址是什么、以及哪些进程在使用它们,这对于你来说都非常重要。

显然这个列表会随着你的目的和你已有的信息而变化。例如,当你需要调试性能的时候,Netflix 就有一个自定义的列表。你有任何不在我 Top 5 中的有用命令吗?在评论部分和我们一起分享吧!






本文作者:佚名
来源:51CTO
目录
相关文章
|
1天前
|
Linux Shell 开发工具
|
1天前
|
安全 Linux Shell
深入探索Linux的login命令
`login`命令是Linux中用户身份验证的关键,用于启动新的会话并访问系统资源。它验证用户名和密码,创建安全的会话,管理权限。主要特点是加密密码、确保身份验证和会话管理。管理员可能使用参数如`-f`, `-h`, `-p`, `-s`进行特殊操作。尽管通常不直接运行login命令,但了解其工作原理和安全最佳实践是重要的,包括使用强密码,定期更改,通过安全协议远程登录,以及谨慎管理会话。
|
1天前
|
监控 Linux 数据处理
深入了解Linux的logger命令:日志记录与监控
`logger`命令在Linux中用于向系统日志发送消息,便于记录系统事件和应用程序状态。它与`syslogd`配合,允许用户指定优先级、标识符和内容。简单易用,灵活适应不同日志需求。示例:`logger -p user.warning -t MYAPP "A warning occurred."`。注意选择合适优先级,使用有意义的标识符,并结合其他工具如`logrotate`进行日志管理。
|
1天前
|
自然语言处理 Linux 数据处理
探索Linux的localedef命令:定义和管理本地化环境
`localedef`是Linux中用于创建和管理本地化环境的命令,它基于输入文件和模板生成二进制的本地化定义,以支持多语言显示和处理。通过参数如 `-i` 指定输入文件,`-f` 指定字符集,`-o` 输出文件路径。在实际应用中,如创建法语(法国)环境,会执行类似 `localedef -i fr_FR -f UTF-8 -c -o /path/to/output fr_FR.UTF-8` 的命令。使用时注意输入文件的准确性、选择合适的字符集,并在操作前备份。查阅文档和社区资源可获取更多帮助。
|
1天前
|
Linux 数据处理
Linux中的localectl命令:深入了解与应用
`localectl`是Linux中用于管理区域设置的`systemd`工具,涉及日期、时间、货币格式等。它通过修改配置文件调整系统本地化,并确保数据处理工具的正确运行。主要功能包括列出所有区域设置(`list-locales`)、设置主区域(如`set-locale LANG=en_US.UTF-8`)和查看当前状态。使用时注意理解区域设置差异,备份配置,测试设置效果,并保持系统一致性。查阅文档以获取更多操作详情。
|
1天前
|
Linux 数据处理
Linux中的setarch命令:深入探索与实际应用
`setarch`是Linux中用于调整程序执行环境的命令,允许在不同CPU架构或功能标志之间切换,支持跨架构运行二进制文件和测试程序兼容性。它通过设置`PERSONALITY`标志改变指令集解释方式。关键参数包括指定架构(-a)和设置CPU功能标志(-R)。在实际应用中,如需在32位模式下运行64位程序,可以使用`setarch i386 <command>`。使用时注意程序需求、测试验证,避免滥用,并在必要时备份。查阅文档以获取详细信息。
|
1天前
|
存储 Linux 数据处理
Linux中的link命令:深入解析与实际应用
**Linux的`ln`命令详解:创建硬链接和软链接。硬链接共享相同inode,不占额外空间;软链接(符号链接)如快捷方式,可跨文件系统。使用`-s`创建软链接,`-f`强制覆盖。注意选择合适链接类型,避免循环链接,确保目标存在。**
|
9月前
|
关系型数据库 Linux 虚拟化
掌握Linux服务器管理技巧与容器化应用 - 从软件服务到虚拟化技术全面解析
掌握Linux服务器管理技巧与容器化应用 - 从软件服务到虚拟化技术全面解析
98 0
|
23天前
|
运维 监控 Linux
提升系统稳定性:Linux服务器性能监控与故障排查实践深入理解与实践:持续集成在软件测试中的应用
【5月更文挑战第27天】在互联网服务日益增长的今天,保障Linux服务器的性能和稳定性对于企业运维至关重要。本文将详细探讨Linux服务器性能监控的工具选择、故障排查流程以及优化策略,旨在帮助运维人员快速定位问题并提升系统的整体运行效率。通过实际案例分析,我们将展示如何利用系统资源监控、日志分析和性能调优等手段,有效预防和解决服务器性能瓶颈。
|
Linux Windows
Linux学习笔记 25(DHCP服务器应用)
1、 安装DHCP 2、 查询DHCP软件包是否安装 3、 服务:/usr/sbin/dhcpd 4、 配置文件目录:/etc/dhcp/dhcpd.conf 5、 模板文件目录:/usr/share/doc/dhcp-4.2.5/dhcpd.conf.example 6、 开启/关闭/重启DHCP服务 Systemcctl start/stop dhcpd 7、 开机自启/开机不自启DHCP服务 systemcctl restart/enable/disable dhcpd 8、 把DHCP服务器配置模板文件复制到/etc/dhcpd.conf文件中 9、 修改配置文
Linux学习笔记 25(DHCP服务器应用)