linux 查看系统环境信息命令汇总

7,028 阅读2分钟

前言

本文所有 shell 命令均在阿里云ECS服务器上测试过,以确保每行代码都是百分百可用的。测试使用的服务器配置信息如下:

  • 2核8G内存 40G SSD云盘
  • CentOS 7.6 64位

为了精简篇幅,同时又方便直观的了解各命令执行的效果。本文对命令输出的处理方式分为以下三种:

  1. 在提供必要的输出信息的命令行前加上 $ , 代表该行为要执行的命令,同时也意味着紧接着的是该命令执行后的输出信息,直到遇到下一个以 $ 开始的行,用于区分命令和命令的输出,实际运行不用加 $

  2. 未加 $ 的整个代码块,都不提供输出信息;

  3. 输出信息量大,但又有一些影响我们了解重要信息的输出,通过管道,使用实用程序 grep 过滤重要信息,格式:$ command | grep xxx

1. 查看服务器配置

1.1 查看系统版本

方式 1:

$ cat /etc/redhat-release
CentOS Linux release 7.6.1810 (Core) 

方式2:

lsb_release -a

1.2 查看CPU和内存

cpu:

$ cat /proc/cpuinfo | grep name
model name      : Intel(R) Xeon(R) Platinum 8163 CPU @ 2.50GHz
model name      : Intel(R) Xeon(R) Platinum 8163 CPU @ 2.50GHz

内存:

$ cat /proc/meminfo | grep Mem
MemTotal:        8009180 kB
MemFree:         7633240 kB
MemAvailable:    7657060 kB

1.3 查看磁盘和分区

磁盘:

$ fdisk -l | grep -E '.+/dev/'
磁盘 /dev/vda:42.9 GB, 42949672960 字节,83886080 个扇区

分区:

$ df -TH | grep ^/dev
/dev/vda1      ext4       43G  1.8G   39G    5% /

1.4 查看网卡和IP地址

网卡:

$ lspci | grep -i eth
00:03.0 Ethernet controller: Red Hat, Inc. Virtio network device

IP:

$ ip addr | grep -E "^[1-9]+|inet"
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
    inet 127.0.0.1/8 scope host lo
2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq state UP group default qlen 1000
    inet 172.18.24.41/20 brd 172.18.31.255 scope global dynamic eth0

1.5 查看主板制造商

$ dmidecode | grep -V -A2 "System Information"
System Information
        Manufacturer: Alibaba Cloud
        Product Name: Alibaba Cloud ECS

2. 查看防火墙

2.1 查看防火墙服务

$ systemctl list-unit-files | grep firewalld
firewalld.service                             enabled

启用防火墙服务(开机启动):

systemctl enable firewalld.service

禁用防火墙服务:

systemctl disable firewalld.service

2.2 查看防火墙运行状态

$ firewall-cmd --state
running

打开防火墙:

systemctl start firewalld.service

关闭防火墙:

systemctl stop firewalld.service

3. 查看系统用户和用户组信息

3.1 查看系统用户

$ cat /etc/passwd | grep bash
root:x:0:0:root:/root:/bin/bash
# 用户名 :密码 :用户ID  :分组ID :注释性描述   :用户目录    :登录Shell
# -------------------------------------------------------------
# root  :x   :0       :0     :root       :/root      :/bin/bash

3.2 查看用户组

$ cat /etc/group | grep root
root:x:0:
# 组名  :密码  :分组ID  :组内用户列表
# root :x     :0      :

3.3 查看系统用户密码(加密)

$ cat /etc/shadow | grep root
root:*::0:99999:7:::
# 用户名 :加密口令(密码) :最后一次修改时间 :最小时间间隔 :最大时间间隔 :警告时间 :不活动时间 :失效时间 :标志
# root  :*            :              :0          :99999      :7       :         :        :

4. 查看系统运行状态

4.1 查看当前运行的进程列表

ps aux
# 加 f 以树状显示父子进程
ps aufx

4.2 查看实时进程资源占用(CPU和内存)

top

ctrl+c 退出。

4.3 系统运行状态监控(CPU和IO)

安装监控程序 dstat:

yum install dstat

实时监控系统运行:

dstat

ctrl+c 退出。