Linux使用 -- 脚本控制
优先级控制 使用nice和renice来调整脚本优先级 避免出现不可控的死循环(导致CPU占用过高或死机) Fork炸弹123456789101112131415161718# 大部分限制对root无效[root@localhost ~]# ulimit -acore file size (blocks, -c) 0data seg size (kbytes, -d) unlimitedscheduling priority (-e) 0file size (blocks, -f) unlimitedpending signals (-i) 3795max locked memory (kbytes, -l) 64max memory size (kbytes, -m) unlimitedopen files (-n) 1024pipe size (512 bytes, -p) 8POS...
Linux使用 -- Shell
转义 + 引用 特殊字符 一个字符不仅有字面意义,还有元意(meta-meaning) 如# ; \ " ' 转义 \n \r \t \$ \" \\ 引用 ":不完全引用,解析里面的变量 ':完全引用,不做任何解析 `:运行命令 12345678[root@localhost ~]# echo "$a"[root@localhost ~]# echo "\$a"$a[root@localhost ~]# echo " abc"x"edf " abcxedf[root@localhost ~]# echo " abc\"x\"edf " abc"x"edf 12345[root@localhost ~]# var1=123[root@localhost ~]# echo "$var1"123[root@localhost ~]# echo '$var'$...
Linux使用 -- 变量
命名规则 字母、数字、下划线 不以字母开头 赋值 基本概念 Shell变量是弱类型的变量 方式 变量名=变量值 a=123,等号左右不能出现空格 使用let为变量赋值 let a=10+20,Shell是解释性语言,尽量不要进行运算 将命令赋值给变量 l=ls 将命令结果赋值给变量,使用$()或者`` letc=$(ls -l /etc) 变量值有空格等特殊字符可以包含在""或者''中 a='hello world' 1234567[root@localhost ~]# a=123[root@localhost ~]# a =123-bash: a: 未找到命令[root@localhost ~]# a = 123-bash: a: 未找到命令[root@localhost ~]# a= 123-bash: 123: 未找到命令 123[root@localhost ~]# l=ls[root@localhost ~]# $lanaconda-ks.cfg a.sh a.txt b.txt comb...
Linux使用 -- 管道 + 重定向
管道 管道是进程通信的方式 信号也是进程通信的方式,例如kill -9 pid是让进程处于某种运行状态 匿名管道(管道符|)是Shell编程经常用到的通信工具 管道符是|,将前一个命令执行的结果传递给后面的命令 ;只是隔开多条命令,顺序执行,命令之间没有任何关系 Session A1234567$ cat | tail -f | ps -fUID PID PPID C STIME TTY TIME CMDroot 2348 2344 0 16:12 pts/1 00:00:00 -bashroot 2971 2348 0 19:13 pts/1 00:00:00 catroot 2972 2348 0 19:13 pts/1 00:00:00 tail -froot 2973 2348 0 19:13 pts/1 00:00:00 ps -f cat的本质:将文本内容作为输入,与终端建立连接 管道符|给两边的外部命令分别创建了对应的子进程,对应pid为2...
Linux使用 -- 执行脚本方式
2.sh12345#!/bin/bash# demo 2.shcd /tmppwd 执行方式子进程bash ./filename.sh在当前终端下面产生一个bash子进程,bash子进程再去解释filename.sh(不需要x权限) 12345678[root@localhost ~]# ll 2.sh-rw-r--r--. 1 root root 37 10月 16 16:30 2.sh[root@localhost ~]# bash 2.sh/tmp[root@localhost ~]# pwd/root ./filename.sh同样产生一个子进程,但使用的是Sha-Bang(即#!)来解释filename.sh 12345678910[root@localhost ~]# ./2.sh-bash: ./2.sh: 权限不够[root@localhost ~]# chmod u+x 2.sh[root@localhost ~]# ./2.sh/tmp[root@localhost ~]# pwd/root 当前进程source ./filename.sh在当...
Linux使用 -- sar + iftop
sar1yum install sysstat CPU12345678910$ sar -u ALL 1 5Linux 2.6.32-696.el6.x86_64 (xxx) 2019年10月15日 _x86_64_ (40 CPU)17时25分50秒 CPU %usr %nice %sys %iowait %steal %irq %soft %guest %idle17时25分51秒 all 14.75 0.00 1.13 0.00 0.00 0.00 0.25 0.00 83.8717时25分52秒 all 11.17 0.00 1.74 0.00 0.00 0.00 0.25 0.00 86.8417时25分53秒 all 12.31 0.00 1.61 0.00 0....
Linux使用 -- ext4(inode + datablock)
基本结构 超级块 在ext4文件系统最开头的部分 记录了整个文件系统中所包含的文件的元数据,df命令读取的就是超级块中的内容,所以执行很快 超级块副本 inode 记录每个文件的大小(非实际大小,用于ls命令)、权限、编号等信息,但文件名是记录在父目录的inode中 文件的r权限,是读取文件内容;而目录的r权限,是读取目录下的文件名称 datablock 记录数据,inode和datablock是链式结构 ls统计的是inode里面的文件大小,而du统计的是文件datablock的总大小 12[root@localhost ~]# ls -li anaconda-ks.cfg33574978 -rw-------. 1 root root 1260 12月 15 19:25 anaconda-ks.cfg ext412345678910111213[root@localhost sdb1]# df -Th文件系统 类型 容量 已用 可用 已用% 挂载点devtmpfs devtmpfs 475M 0 ...
Linux使用 -- ls VS du
duestimate file space usage 非空洞文件12345678[root@localhost dd]# dd if=/dev/zero bs=4M count=10 of=afile记录了10+0 的读入记录了10+0 的写出41943040字节(42 MB)已复制,0.0569579 秒,736 MB/秒[root@localhost dd]# ls -lh afile-rw-r--r--. 1 root root 40M 12月 16 20:55 afile[root@localhost dd]# du -sh afile40M afile 空洞文件12345678[root@localhost dd]# dd if=/dev/zero bs=4M count=10 seek=20 of=bfile记录了10+0 的读入记录了10+0 的写出41943040字节(42 MB)已复制,0.0357481 秒,1.2 GB/秒[root@localhost dd]# ls -lh bfile-rw-r--r--. 1 root root 120M 12月 16 20:58...
Linux使用 -- 守护进程
nohup & VS 守护进程 nohup命令使得进程忽略hangup(挂起)信号 守护进程 不需要终端就能启动 输出会打印到特定的文件中 守护进程占用的目录是根目录 nohup &Session A1234567891011[root@localhost ~]# tail -f /var/log/messagesDec 16 06:39:44 localhost NetworkManager[758]: <info> [1576496384.0844] dhcp4 (ens33): nameserver '192.168.206.2'Dec 16 06:39:44 localhost NetworkManager[758]: <info> [1576496384.0844] dhcp4 (ens33): domain name 'localdomain'Dec 16 06:39:44 localhost NetworkManager[758]: <info> [1576496384.08...
Linux使用 -- 帮助命令
man Executable programs or shell commands System calls (functions provided by the kernel) Library calls (functions within program libraries) Special files (usually found in /dev) File formats and conventions eg /etc/passwd Games Miscellaneous (including macro packages and conventions), e.g. man(7), groff(7) System administration commands (usually only for root) Kernel routines [Non standard] 123456$ ls /usr/bin/passwd /etc/passwd/etc/passwd /usr/bin/passwd$ man 1 passwd$ man 5 passwd$ ma...














