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

简介:

连上 Linux 服务器的第一分钟

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

 
  1. w
  2. history
  3. top
  4. df
  5. 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地址是什么、以及哪些进程在使用它们,这对于你来说都非常重要。

原文发布时间为:2017-04-07

本文来自云栖社区合作伙伴“Linux中国”

相关文章
|
1天前
ffb浏览器报错:服务器拒绝连接
ffb浏览器报错:代理服务器拒绝连接
12 0
|
2天前
|
存储 监控 Linux
性能监控之Telegraf+InfluxDB+Grafana linux服务器实时监控
【6月更文挑战11天】标题性能监控之 Java Metrics 度量包性能监控之Telegraf+InfluxDB+Grafana linux服务器实时监控
13 2
|
2天前
|
存储 Linux C语言
Linux|如何安装和运行多个 glibc 库
Linux|如何安装和运行多个 glibc 库
13 5
|
3天前
|
Linux 网络安全
|
5天前
|
Java Linux Spring
在 Linux 系统中将 Spring Boot 应用作为系统服务运行
【6月更文挑战第11天】最近由于一些原因,服务器经常会重启,每次重启后需要手动启动 Spring Boot 的工程,因此我需要将其配置成开启自启动的服务。
25 1
|
6天前
|
Linux 数据库 iOS开发
超级签名源码/超级签/ios分发/签名端本地linux服务器完成签名
该系统完全在linux下运行,不存在使用第三方收费工具,市面上很多系统都是使用的是第三方收费系统,例如:某心签名工具,某测侠等,不开源而且需要每年交费,这种系统只是在这些工具的基础上套了一层壳。请需要系统的放大你们的眼睛。
10 0
|
6天前
|
Linux
【Linux】一条命令,转发所有请求到另一台服务器上 -高级技巧
【Linux】一条命令,转发所有请求到另一台服务器上 -高级技巧
10 0
|
12小时前
|
Linux 数据处理
Linux中的mknod命令:深入解析与实用指南
**mknod命令详解:Linux下创建设备文件与FIFO** Linux中的mknod用于创建设备文件(块设备、字符设备)和命名管道。需root权限,语法:`mknod NAME TYPE MAJOR MINOR`。例如,创建块设备`/dev/sda`(b 8 0)和字符设备`/dev/null`(c 1 3)。命名管道示例:`mknod /tmp/myfifo p`。注意:现代系统多用udev管理设备文件,手动使用需谨慎。
|
15小时前
|
存储 安全 Linux
Linux命令mkfifo深度解析
`mkfifo`在Linux中创建命名管道,用于进程间通信(IPC)。管道是临时的,非持久存储,作为数据传输的通道。特点是无缓冲、支持阻塞/非阻塞模式和权限控制。命令语法:`mkfifo -m <权限> 文件名`。示例:创建`mypipe`,一个进程写入,另一进程读取。注意选择阻塞模式、管理权限、删除不再使用的管道,并处理可能的错误。用于数据交换和高效能应用。