飞道的博客

Linux常用命令

813人阅读  评论(0)

系统命令

runlevel                     # 查看当前的运行级别
systemctl status firewalld   # 开启网络服务功能
          stop               # 关闭
          restart            # 重启
          reload             # 重载
reboot                       # 重启
halt                         # 关机
poweroff                     # 关机
文件操作
cat                      # 在命令提示符下查看文件内容
more                     # 在命令提示符中分页查看文件内容
less                     # 命令行中查看文件可以上下翻页反复浏览
head 5n /etc/passwd      # 命令行中查看文件头几行
tail 5n /etc/passwd      # 命令行中查看文件尾几行
wc                       # 统计文件的单词数 行数等信息
目录管理
pwd                   # 查看你当前所在的目录
cd                    # 切换目录
ls                    # 查看显示目录的内容
du                    # 统计目录和文件空间的占用情况
mkdir                 # 创建新目录
touch                 # 创建文件
rm                    # 删除文件
ln                    # 创建硬链接
ln -s                 # 创建软链接
cp                    # 复制文件或目录
mv                    # 移动文件或目录
which                 # 查看linux命令所在的目录
账号与权限

```1.组管理'''
groupadd group_name                            # 创建一个新用户组 
groupdel group_name                            # 删除一个用户组 
groupmod -n new_group_name old_group_name      # 重命名一个用户组

'''2.用户管理'''
useradd zhangsan                               # 创建账户张三
passwd zhangsan                                # 给用户设置密码
userdel -r zhangsan                            # 删除张三及他的宿主目录

'''3.用户组管理'''
gpasswd -a zhangsan root                       # 将张三用户加入root组
groups zhangsan                                # 确认zhangsan用户在root组
gpasswd -d lisi root                           # 将李zhangsan户从root组中删除

'''4.权限管理'''
chown -R zhangsan /aaa                         # 将文件夹/aaa的多有者修改为zhangsan
chown root:root /aaa                           # 将/aaa文件夹的属主和属组都改成root
chmod 777 /aaa                                 # 给文件夹文件/aaa设置权限为777
磁盘

1. df -hl 查看磁盘使用情况

[root@linux-node1 ~]# df -hl
Filesystem           Size  Used Avail Use% Mounted on
/dev/mapper/cl-root   37G  2.9G   35G   8% /
devtmpfs             898M     0  898M   0% /dev
tmpfs                910M   16K  910M   1% /dev/shm
tmpfs                910M   34M  877M   4% /run

2. df -h /home :查看指定目录磁盘使用情况

[root@linux-node1 ~]# df -h /home
Filesystem           Size  Used Avail Use% Mounted on
/dev/mapper/cl-root   37G  2.9G   35G   8% /

3.du -sh ./ | grep G : 查看当前目录下个文件大于1G的文件夹*

[root@linux-node1 /]# du -sh ./*|grep G
2.2G    ./usr
1.2G    ./home

4. find / -type f -size +10M -a -size -100M -print0 | xargs -0 du -h | sort -nr
: 查找文件大于10M小于100M,倒序排列

[root@linux-node1 /]# find / -type f -size +10M -a -size -100M  -print0 | xargs -0 du -h | sort -nr
85M     /usr/bin/docker
80M     /var/lib/rpm/Packages
48M     /usr/bin/containerd
47M     /boot/initramfs-0-rescue-8b956f09fe0549c4b6182589acceab30.img
find / -type f -size +10M -a -size -100M   # 查找根文件夹下大于 10M小于 100M
CPU

1.top :查看cpu 内存等使用情况

[root@linux-node1 /]# top
top - 03:24:29      # 表示当前时间
up 4 days, 22:56,   # 系统已经运行时间 
2 users,            # 当前登录用户数
load average: 0.01, 0.03, 0.05  # 系统负载,即任务队列的平均长度。 三个数值分别为 1分钟、5分钟、15分钟前到现在的平均值
Tasks: 123 total(进程总数),   2 running(正在运行进程数), 121 sleeping,   0 stopped,   0 zombie
%Cpu(s):  0.0 
us,  0.0  # 用户空间占用CPU百分比
sy,  0.0  # 内核空间占用CPU百分比
ni,100.0  # 用户进程空间内改变过优先级的进程占用CPU百分比
id,  0.0  # 空闲CPU百分比
wa,  0.0  # 等待输入输出的CPU时间百分比
hi,  0.0  # 硬中断(Hardware IRQ)占用CPU的百分比
si,  0.0  # 软中断(Software Interrupts)占用CPU的百分比
st
KiB Mem :  1863224 total(物理内存总量),   219592 free,   498732 used,  1144900 buff/cache
KiB Swap:  2097148 total(交换区总量),  2094580 free,     2568 used.  1043628 avail Mem

进程id 进程所有者  优先级  
 PID    USER       PR      RES    SHR S %CPU %MEM     TIME+ COMMAND                                          
6583    root       20      5156   3796 S  0.3  0.3  10:54.90 vmtoolsd       
7284    root       20      2252   1580 R  0.3  0.1   0:00.03 top                 
   1    root       20      3844   2436 S  0.0  0.2   2:04.28 systemd

2. sar -u 1 5 : 每1秒采集一次CPU使用率,共采集5次

[root@linux-node1 /]# yum install sysstat  # 安装sar工具
[root@linux-node1 /]# sar -u 1 5  # 每1秒采集一次CPU使用率,共采集5次
03:58:40 AM     CPU     %user     %nice   %system   %iowait    %steal     %idle
03:58:41 AM     all      0.00      0.00      3.61      0.00      0.00     96.39
03:58:42 AM     all      0.00      0.00      0.00      0.00      0.00    100.00
03:58:43 AM     all      0.00      0.00      0.00      0.00      0.00    100.00
Average:        all      0.00      0.00      0.62      0.00      0.00     99.38

3. cat /proc/cpuinfo : 查看CPU基本信息

[root@linux-node1 ~]# cat /proc/cpuinfo
processor       : 0                # 系统中逻辑处理核的编号
vendor_id       : GenuineIntel     # CPU制造商 
cpu family      : 6                # CPU产品系列代号
model           : 142              # CPU属于其系列中的哪一代的代号
model name      : Intel(R) Core(TM) i7-7500U CPU @ 2.70GHz   # CPU属于的名字及其编号、标称主频
stepping        : 9                # CPU属于制作更新版本
cache size      : 4096 KB          # CPU二级缓存大小
physical id     : 0                # 单个CPU的标号
siblings        : 1                # 单个CPU逻辑物理核数          
cpu cores       : 1                # cpu个数

4. cat /proc/cpuinfo| grep “physical id”| sort| uniq| wc -l :查看CPU个数

[root@linux-node1 ~]# cat /proc/cpuinfo
processor       : 0                # 系统中逻辑处理核的编号
vendor_id       : GenuineIntel     # CPU制造商 
cpu family      : 6                # CPU产品系列代号
model           : 142              # CPU属于其系列中的哪一代的代号
model name      : Intel(R) Core(TM) i7-7500U CPU @ 2.70GHz   # CPU属于的名字及其编号、标称主频
stepping        : 9                # CPU属于制作更新版本
cache size      : 4096 KB          # CPU二级缓存大小
physical id     : 0                # 单个CPU的标号
siblings        : 1                # 单个CPU逻辑物理核数          
cpu cores       : 1                # cpu个数
内存

1. free -m :查询内存详情

[root@linux-node1 ~]# free -m
              total        used        free      shared              buff/cache   available
Mem:           1819         486         190          32                1142        1020
Swap:          2047           2        2045
              总内存       已使用       可用空间    多进程共享内存        磁盘缓存大小
                总内存       已使用       可用空间    多进程共享内存        磁盘缓存大小

2. cat /proc/meminfo :查看内存详细信息

[root@linux-node1 ~]# cat /proc/meminfo
MemTotal:        1863224 kB
MemFree:          195568 kB
MemAvailable:    1044924 kB
Buffers:               0 kB

3. vmstat:查看内存

[root@linux-node1 shdir]# vmstat
procs -----------memory---------- ---swap-- -----io---- -system-- ------cpu-----
 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa st
 1  0   2568 181696      0 1057272    0    0     9    52  107  155  2  1 97  0  0

r   # 表示运行队列(就是说多少个进程真的分配到CPU),当这个值超过了CPU数目,就会出现CPU瓶颈了。
b   # 表示阻塞的进程,这个不多说,进程阻塞,大家懂的。
swpd   # 虚拟内存已使用的大小,如果大于0,表示你的机器物理内存不足了
free   #空闲的物理内存的大小,我的机器内存总共8G,剩余3415M。
buff   # 用来存储目录里面有什么内容,权限等的缓存,我本机大概占用300多M
cache  # cache直接用来记忆我们打开的文件,给文件做缓冲
si     # 每秒从磁盘读入虚拟内存的大小,如果这个值大于0,表示物理内存不够用或者内存泄露了,要查找耗内存进程解决掉。
so     # 每秒虚拟内存写入磁盘的大小,如果这个值大于0,表示物理内存不够用或者内存泄露了,要查找耗内存进程解决掉。
bi     # 块设备每秒接收的块数量,当处理拷贝大量数据(2-3T)的机器上看过可以达到140000/s,磁盘写入速度差不多140M每秒
bo     # 块设备每秒发送的块数量,例如我们读取文件,bo就要大于0。bi和bo一般都要接近0,不然就是IO过于频繁,需要调整。
in     # 每秒CPU的中断次数,包括时间中断
cs     # 每秒上下文切换次数,例如我们调用系统函数,就要进行上下文切换,线程的切换,也要进程上下文切换,这个值要越小越好

us  # 用户CPU使用百分比
sy  # 系统CPU使用百分比
id  # idle(空闲CPU百分比),一般来说,id + us + sy = 100,一般我认为id是空闲CPU使用率,us是用户CPU使用率,sy是系统CPU使用率。
wt  # 等待IO CPU时间(大于0代表系统资源不足)

4. vmstat -s : 显示内存使用详细信息

[root@linux-node1 ~]# vmstat -s
      1863224 K total memory
       497780 K used memory
       599272 K active memory
       620812 K inactive memory
       188652 K free memory
            0 K buffer memory
      1176792 K swap cache
      2097148 K total swap
         2568 K used swap
      2094580 K free swap
       608294 non-nice user cpu ticks
          625 nice user cpu ticks
       539067 system cpu ticks
     63631049 idle cpu ticks
        15051 IO-wait cpu ticks
            0 IRQ cpu ticks
        10324 softirq cpu ticks
            0 stolen cpu ticks
       420669 pages paged in
      3118282 pages paged out
            7 pages swapped in
          627 pages swapped out
     73440819 interrupts
    111933117 CPU context switches
   1574604468 boot time
      1097163 forks
负载

什么是系统平均负载?

# 1. 系统平均负载是指在特定时间间隔内运行队列中的平均进程数。
# 2. 如果每个CPU内核的当前活动进程数不大于3的话,那么系统的性能是良好的。
# 3. 如果每个CPU内核的任务数大于5,那么这台机器的性能有严重问题。
# 4. 如果你的linux主机是1个双核CPU的话,当Load Average 为6的时候说明机器已经被充分使用了。
# 5. 1可以被认为是最优的负载值。负载是会随着系统不同改变得。
# 6. 单CPU系统1-3和SMP系统6-10都是可能接受的。

1. uptime : 查询系统当前负载信息

[root@linux-node1 ~]# uptime
 21:03:50 up 5 days,  5:14,  2 users,  load average: 0.02, 0.04, 0.05

'''显示内容说明:'''
10:19:04             # 系统当前时间 
up 257 days, 18:56   # 主机已运行时间,时间越大,说明你的机器越稳定。 
12 user              # 用户连接数,是总连接数而不是用户数 
load average         # 系统平均负载,统计最近1,5,15分钟的系统平均负载

2. cat /proc/loadavg :查看负载信息

[root@linux-node1 ~]# cat /proc/loadavg 
0.00 0.01 0.05 2/384 4482

# 0.00 0.01 0.05 表示最近1分钟,5分钟,15分钟 系统的平均负载; 系统负载越高,代表CPU越繁忙;
# 2/384 2代表此时运行队列中的进程个数;384 代表系统中进程的总数
# 4482 代表到此为止创建的最后一个进程的ID.
进程查询常用命令

1. ps -ef|grep python : 查看python相关进程

-e  : 显示运行在系统上的所有进程
-f  : 扩展显示输出
[root@linux-node1 ~]# ps -ef|grep python
所有者     进程id  父进程id
root       6852      1     0 Nov23 ?        00:01:23 /usr/bin/python2 -Es /usr/sbin/tuned -l -P
root      37276      1     0 Nov24 ?        00:00:25 /usr/bin/python /usr/bin/salt-master
root      37285  37276     0 Nov24 ?        00:00:00 /usr/bin/python /usr/bin/salt-master

2. ps -aux | grep python :查看python相关进程

-a  :  显示现行终端机下的所有程序,包括其他用户的程序
-u  :  以用户为主的格式来显示程序状况
-x  :  显示所有程序,不以终端机来区分
[root@linux-node1 ~]# ps -aux | grep python
所有者    进程id  cpu占用 内存占用
root       6852  0.0  0.8 573820 16424 ?        Ssl  Nov23   1:23 /usr/bin/python2 -Es /usr/sbin/tuned -l -P
root      37276  0.0  2.1 389128 40640 ?        Ss   Nov24   0:25 /usr/bin/python /usr/bin/salt-master
root      37285  0.0  1.0 306196 20276 ?        S    Nov24   0:00 /usr/bin/python /usr/bin/salt-master

3. pgrep -ln sshd
: 通过程序的名字来查询进程的工具,一般是用来判断程序是否正在运行

[root@linux-node1 ~]# pgrep -ln sshd
32946 sshd

4. pstree -apnh|grep sshd :显示进程间的关系

-a  :  显示每个程序的完整指令,包含路径
-p  :  显示程序识别码
-n  :  用程序识别码排序,预设是以程序名称来排序。
-h  :  列出树状图时
[root@linux-node1 ~]# pstree -apnh|grep sshd
  |-sshd,6851 -D
  |   `-sshd,32946    
  |           `-grep,39535 --color=auto sshd

5.pidof sshd :显示sshd进程的所有进程号

[root@linux-node1 ~]# pidof sshd
32946 6851

6. kill 和 pkill 杀死进程

[root@linux-node1 ~]# kill -9  2233    # 杀死进程2233
[root@linux-node1 ~]# pkill zabbix     # 杀死zabbix进程

** 7.netstat -anptu|grep 22 : 查看22端口运行的服务**

[root@linux-node1 ~]# netstat -anptu|grep 22
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN      6851/sshd           
tcp        0      0 192.168.56.11:22        192.168.56.1:62530      ESTABLISHED 32946/sshd: root@pt 
tcp6       0      0 :::22                     :::*                   LISTEN      6851/sshd

转载:https://blog.csdn.net/Hanmin_hm/article/details/104903254
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场