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

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

连上 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

时间: 2024-11-05 16:38:34

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

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

连上 Linux 服务器的第一分钟 这些命令对于有经验的软件工程师来说都非常熟悉,但我意识到对于一个刚开始接触 Linux 系统的初学者来说,例如我在 Holberton 学校任教的学生,却并非如此.这也是我为什么决定分享当我连上 Linux 服务器首先要运行的前 5 个命令的原因. w history top df netstat 这 5 个命令在任何一个 Linux 发行版中都有,因此不需要额外的安装步骤你就可以直接使用它们. w: [ubuntu@ip-172-31-48-251 ~]$

linux服务器crontab无法自动运行php文件问题

问题描述 linux服务器crontab无法自动运行php文件问题 1.crontab -l 2.geturl.php文件内容 3.geturl.php文件权限截图 4.如果php文件内容是 echo "123";的话可以正常运行. 请各位大神帮忙一下,应该是什么问题,多谢~ 解决方案 加一些echo在php中等,看具体是不是哪一步出错了 解决方案二: cli模式不支持header跳转,所以我用file_get_contents函数实现了这个功能,问题解决了,多谢了~ 解决方案三: 你

Linux服务器上监控网络带宽的18个常用命令

本文介绍了一些可以用来监控网络使用情况的Linux命令行工具.这些工具可以监控通过网络接口传输的数据,并测量目前哪些数据所传输的速度.入站流量和出站流量分开来显示. 一些命令可以显示单个进程所使用的带宽.这样一来,用户很容易发现过度使用网络带宽的某个进程. 这些工具使用不同的机制来制作流量报告.nload等一些工具可以读取"proc/net/dev"文件,以获得流量统计信息;而一些工具使用pcap库来捕获所有数据包,然后计算总数据量,从而估计流量负载. 下面是按功能划分的命令名称. 监

CMD里或登陆远程linux服务器时命令行下复制和粘贴实现方法_DOS/BAT

如果要在CMD中复制的话,必须通过鼠标. 复制:要先标记(在CMD中击鼠标右键)要复制的内容(或者称是范围),然后鼠标点击右键或按回车(或Ctrl+C)即可复制完成. 粘贴:击右键粘贴即可把复制到粘贴板上的内容粘贴到CMD中. putty登陆远程大型机 复制:双击选中或鼠标拖动选中要复制的内容 粘贴:点右键直接粘贴 Xshell登陆远程大型机 复制:光标选中要复制的内容,按Ctrl+Insert 粘贴:Shift+Insert

Linux服务器开发之:chmod()函数,chmod命令,以及文件屏蔽umask命令,程序修改umask,详细介绍+案例演示

 1.依赖的头文件 #include<sys/stat.h> 2.函数定义: //通过传入path中给定的文件名的方式来改变文件制定的权限 int chmod(const char *path,mode_t mode); //通过传入文件描述符的方式为一个文件重设权限 int fchmod(int fd,mode_t mode); 注意:如果使用Linux的chmod命令时,得有root权限 3.关于mode_t的定义:   A:mode_t的定义实际就是unsigned int 形式的

linux服务器下添加用户和删除用户的命令_Linux

其中各选项含义如下: -c comment 指定一段注释性描述. -d 目录 指定用户主目录,如果此目录不存在,则同时使用-m选项,可以创建主目录. -g 用户组 指定用户所属的用户组. -G 用户组,用户组 指定用户所属的附加组. -s Shell文件 指定用户的登录Shell. -u 用户号 指定用户的用户号,如果同时有-o选项,则可以重复使用其他用户的标识号. 用户名 指定新账号的登录名. 例如: 复制代码 代码如下: # useradd –d /usr/sam -m sam 此命令创建了

Linux服务器编程之:link()函数,ln命令,symlink,readlink,案例说明

1 link()依赖头文件 #include<unistd.h> 2函数定义 int link(const char *oldpath,const char *newpath); 函数说明:  link()  creates  a  new link (also known as a hard link) to an existing        file.        翻译:link()函数为一个已经存在的文件创建一个新的链接(也就是通常所说的"硬链接") If ne

Linux服务器编程之:chown()函数,chown命令

1.依赖的头文件 #include<unistd.h> 2.函数定义: //通过传入path的方式,改变和文件的拥有关系,如果他是一个符号链接,则跟踪它 int chown(const char *path, uid_t owner, gid_t group); //通过文件描述的方式进行修改用户所有组等的情况 int fchown(int fd, uid_t owner, gid_t group); //和chown不同的是它不跟踪符号链接 int lchown(const char *pa

历数Linux服务器被黑问题及应对措施

本文给大家讲解了关于linux服务器被黑的解决方法.其中的讲到了"root kits"或者流行的刺探工具占用了你的CPU,存储器,数据和带宽的问题. 平时会有一些朋友遇见服务器被黑的问题,经过搜集和整理相关的相关的材料,在这里本人给大家找到了Linux服务器被黑的解决方法,希望大家看后会有不少收获.如果你安装了所有正确的补丁,拥有经过测试的防火墙,并且在多个级别都激活了先进的入侵检测系统,那么只有在一种情况下你才会被黑,那就是,你太懒了以至没去做该做的事情,例如,安装BIND的最新补丁