第1次 更多的bash shell命令

1.检测程序

       程序都是进程在运行,进程里面有很多线程,面试经常会问进程和线程的区别,线程可以访问另一个线程的什么什么的,这些我都听腻了,区别就是进程会分配程序需要的空间,创建线程需要的资源,用一个中二的说法:进程就是世界,线程是世界意志的执行者。线程可以访问进程的各种资源,但是不能访问线程自己的堆栈。

        查看进程的命令是ps,它有很多搭配的参数,比如ps -e 输出全部进程,ps -f显示进程的完整信息,还可以组合ps -ef

       实时检测进程的运行情况:top

        进程显示的信息有哪些?

        UID 启动这些进程的用户

        PID 进程的ID号

        PPID 父进程的ID

        C 进程生命周期中CPU利用率

        STIME 进程启动时的系统时间

        TTY 启动进程时的终端时间

        CMD 启动的程序名称

       使用ps -l会出现更多的字段,可以自行查询

2.结束进程

        我们需要知道进程的各种状态,根据情况结束进程,唤醒进程,挂起进程等等,进程是通过信号来通信。下面列举了几种信号对应的状态

信号 名称 描述
1 HUP 挂起
2 INT 中断
3 QUIT 结束运行
9 KILL 无条件终止
11 SEGV 段错误
15 TERM 尽可能终止
17 STOP 无条件停止运行,但是不终止
18 TSTP 停止或者暂停,但继续在后台运行
19 CONT 在STOP或者TSTP后恢复运行

(1).kill命令

    kill PID  

        终止PID代表的进程,这是向进程发生TERM命令,有些进程会很调皮,无视这个命令,这个时候你可以强硬一点,使用kill -s PID,pid进程会立刻GG

(2). killall命令

kill需要pid,killall可以指定进程名字,还能用通配符

3.监测磁盘空间

有时候我们还要处理LINUX系统空间,所以这也是一项基本技能。

1.挂载存储媒体

LINUX文件系统把所有的磁盘并入到一个虚拟目录下,把新的储存媒体比如U盘放在虚拟目录下,这样的工作叫做挂载。

(1).mount命令

这是挂载媒体的命令,输入mount,输出当前系统上挂载的设备列表

mount命令提供四个部分的信息:

(1).媒体的设备文件名

(2).媒体挂载的虚拟目录的挂载点

(3).文件系统类型

(4).已挂载媒体的访问状态

·修改挂载点 mount -t type device directory

type:格式化方法,有很多种,比如vfat,ios9660,ntfs

device:目前的挂载点

directory:修改到指定位置的挂载点

mount -t  vfat /dev/sdb1 /media/disk

把sdb1的挂载点修改到/media/disk

mount还可以搭配其他的参数,完成更加复杂的命令,这里只介绍重要的-o

-o可以添加一些其他的命令,后面用逗号分割,

ro只读挂载

rw读写挂载

user允许普通用户挂载文件系统

check-none挂载时不检测

loop挂载一个文件

2.umount移除挂载设备

从系统中移除一个可移动设备,需要先卸载。

umount [directory | device]

可以指定设备名字或者挂载点来移除设备,如果设备正在使用,则会失败

3.df命令

查看挂载设备的内存使用情况

这个输出很容易看懂,下面就是df的输出,分别是设备的设备文件位置,块(1M)的数量,已经使用的块,可以空间,使用率,挂载点

Filesystem     1K-blocks    Used Available Use% Mounted on
/dev/root       61054632 3911020  54605344   7% /
devtmpfs          781052       0    781052   0% /dev
tmpfs             946812       0    946812   0% /dev/shm
tmpfs             378728    1188    377540   1% /run
tmpfs               5120       4      5116   1% /run/lock
/dev/mmcblk0p1    261108   31228    229880  12% /boot
tmpfs             189360      20    189340   1% /run/user/1000

df -h 输出更明白

Filesystem      Size  Used Avail Use% Mounted on
/dev/root        59G  3.8G   53G   7% /
devtmpfs        763M     0  763M   0% /dev
tmpfs           925M     0  925M   0% /dev/shm
tmpfs           370M  1.2M  369M   1% /run
tmpfs           5.0M  4.0K  5.0M   1% /run/lock
/dev/mmcblk0p1  255M   31M  225M  12% /boot
tmpfs           185M   20K  185M   1% /run/user/1000

4.du命令

df是看整体的情况,则du是看某个指定文件夹下面的内存情况,某人情况下是看当前的文件夹,它会输出指定文件夹下的子文件夹使用情况。这种输出会从文件夹最底层开始,也就是最里面开始输出。也许我们并不需要知道每个文件夹的情况。只需要知道指定的文件夹整体情况。

du -s 则输出文件夹下的整体占用空间

du -h 输出普通人看得明白的数据,和上面那个一样

du -c 输出整体的情况,它是在末尾多了一个统计而已

我的桌面有一个Linux文件目录

du -s linux #输出Linux的文件大小

输出:

6236    linux

du -h linux

64K     linux/.git/hooks
4.0K    linux/.git/refs/heads
4.0K    linux/.git/refs/tags
12K     linux/.git/refs
8.0K    linux/.git/info
4.0K    linux/.git/branches
4.0K    linux/.git/objects/info
4.0K    linux/.git/objects/pack
12K     linux/.git/objects
116K    linux/.git
64K     linux/linux-2.6/.git/hooks
4.0K    linux/linux-2.6/.git/refs/heads
4.0K    linux/linux-2.6/.git/refs/tags
12K     linux/linux-2.6/.git/refs
8.0K    linux/linux-2.6/.git/info
4.0K    linux/linux-2.6/.git/branches
4.0K    linux/linux-2.6/.git/objects/info
5.9M    linux/linux-2.6/.git/objects/pack
5.9M    linux/linux-2.6/.git/objects
6.0M    linux/linux-2.6/.git
6.0M    linux/linux-2.6
6.1M    linux

64      linux/.git/hooks
4       linux/.git/refs/heads
4       linux/.git/refs/tags
12      linux/.git/refs
8       linux/.git/info
4       linux/.git/branches
4       linux/.git/objects/info
4       linux/.git/objects/pack
12      linux/.git/objects
116     linux/.git
64      linux/linux-2.6/.git/hooks
4       linux/linux-2.6/.git/refs/heads
4       linux/linux-2.6/.git/refs/tags
12      linux/linux-2.6/.git/refs
8       linux/linux-2.6/.git/info
4       linux/linux-2.6/.git/branches
4       linux/linux-2.6/.git/objects/info
6000    linux/linux-2.6/.git/objects/pack
6008    linux/linux-2.6/.git/objects
6112    linux/linux-2.6/.git
6116    linux/linux-2.6
6236    linux
6236    total

5. 处理数据文档

(1) sort 对文档的数据排序

默认情况是安装字符串的升序排序,如果你的文档是数字字符,然后你想按数字排序,可以用-n,如果开头是时间,可以按时间排序,-r是降序,-t指定分隔符,-k指定排序的字段。-k和-t一起使用很有效。

理解一下:

du linux | sort -nr

6236    linux
6116    linux/linux-2.6
6112    linux/linux-2.6/.git
6008    linux/linux-2.6/.git/objects
6000    linux/linux-2.6/.git/objects/pack
116     linux/.git
64      linux/linux-2.6/.git/hooks
64      linux/.git/hooks
12      linux/linux-2.6/.git/refs
12      linux/.git/refs
12      linux/.git/objects
8       linux/linux-2.6/.git/info
8       linux/.git/info
4       linux/linux-2.6/.git/refs/tags
4       linux/linux-2.6/.git/refs/heads
4       linux/linux-2.6/.git/objects/info
4       linux/linux-2.6/.git/branches
4       linux/.git/refs/tags
4       linux/.git/refs/heads
4       linux/.git/objects/pack
4       linux/.git/objects/info
4       linux/.git/branches

Linux文件下全部文件降序排列 ,|是管道符

sort -t ':' -k 3 /etc/passwdsystemd-network:x:101:102:systemd Network Management,,,:/run/systemd:/usr/sbin/nologin
systemd-resolve:x:102:103:systemd Resolver,,,:/run/systemd:/usr/sbin/nologin
systemd-timesync:x:103:109:systemd Time Synchronization,,,:/run/systemd:/usr/sbin/nologin
messagebus:x:104:110::/nonexistent:/usr/sbin/nologin
_rpc:x:105:65534::/run/rpcbind:/usr/sbin/nologin
sshd:x:106:65534::/run/sshd:/usr/sbin/nologin
statd:x:107:65534::/var/lib/nfs:/usr/sbin/nologin
avahi:x:108:113:Avahi mDNS daemon,,,:/run/avahi-daemon:/usr/sbin/nologin
dnsmasq:x:109:65534:dnsmasq,,,:/var/lib/misc:/usr/sbin/nologin
lightdm:x:110:114:Light Display Manager:/var/lib/lightdm:/bin/false
rtkit:x:111:116:RealtimeKit,,,:/proc:/usr/sbin/nologin
pulse:x:112:119:PulseAudio daemon,,,:/run/pulse:/usr/sbin/nologin
saned:x:113:122::/var/lib/saned:/usr/sbin/nologin
colord:x:114:123:colord colour management daemon,,,:/var/lib/colord:/usr/sbin/nologin
hplip:x:115:7:HPLIP system user,,,:/run/hplip:/bin/false
daemon:x:1:1:daemon:/usr/sbin:/usr/sbin/nologin
proxy:x:13:13:proxy:/bin:/usr/sbin/nologin
bin:x:2:2:bin:/bin:/usr/sbin/nologin
www-data:x:33:33:www-data:/var/www:/usr/sbin/nologin
sys:x:3:3:sys:/dev:/usr/sbin/nologin
backup:x:34:34:backup:/var/backups:/usr/sbin/nologin
list:x:38:38:Mailing List Manager:/var/list:/usr/sbin/nologin
irc:x:39:39:ircd:/run/ircd:/usr/sbin/nologin
gnats:x:41:41:Gnats Bug-Reporting System (admin):/var/lib/gnats:/usr/sbin/nologin
sync:x:4:65534:sync:/bin:/bin/sync
games:x:5:60:games:/usr/games:/usr/sbin/nologin
man:x:6:12:man:/var/cache/man:/usr/sbin/nologin
nobody:x:65534:65534:nobody:/nonexistent:/usr/sbin/nologin
lp:x:7:7:lp:/var/spool/lpd:/usr/sbin/nologin
mail:x:8:8:mail:/var/mail:/usr/sbin/nologin
systemd-coredump:x:996:996:systemd Core Dumper:/:/usr/sbin/nologin
news:x:9:9:news:/var/spool/news:/usr/sbin/nologin

观察一下,它把: 作为分割符号,分为很多个字段,指定第三个字段作为排序的指标,然后升序排列。

(2).搜索数据:grep

他的使用方法很多,需要仔细研究。命令模式:

grep [options] pattern [file]

比如我们有一个文本test.txt,内容如下:

abc
def
123
456

grep a test.txt

输出:abc

grep -v a test.txt #-v表示输出不含查询的字符

def
123
456

有很多选项,可以自己查询

6.压缩文件

有很多工具可以压缩,比如bzip2,compress,gzip,zip

后缀名也各不一样,分别对应.bz2,.z,.gz,.zip

介绍一下gzip,这是GUN的一个压缩软件

(1).gzip 压缩文件

(2).gzcat 查看压缩文件的内容

(3).gunzip 解压

7.归档文件

虽然gzip可以压缩文件,但是它是对单个文件使用,我们常常需要对一系列文件使用,所以需要tar命令。

tar function [option] object1 object2 object3

功能有很多

-A 把一个归档的文件追加到另一个中

-c 创建一个新的归档文件

-d 比较两个归档文件的不同

-r 追加归档文件到末尾

-t 列出归档文件的内容

-u 更新,追加同名文件

-x 从归档文件中提取文件

选项也有很多

-C dir 切换到指定dir

-f file 输出结果到文件file

-j 重定向输出结果给bzip2来压缩文件

-p 保留文件权限

-v 处理文件的时候显示文件

-z 重定向给gzip命令来压缩文件

比如压缩三个文件a1,a2,a3

tar -cvf A.tar a1 a2 a3

把a1 a2 a3 的内容输入到创建的文件A.tar中

查看压缩文件

tar -tf A.tar

则输出a1 a2 a3

 A.tar会被重新构建

解压命令:

tar -zxvf A.tar

你可能感兴趣的:(shell,命令)