一、实用命令
1、crontab(定时任务)
(1)基本概念
crontab 是用来管理定时任务的命令。
系统启动后,将会自动调用 crontab,如果存在任务,则根据相关定义去执行。
(2)常用场景
系统周期性执行的工作。比如:系统数据备份,定期清理缓存等。
个人定期执行的工作。比如:每隔几分钟检查邮件服务器是否存在新邮件。
(3)语法规则
【语法:】 crontab [options] crontab [options] file 【options:】 -u <user> 指定某用户的定时任务。 -e 编辑当前用户的任务,进入 vi 文字编辑器。 -l 查看当前用户的任务 -r 删除当前用户的任务 【定时任务格式:】 f1 f2 f3 f4 f5 command 说明: f1 表示分钟(0 - 59) f2 表示小时(0 - 23) f3 表示天数(1 - 31) f4 表示月数(1 - 12) f5 表示星期几(0 - 6, 0 表示 星期天,1 表示星期一...) command 表示待执行的命令 即:(通过 cat /etc/crontab 可以查看) # .---------------- minute (0 - 59) # | .------------- hour (0 - 23) # | | .---------- day of month (1 - 31) # | | | .------- month (1 - 12) OR jan,feb,mar,apr ... # | | | | .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat # | | | | | .---- command to be executed # * * * * * command 注: f1 为 * 时,表示每分钟执行。f2...f5 类似。 f1 为 a-b 时,表示从第 a 分钟到第 b 分钟时间段内,每分钟执行一次。f2...f5 类似。 f1 为 */n 时,表示每隔 n 分钟执行一次。f2...f5 类似。 f1 为 a,b,c 时,表示第 a、b、c 分钟执行一次。f2...f5 类似。
(4)相关命令
【查看 crontab:】 cat /etc/crontab 【编辑 crontab:】 crontab -e 注: 不同的用户创建的任务,最终出现在 /var/spool/cron 下,文件名为 用户名。 比如:root 用户创建的任务最终存储在 /var/spool/cron/root 文件中。 【查看 crontab:】 crontab -l cat /var/spool/cron/root # 查看 root 用户的定时任务 【删除所有 crontab:】 crontab -r 【查看、启动、重启、停止 crontab 服务:】 service crond status service crond start/stop/restart 【查看日志:】 tail -f /var/log/cron
(5)举例:
【每分钟执行一次 echo:】 * * * * * echo 11 >> /root/test/text.txt 注: 若脚本中命令不生效,将命令换成 绝对路径 试一下。 通过 which 可以查找 命令所在的 绝对路径,比如: which echo 输出为 /usr/bin/echo 替换绝对路径,比如: * * * * * /usr/bin/echo 11 >> /root/test/text.txt 【每个月 1 号、15 号 执行一次 echo:】 0 0 1,15 * * echo 11 >> /root/test/text.txt
2、sh、source、exec(执行脚本)
(1)基本概念
【sh:】 使用 sh script.sh 执行脚本时,当前 shell 是父进程,生成一个子 shell 进程,在子 shell 中执行脚本。 脚本执行完毕,退出子 shell,回到当前 shell。 ./script.sh 与 sh script.sh 等效 注: echo $$ # 输出当前 shell 的进程号 【source:】 使用 source script.sh 方式,在当前上下文中执行脚本,不会生成新的进程。 脚本执行完毕,回到当前 shell。 . script.sh(. 与 script.sh 之间有一个空格) 与 source script.sh 等效。 【exec:】 使用 exec command 方式,一般用于脚本内部,会用 command 进程替换当前 shell 进程,并且保持 PID 不变。 执行完毕,直接退出,不回到之前的 shell 环境。
(2)问题一:sh、source 区别
【sh、source 区别:】
使用 sh 和 source 方式下,脚本执行完毕,都会回到之前的 shell 中。
通过 sh 执行脚本时,修改的上下文(比如:环境变量)不会影响当前 shell。
通过 source 执行脚本时,修改的上下文(比如:环境变量)会影响当前 shell。
(3)问题二:修改 PATH 变量,不重启使其生效
【修改 PATH 变量,不重启使其生效:】 Step1: 在 /etc/profile 文件末尾追加 PATH 设置。 比如: echo 'export MAVEN_HOME=/usr/local/maven/apache-maven-3.6.1' >> /etc/profile echo 'export PATH=$MAVEN_HOME/bin:$PATH' >> /etc/profile Step2: 执行 source /etc/profile 使其生效
(4)问题三:在脚本中执行 source /etc/profile 不生效
【在脚本中执行 source /etc/profile 不生效:】 方式一: 可以直接使用 source 脚本名 直接去调用,不需要在脚本中写 source /etc/profile 方式二: 在脚本执行 source /etc/profile 后,追加 exec 语句。 通过 exec bash -l 或者 exec /bin/bash -l 或者 exec $SHELL -l 去打开一个新进程。 注: exec 会导致 exec 之后的语句不执行,exec 一般放于脚本末尾。
3、jq(json 解析工具)
(1)基本概念
jq 是一款在使用命令行处理 JSON 数据的工具,可用于处理 标准输入、管道、文件 传递的 JSON 数据,经过一系列 过滤器、表达式 后,提取成需要的数据 并输出到 标准输出中。
(2)相关地址
jq 官网地址: https://stedolan.github.io/jq/
jq 文档: https://github.com/stedolan/jq/wiki
jq 文档: https://stedolan.github.io/jq/manual/
(3)安装
【centos:】 yum install -y epel-release yum install -y jq 【其余方式参考官网提供方式:】 https://stedolan.github.io/jq/download/
(4)语法规则
【语法:】 jq [options] <jq filter> [file...] 【options: 】 -c 紧凑输出(默认为 树形结构,紧凑输出将树形结构转为一行输出) -r 输出原始字符串,不在结果上加双引号 -R 读取原始字符串,在结果上加上双引号 -C 字符串着色 -M 字符串不着色 --tab 使用 tab 替换缩进符 -s 将结果使用数组保存 --arg a v 将变量 $a 设置为值 v 注: 对于待解析的数据,其所有的属性名必须是以双引号包括的字符串,否则可能会解析失败。 数据不存在时,返回 null 。 【jq filter -- 基本规则: 】 jq 根据语法规则解析 jq filter,并将其应用在 JSON 数据上,从而解析出想要的结果。 . 是最基本的过滤器。仅用 . 作为过滤器时,表示对整个 JSON 数据的引用,结果是格式化输出 JSON 数据。 '' 单引号可以不使用,但是若组合了多个过滤器,需要使用单引号包裹。 "" 双引号用于包裹特殊字符。比如: ."key$" 或者 .["key$"] , 用于输出多个过滤器结果。比如: .key1,.key2 表示过滤 key1 key2 的数据 | jq filter 支持串行化操作,一个复杂的 filter 可以由多个简单的 filter 通过 管道符 "|" 连接组成,每个 filter 均以 前一个 filter 的结果作为输入数据进行处理。 .. 递归输出每个值。 [] 将结果构造为一个数组,比如: '[.key1,.key2]' {} 将结果构造为一个对象,比如: '{"result": .key1}'。 比如: {"key1":{"key11":"value11","key12":"value12"}}, 可以通过 '.key1 | .key11' 去解析 key11 的值。 echo '{"key1":{"key11":"value11","key12":"value12"}}' | jq '.key1 | .key11' 【jq filter -- 对象操作: 】 jq 使用类似于 '.key' 的方式过滤 JSON 对象,当数据不存在时,返回 null。 过滤单个对象: '.key1' 等价于 .'["key1"]' 过滤多个对象 '.key1, .key2' 等价于 .'["key1", "key2"]' 过滤对象的对象: '.key1.key2' 等价于 '.key1 | .key2' 【jq filter -- 数组操作: 】 jq 使用类似于 '.[index]' 的方式过滤 JSON 数组。 过滤单个数组元素: '.[index]' index 从 0 开始,正序输出,若为负数,反序输出(0 表示第一个元素, -1 表示最后一个元素)。 过滤多个数组元素: '.[index, index2]' 过滤所有数组元素: '.[]' 过滤数组某个范围的数据: '.[startIndex:endIndex]' 包含 startIndex ,但不包含 endIndex
(5)举例(简单)
【vi test.json 编辑 json 数据】 { "key1": "value1", "key2": "value2" } 【cat test.json | jq 格式化输出数据】 { "key1": "value1", "key2": "value2" } 【cat test.json | jq -c 输出紧凑的数据】 {"key1":"value1","key2":"value2"} 【cat test.json | jq -R 输出结果会加上双引号】 "{" " "key1": "value1", "key2": "value2"" "}" 【cat test.json | jq -s 结果使用数组形式保存】 [ { "key1": "value1", "key2": "value2" } ] 【cat test.json | jq --arg name jarry '{name: $name}' 将变量 $a 设置为值 v】 { "name": "jarry" }
(6)举例(解析对象 Object)
【vi test.json 编辑 json 数据】 { "key1": { "key11": "value11", "key12": "value12" }, "key2": "value2" } 【cat test.json | jq .key1 获取 key1 对应的 value】 { "key11": "value11", "key12": "value12" } 【cat test.json | jq .'["key1"]' 获取 key1 对应的 value】 { "key11": "value11", "key12": "value12" } 【cat test.json | jq .key1,.key2 获取 key1,key2 对应的 value】 { "key11": "value11", "key12": "value12" } "value2" 【cat test.json | jq .'["key1", "key2"]' 获取 key1,key2 对应的 value】 { "key11": "value11", "key12": "value12" } "value2" 【cat test.json | jq .[] 获取所有的 value】 { "key11": "value11", "key12": "value12" } "value2" 【cat test.json | jq .key1.key11 获取 key11 对应的 value】 "value11" 【cat test.json | jq -r .key1.key11 获取 key11 对应的 value】 value11 【cat test.json | jq keys 获取所有 key 组成的数组】 [ "key1", "key2" ] 【cat test.json | jq [.[]] 获取所有的 value 组成的数组】 [ { "key11": "value11", "key12": "value12" }, "value2" ]
(7)举例(解析数组 Array)
【vi test.json 编辑 json 数据】 [ { "key1": ["value1"], "key2": "value2" }, ["value3", "value4"] ] 【cat test.json | jq .[] 获取数组所有的元素】 { "key1": [ "value1" ], "key2": "value2" } [ "value3", "value4" ] 【cat test.json | jq .[0] 获取数组的第一个元素】 { "key1": [ "value1" ], "key2": "value2" } 【cat test.json | jq .[1] 获取数组的第二个元素】 [ "value3", "value4" ] 【cat test.json | jq .[0:2] 获取数组 第一个元素 到 第三个元素】 [ { "key1": [ "value1" ], "key2": "value2" }, [ "value3", "value4" ] ] 【cat test.json | jq .[0].key1 获取 Object 对象的 value 值】 [ "value1" ] 【cat test.json | jq '.[0] | .key1' 获取 Object 对象的 value 值】 [ "value1" ] 【cat test.json | jq .[0].key1,.[0].key2】 [ "value1" ] "value2" 【cat test.json | jq .[1][0] 获取 数组元素 】 "value3" 【cat test.json | jq '.[1] | .[0]'】 "value3" 【cat test.json | jq [.[0].key2]】 [ "value2" ] 【cat test.json | jq [.[1][0]]】 [ "value3" ]
4、logrotate(管理日志文件)
(1)基本概念
logrotate 是 Linux 上的一个日志文件管理工具。 可以删除 旧的日志文件,并创建新的日志文件。这个过程可以称为 “日志轮替”。 可以根据 日志文件的大小、以及 日志文件 的存放天数 来进行处理。一般通过 cron 程序来执行。 crontab 会每天执行一次 /etc/cron.daily 目录下的脚本,该目录下存在一个 /etc/cron.daily/logrotate 文件,内部执行 logrotate 命令。 若 logrotate 配置在其他目录下,比如: /etc/cron.daily/,/etc/cron.weekly/,/etc/cron.monthly/,/etc/cron.hourly/,则可能 每天、每周、每月、每小时 执行一次。 一般情况下,logrotate 每天由 crontab 执行一次,可以手动执行 logrotate 命令(-f 强制执行),或者 自定义定时任务。
(2)语法规则
【语法:】 logrotate [options] <configfile> 【options:】 -d, --debug 显示指令执行过程,不进行实际操作 -v, --verbose 显示指令执行过程,进行实际操作 -f, --force 强制执行 -s, --state=statefile 指定日志更新状态,形如:"/var/log/yum.log" 2021-4-1-10:54:26 【logrotate 基本格式:】 日志文件路径 + {} 组成,{} 内部每行表示一个规则。 若配置多个文件,文件名独立成行。 *.log { rule1 rule2 ... } xxx.log xxx.log2 { rule1 rule2 ... } 【logrotate 基本规则参数:】 compress 使用 gzip 压缩日志文件。 nocompress 不压缩日志文件。 copytruncate 先复制日志文件,再清空。复制与清空之间存在时间差,可能丢失部分日志数据。 create mode owner group 创建空文件,并指定权限、用户名、组名。比如: create 0600 root root。 nocreate 不创建新的空文件。 daily 指定 日志轮替 周期为 每天。 weekly 指定 日志轮替 周期为 每周。 monthly 指定 日志轮替 周期为 每月。 delaycompress 延迟压缩过程到 下一次 进行 日志轮替 时进行。与 compress 配合使用,即当前日志文件 需要等待下一次 日志轮替 时才进行 压缩。 ifempty 即使日志文件为空,也进行 日志轮替。 notifempty 日志文件为空,则不作 日志轮替。 missingok 如果日志文件不存在,仍可以继续处理,不会出错。 nomissingok 如果日志文件不存在,则会出错(显示出错信息)。 noolddir 日志存储在同一个目录下。 olddir [目录名] 指定日志存储目录。 rotate [数量] 指定日志文件备份数量。执行一次日志轮替,就生成一次备份文件,超过后,备份文件内容将清空,若未配置,则直接修改原文件。 size [大小] 当日志文件超过指定的文件大小时进行日志轮替,默认单位为 byte,可以为 K、M、G,比如: size 10M sharedscripts 对多个日志文件 执行 postrotate 或者 prerotate 命令。 dateext 使文件以日期为后缀。默认为 xxx.log.1,xxx.log.2 等,以日期结尾,比如:xx.log.2020-04-20 dateformat -%Y%m%d%H.%s 配合 dateext 使用,改变日期后缀的格式。 prerotate~endscript 预操作,在执行 日志轮替前 先执行 prerotate~endscript 之间的命令。 postrotate~endscript 后操作,在执行 日志轮替后 执行 postrotate~endscript 之间的命令。
(3)相关文件
【cat /etc/cron.daily/logrotate】 #!/bin/sh /usr/sbin/logrotate -s /var/lib/logrotate/logrotate.status /etc/logrotate.conf EXITVALUE=$? if [ $EXITVALUE != 0 ]; then /usr/bin/logger -t logrotate "ALERT exited abnormally with [$EXITVALUE]" fi exit 0 【cat /etc/logrotate.conf】 # see "man logrotate" for details 通过 man logrotate 指令可以查看 logrotate 详情 # rotate log files weekly 每周进行一次 日志轮替 weekly # keep 4 weeks worth of backlogs 保留最近 4 周的日志 rotate 4 # create new (empty) log files after rotating old ones 创建一个空的新文件 在 日志轮替 老文件后 create # use date as a suffix of the rotated file 使文件以日期为后缀 dateext # uncomment this if you want your log files compressed compress 表示压缩日志文件 #compress # RPM packages drop log rotation information into this directory 存放 rpm 安装的软件的日志轮替规则,自定义日志轮替 include /etc/logrotate.d # no packages own wtmp and btmp -- we'll rotate them here 配置 wtmp、btmp 日志轮替规则 /var/log/wtmp { monthly create 0664 root utmp minsize 1M rotate 1 } /var/log/btmp { missingok monthly create 0600 root utmp rotate 1 } # system-specific logs may be also be configured here 可以在此处配置系统日志轮替规则
(4)配置 logrotate 的方式
【方式一:】 直接在 /etc/logrotate.conf 文件中进行配置。 一般用于配置非 rpm 安装的软件的系统文件。 【方式二:】 在 /etc/logrotate.d 文件夹下 新建一个配置文件。 一般 rpm 安装的软件 会自动生成一个配置文件。比如:/etc/logrotate.d/yum 【cat /etc/logrotate.d/yum】 /var/log/yum.log { missingok notifempty maxsize 30k yearly create 0600 root root }
5、sed(修改文本)
(1)基本概念
【基本概念:】 sed 是一个过滤和转换文本的流编辑器(非交互式)。 用于处理 文件 或者 管道符 传递的文本数据,可以对数据行进行替换、删除、新增、选取等特定工作,简化对文件的反复操作。 默认情况下,sed 逐行处理 输入数据,会将修改结果输出,不会修改源文件。 【处理流程:】 1、将正在处理的行 保存在一个临时缓存区(模式空间)中. 2、处理临时缓存区中的数据,将结果输出。处理完一行,就将其从临时缓存区删除。 3、重复 1-2 部署,直至数据处理完成。
(2)语法规则
【语法:】 sed [options] 'command' fileName1 [fileName2] # sed 命令格式 sed [options] -f scriptFile fileName(s) # sed 脚本模式(根据 scriptFile 中的 sed 命令对 fileName 表示的文件进行操作) 【options:】 -i 直接修改源文件内容,不输出。 -e 默认选项,不修改源文件(可以进行重定向覆盖源文件)。 -n 禁止默认输出行为(输出所有内容),仅显示模糊匹配的行,不修改源文件。 【command:】 command 定义如何处理文件,默认处理所有行。可以通过 数字、字符、正则表达式 组合形式过滤文件。 【command -- 数字(从 1 开始,1 表示第一行):】 单个数字表示第几行 $ 表示最后一行 使用 , 连接,表示 第几行 到 第几行 使用 ~ 连接,表示从 第几行 开始,每隔 几行 取一行 比如: 2 表示第 2 行。 $ 表示最后一行。 2,4 表示第 2 行 到 第 4 行。 2~3 表示从第 2 行开始,每隔 3 行取一行。 2,+4 表示从第 2 行到 第 2+4 行。 【command -- 字符:】 a 表示在当前行后面插入一行 或 多行。追加多行时,除最后一行,每行需要以 结尾(表示换行)。 i 表示在当前行之前插入一行 或 多行。追加多行时,除最后一行,每行需要以 结尾(表示换行)。 c 表示使用新文本替换当前行。追加多行时,除最后一行,每行需要以 结尾(表示换行)。 d 表示删除选择的行。 h 把模式空间里的内容复制到暂存缓冲区. H 把模式空间里的内容追加到暂存缓冲区 g 把暂存缓冲区里的内容复制到模式空间,覆盖原有的内容 G 把暂存缓冲区的内容追加到模式空间里,追加在原有内容的后面 x 交换暂存缓冲区 与 模式空间的内容。 n 读取下一个输入行到模式空间。 N 追加下一个输入行到模式空间。 p 显示每行的内容,若与 options 中的 -n 使用时,可以仅输出 选定的 内容。 P 仅显示第一行。 q 结束 sed 操作 ! 非,表示对非选中行进行操作。 = 输出当前行号。 【command -- 正则表达式:】 s/regexp/replacement/ 根据 regexp 匹配到指定字符串,然后使用 replacement 进行替换。 /regexp/ regexp: ^ 行首定位符,匹配 xx 开头的行。 /^xx/ $ 行位定位符,匹配 xx 结尾的行. /xx$/ . 匹配单个字符(除换行符外)。 /x..x/ * 匹配 0个 或 多个 字符(不能用于首字母)。 /x*x/ [] 匹配指定字符组的任一个字符。 /[Xx]xx/ [^] 匹配不在指定字符组内的任一字符。 /[^Xx]xx/ (..) 匹配拆分子串,下标从 1 开始,在替换字符串中使用 1、2 对其进行引用。 s/(love)able/1rs -> lovers & 保存查找串,在替换字符串中使用 & 进行引用。 s/my/**&**/ -> **my** < 词首定位符,匹配 xx 开头的词。 /<xx/ > 词尾定位符,匹配 xx 结尾的词。 /xx>/ x{m} 匹配重复 x 行 m 次的行。 /x{5}/ x{m,} 匹配重复 x 行至少 m 次的行。 /x{5,}/ x{m,n} 匹配重复 x 行至少 m 次,但是少于 n 次的行。 /x{5,10}/
(3)举例(数字)
【vi test.txt】 java javascript python c++ go 【sed -n '2p' test.txt 仅输出 test.txt 第二行内容】 javascript 【sed -n '3,$p' test.txt 输出第 3 行 到最后一行的内容】 python c++ go 【sed -n '2,+2p' test.txt 输出第 2 行开始,到第 4 行(2+2=4)的内容】 javascript python c++ 【sed -n '2~3p' test.txt 输出从第 2 行开始,每隔 3 行的内容】 javascript go
(4)举例(字符)
【vi test.txt】 java javascript python c++ go 【sed -e '2ahello' test.txt 在 第二行 与 第三行 之间 插入新的一行 hello。此时 hello 作为新的第三行单独存在】 java javascript hello python c++ go 【sed -e '3chelloworld' test.txt 使用 helloworld 替换 第三行】 java javascript helloworld python c++ go 【sed -e '3iworld' test.txt 在 第三行 之前插入 新的一行 world】 java javascript world helloworld python c++ go 【sed -e '3,4d' test.txt 删除第三行、第四行】 java javascript python c++ go
(5)举例(正则表达式)
【vi test.txt】 java javascript python c++ go 【sed -n '/^java/p' test.txt 输出所有以 java 开头的行】 java javascript 【sed -n '/.*va/p' test.txt 输出包含 va 的行,若写成 /*va/ 的形式,可能匹配不到数据】 java javascript 【sed -n '/<ja/p' test.txt 输出包含 ja 开头的词的行】 java javascript 【sed -n '/>++/p' test.txt 输出包含 ++ 结尾的词的行】 c++ 【sed -e 's/c++/c--/' test.txt 替换 c++ 为 c--】 java javascript python c-- go 【sed -e 's/(c)(++)/1--/' test.txt 替换字符串,1 用于替代 (c),最终效果为 c++ -> c--】 java javascript python c-- go 【sed -e 's/c++/--&&--/' test.txt & 用于替代查找串,此处 & 等同于 c++】 java javascript python --c++c++-- go
二、网络相关
1、netstat(显示网络状态)
(1)基本概念
netstat 命令用于显示网络状态。
通过 netstat 可以知道整个 Linux 系统的网络情况。
(2)语法规则
【语法:】 netstat [options] 【options:】 -a, --all 显示所有的网络状态(包括 监听、非监听的 Socket) -l, --listening 只显示正在监听的 Socket -c, --continuous 持续的列出网络状态 -C, --cache 显示路由缓冲中的路由信息 -e, --extend 显示网络其他相关信息 -F, --fib 显示路由缓冲信息 -n, --numeric 显示 ip 地址而不是去解析域名获取 主机、端口或用户名。 -o, --timers 显示与网络定时器有关的信息。 -p, --program 显示 Socket 所属进程的 PID 和名称。 -t, --tcp 显示 TCP 传输协议的连线状况。 -u, --udp 显示 UDP 传输协议的连线状况。 -i, --interfaces 显示网络界面信息表单(网卡信息)。
(3)举例
【显示网卡相关信息:】 netstat -i 【显示 tcp 连接情况:】 netstat -nltp
2、telnet(连接远程机器,确认机器端口是否开放)
(1)基本概念
telnet 命令用于使用 TELNET 协议与另一个主机进行交互通信。
可以对另一主机进行远程登录、管理操作(有些 linux 服务器不支持 telnet,使用 ssh)。
可以通过 telnet 来确认远程主机的某个端口是否开放。也是日常网络故障排错的重要一部分。
(2)安装
【centos7: 】 yum -y install telnet-server yum -y install telnet
(3)语法规则
【语法:】
telnet [options] [ip] [port]
【options:】
此处省略,通过 man telnet 可以查看语法规则。
(4)举例
【连接远程主机:】 telnet 192.168.210.157 【确认远程主机上某个端口是否可用:】 telnet 192.168.210.157 8080 注: 输出中出现 "Escape character is '^]'" 即表示端口开放。
3、nslookup(查询域名服务器)
(1)基本概念
nslookup 是一个查询 Intelnet 域名服务器的程序。有两种模式: 交互式、非交互式。
交互模式允许 用户查询名称服务器 以获取有关 各种主机 和 域的信息 或 输出域中的主机列表。
非交互模式仅用于输出主机 或 域的名称 等信息。
(2)语法规则
【语法:】 nslookup [options] domain [DNS-Server] 【options:】 此处省略,通过 man nslookup 可以查看语法规则。
(3)举例:
【查询百度域名情况:】 nslookup www.baidu.com Server: 192.168.157.2 Address: 192.168.157.2#53 Non-authoritative answer: www.baidu.com canonical name = www.a.shifen.com. Name: www.a.shifen.com Address: 14.215.177.38 Name: www.a.shifen.com Address: 14.215.177.39 【指定域名服务器进行查询:】 nslookup www.baidu.com 8.8.8.8 Server: 8.8.8.8 Address: 8.8.8.8#53 Non-authoritative answer: www.baidu.com canonical name = www.a.shifen.com. Name: www.a.shifen.com Address: 14.215.177.38 Name: www.a.shifen.com Address: 14.215.177.39 【反向 DNS 解析:】 nslookup -ty=ptr 8.8.8.8 Server: 127.0.0.53 Address: 127.0.0.53#53 Non-authoritative answer: 8.8.8.8.in-addr.arpa name = dns.google. Authoritative answers can be found from:
三、系统内存、磁盘相关
1、free(显示内存使用情况)
(1)基本概念
显示机器内存使用情况(包括已用和未用的内存空间)。
显示 系统中 已用和未用的 物理内存和交换内存, 共享内存和 内核使用的 缓冲区的 总和。
(2)语法规则
【语法:】 free [options] 【options:】 -b, --bytes 以 B 为单位显示内存 -k, --kilo 以 KB 为单位显示内存(默认) -m, --mega 以 MB 为单位显示内存 -g, --giga 以 GB 为单位显示内存 -h, --human 优化输出,数据显示带单位 -t, --total 额外增加一个 total 行,显示总和 -s N, --seconds N 每隔 N 秒输出一次 -c N, --count N 输出 N 次后退出
(3)举例
【free -h】 total used free shared buff/cache available Mem: 1.8G 763M 256M 20M 799M 852M Swap: 2.0G 776K 2.0G 【free -h -s 2 -c 3】 total used free shared buff/cache available Mem: 1.8G 762M 257M 20M 799M 853M Swap: 2.0G 776K 2.0G total used free shared buff/cache available Mem: 1.8G 762M 257M 20M 799M 853M Swap: 2.0G 776K 2.0G total used free shared buff/cache available Mem: 1.8G 762M 257M 20M 799M 853M Swap: 2.0G 776K 2.0G
2、df(显示磁盘使用情况)
(1)基本概念
显示目前在 Linux 系统上的文件系统磁盘使用情况统计。
(2)语法规则
【语法:】 df [options] [file] 【options:】 -a, --all 列出所有的文件系统 -h,--huma-readable 以易读的方式列出,带单位 -H, --si 与 -h 类似,但是计数单位为 1000,不是 1024 -T, --print-type 输出每个文件的类型 --type=TYPE 只显示指定类型的文件系统 --exclude-type=TYPE 只显示指定类型以外的文件系统
(3)举例
【df -Th】 文件系统 类型 容量 已用 可用 已用% 挂载点 devtmpfs devtmpfs 894M 0 894M 0% /dev tmpfs tmpfs 910M 0 910M 0% /dev/shm tmpfs tmpfs 910M 19M 892M 3% /run tmpfs tmpfs 910M 0 910M 0% /sys/fs/cgroup /dev/mapper/centos-root xfs 17G 13G 4.2G 76% / /dev/sda1 xfs 1014M 184M 831M 19% /boot tmpfs tmpfs 182M 12K 182M 1% /run/user/42 tmpfs tmpfs 182M 0 182M 0% /run/user/0 【df --exclude-type=xfs -hT】 文件系统 类型 容量 已用 可用 已用% 挂载点 devtmpfs devtmpfs 894M 0 894M 0% /dev tmpfs tmpfs 910M 0 910M 0% /dev/shm tmpfs tmpfs 910M 19M 892M 3% /run tmpfs tmpfs 910M 0 910M 0% /sys/fs/cgroup tmpfs tmpfs 182M 12K 182M 1% /run/user/42 tmpfs tmpfs 182M 0 182M 0% /run/user/0
3、du(显示文件占用磁盘空间)
(1)基本概念
显示指定的目录或文件所占用的磁盘空间。
默认为当前目录。
(2)语法规则
【语法:】 du [options] [file] 【options:】 -a, --all 显示对所有文件的统计,而不只是包含子目录。 -b, --bytes 输出以字节为单位的大小,替代缺省时1024字节的计数单位。 -c, --total 在处理完所有参数后给出所有这些参数的总计。即用于统计指定的一组文件或目录使用的空间的总和。 -h, --human-readable 以易读的方式输出,带单位 -s或--summarize 只显示指定目录占用磁盘空间的总和(不与 a 连用)。
(3)举例
【ls -lh】 总用量 11M drwxr-xr-x. 9 root root 220 3月 19 2021 apache-tomcat-9.0.44 -rw-r--r--. 1 root root 11M 3月 19 2021 apache-tomcat-9.0.44.tar.gz 【du -shc *】 17M apache-tomcat-9.0.44 11M apache-tomcat-9.0.44.tar.gz 28M 总用量
4、mount(挂载文件系统)
(1)基本概念
用于挂载文件系统。
(2)语法规则
【语法:】 mount [-lhV] mount -a [-frvw] [-t vfstype] [-O optlist] mount [-frvw] [-o option[,option]...] device|dir mount [-frvw] [-t vfstype] [-o options] device dir 【options:】 -a, --all 挂载 /etc/fstab 中的定义的所有文件系统 -t, --types <列表> 限制文件系统类型集合 -T, --fstab <路径> /etc/fstab 的替代文件 -v, --verbose 打印当前进行的操作 -o, --options <列表> 挂载选项列表,以英文逗号分隔 -f, --fake 模拟 mount 动作,并未真正执行,通常与 -v 连用 -r, --read-only 以只读方式挂载文件系统(同 -o ro) -w, --rw, --read-write 以读写方式挂载文件系统(默认)
(3)举例
【挂载类型为 cifs 的目录】 mount -t cifs --verbose -o vers=3.0,sec=ntlmsspi,cred=/home/ec2-user/creds.txt,rsize=130048,wsize=130048,cache=none //172.24.14.0/share /mnt/fsx 【挂载 /etc/fstab 定义的文件系统】 mount -a 【cat /etc/fstab】 /dev/mapper/centos-root / xfs defaults 0 0 UUID=2a32db5c-0484-4f80-b574-74fd01ff36e0 /boot xfs defaults 0 0 /dev/mapper/centos-swap swap swap defaults 0 0
四、其他命令
1、nohup(后台运行程序)
(1)基本概念
nohup 即 no hang up(不挂起),即使关闭连接终端也不会终止程序的运行。
默认情况下,会在当前目录下生成一个名为 nohup.out 的文件。
(2)语法规则
【语法规则:】 nohup Command [ & ] 注: Command 为要执行的命令 & 表示命令在后台执行,终端退出后命令仍旧执行。 nohup 与 & 连用,可以让程序在后台执行,且退出用户终端也不会停止。
(3)举例
【后台启动 helloworld.jar 】 nohup java -jar helloworld.jar & 【要杀死进程:】 ps -aux | grep "helloworld" # 先找到后台进程 kill -9 PID # 再根据进程号杀死进程
2、wget(网络文件下载工具)
(1)基本概念
wget 是一款非交互式的网络文件下载工具。
(2)安装
【centos7:】
yum install -y wget
(3)语法规则
【语法:】 wget [options] [url] 【options:】 -r, --recursive 递归下载 -q, --quiet 安静下载,无信息输出 -v, --verbose 输出详细信息(默认) 注: 通过 wget --help 可以查看详细描述,此处省略
(4)举例
【获取 git 数据】
wget https://awscli.amazonaws.com/awscli-exe-linux-x86_64.zip
3、curl(发送请求、下载文件)
(1)基本概念
curl 一般用于向服务器发送请求,默认发送 Get 请求。
当与 -o 或 -O 参数连用时,可以用于下载文件。
(2)安装
【centos7:】
yum install -y curl
(3)语法规则
【语法:】 curl [options] [url] 【options:】 -b xxx 向服务器发送 cookie 数据 -c xxx 将服务器返回的 cookie 数据写入本地文件 -d xxx 发送 POST 的数据体,可以省略 -X POST -o xxx 将服务器回应保存为文件,功能等同于 wget -O 无需指定文件名,默认使用 URL 最后部分作为文件名 注: 通过 man curl 或者 curl --help 可以查看详细描述,此处省略
(4)举例
【向服务器发送 cookie 数据】 curl -b 'foo1=bar;foo2=bar2' https://www.baidu.com/ curl -b cookies.txt https://www.baidu.com/ 【将服务器返回的 cookie 数据写入文件】 curl -c cookies.txt https://www.baidu.com/ 【向服务器发送 POST 数据体】 curl -d'login=emma&password=123'-X POST https://baidu.com 【将回应数据保存在 test 中】 curl "https://awscli.amazonaws.com/awscli-exe-linux-x86_64.zip" -o "awscliv2.zip" 【默认文件名为 blog.git】 curl -O "https://awscli.amazonaws.com/awscli-exe-linux-x86_64.zip"
五、设置开机自动启动脚本(CentOS7)
1、方式一:crontab 定时任务
crontab 开机自启动,通过 crontab 执行命令,可以间接的实现 开机自启动脚本。
crontab 用法见 https://www.cnblogs.com/l-y-h/p/15379861.html#_label0_0
2、方式二:修改脚本 (/etc/rc.local、/etc/rc.d/rc.local)
(1)基本认识
/etc/rc.local 是 /etc/rc.d/rc.local 的软连接,linux 机器重启的时候会去加载 这个文件。
将待执行的命令 写入 /etc/rc.d/rc.local 文件中,并给其可执行权限(默认没有执行权限)。
chomd +x /etc/rc.d/rc.local
重启机器后会加载 /etc/rc.d/rc.local 中的命令。
(2)cat /etc/rc.d/rc.local
#!/bin/bash # THIS FILE IS ADDED FOR COMPATIBILITY PURPOSES # # It is highly advisable to create own systemd services or udev rules # to run scripts during boot instead of using this file. # # In contrast to previous versions due to parallel execution during boot # this script will NOT be run after all other services. # # Please note that you must run 'chmod +x /etc/rc.d/rc.local' to ensure # that this script will be executed during boot. touch /var/lock/subsys/local
3、方式三:注册系统服务(chkconfig)
(1)基本认识
【linux 系统启动级别:】 级别有0-6共7个级别。 运行级别0:系统关机状态,默认级别不能设为 0,否则不能正常启动(一启动就关机)。 运行级别1:单用户工作状态,用于系统维护、找回 root 密码等,禁止远程登录,只能在当前计算机上操作。 运行级别2:多用户状态(无网络服务)。 运行级别3:多用户状态(有网络服务)。 运行级别4:作为保留级别,未使用。 运行级别5:图形界面状态。 运行级别6:系统重启状态,默认级别不能设为 6,否则不能正常启动(一启动就重启)。 【chkconfig:】 chkconfig 用于更新和查询系统服务的运行级别信息。 chkconfig 提供了一个简单的命令行工具,用于维护 /etc/rc[0-6].d 目录层次结构,免除了系统管理员直接操作这些系统中大量符号链接的任务目录。 chkconfig 不是立即自动禁止或激活一个服务,它只是简单的改变了符号连接。
(2)语法规则
【语法:】 chkconfig [--list] [--type <type>] [name] chkconfig --add <name> chkconfig --del <name> chkconfig --override <name> chkconfig [--level <levels>] [--type <type>] <name> <on|off|reset|resetpriorities> 【参数说明:】 -–add 增加所指定的系统服务,让 chkconfig 指令得以管理它,并同时在系统启动的叙述文件内增加相关数据。 -–del 删除所指定的系统服务,不再由 chkconfig 指令管理,并同时在系统启动的叙述文件内删除相关数据。 -–level 指定系统级别(0-6),表示服务在哪个级别启动、关闭。 --list 列出服务信息。 【on、off、reset 说明:】 如果在服务名后面指定了 on,off 或者 reset,那么 chkconfig 会改变指定服务的启动信息。 on 和 off 分别指服务被启动和停止,reset 指重置服务的启动信息。 对于 on 和 off,系统默认只对运行级 2,3,4,5 有效。reset 对所有级别均有效。
(3)如何新增一个服务
【步骤:】 Step1:服务脚本必须存放在/etc/init.d/目录下。编辑脚本。 Step2:使用 chkconfig --add 添加服务。 注: 假设服务名为myservice, 当我们运行添加服务的命令时候,会出现 "service myservice does not support chkconfig"。 一般在脚本开头加入 "#chkconfig: 2345 10 90" 即可: 其中: 2345 是系统启动级别,10是启动优先级,90是停止优先级,优先级范围是0-100,数字越大,优先级越低。 执行 --add 后,会在 /etc/rc[0-6].d 中创建软链接。
(4)举例:
【chkconfig --list】 netconsole 0:关 1:关 2:关 3:关 4:关 5:关 6:关 network 0:关 1:关 2:开 3:开 4:开 5:开 6:关 【vi /etc/init.d/autoStartUp.sh】 #!/bin/bash # chkconfig: 2345 20 90 # description: autoStartUp 【chkconfig --add /etc/init.d/autoStartUp.sh】 【ls -lh /etc/rc0.d/ /etc/rc2.d/】 /etc/rc0.d/: 总用量 0 lrwxrwxrwx. 1 root root 20 10月 8 21:42 K50netconsole -> ../init.d/netconsole lrwxrwxrwx. 1 root root 24 10月 11 22:11 K90autoStartUp.sh -> ../init.d/autoStartUp.sh lrwxrwxrwx. 1 root root 17 10月 8 21:42 K90network -> ../init.d/network /etc/rc2.d/: 总用量 0 lrwxrwxrwx. 1 root root 20 10月 8 21:42 K50netconsole -> ../init.d/netconsole lrwxrwxrwx. 1 root root 17 10月 8 21:42 S10network -> ../init.d/network lrwxrwxrwx. 1 root root 24 10月 11 22:11 S20autoStartUp.sh -> ../init.d/autoStartUp.sh 【chkconfig --list】 autoStartUp.sh 0:关 1:关 2:开 3:开 4:开 5:开 6:关 netconsole 0:关 1:关 2:关 3:关 4:关 5:关 6:关 network 0:关 1:关 2:开 3:开 4:开 5:开 6:关 【chkconfig --del /etc/init.d/autoStartUp.sh】 netconsole 0:关 1:关 2:关 3:关 4:关 5:关 6:关 network 0:关 1:关 2:开 3:开 4:开 5:开 6:关
4、方式四:注册系统服务(systemctl )
(1)基本认识
【systemd 与 systemctl】 systemctl 是 CentOS7 采用的 用于 Linux 启动处理和系统管理的机制,可以理解为 systemd 的管理工具。 systemd 是 CentOS7 完成引导程序进入操作系统后启动的第一个进程。可用于管理 服务 的启动顺序。 chkconfig 是 CentOS6 使用的。 【linux 启动流程】 在电源打开时启动 BIOS 从 BIOS 调用引导加载程序 引导加载程序引导 Linux 内核 Linux 内核启动 init 进程 (PID 1) Systemd 是 init 进程。
(2)语法规则
【语法:】 systemctl [OPTIONS...] [COMMAND] 【options:】 list-unit-files 列出所有可用单元 list-units 列出所有运行中的单元 list-unit-files --type=service 列出指定类型的单元 enable、disable 开启、禁用 服务 status/start/restart/stop 查看、启动、重启、关闭 服务 daemon-reload 重新加载 systemd 管理器配置 【常用命令:】 systemctl list-unit-files systemctl list-units systemctl list-unit-files --type=mount systemctl enable/disable xxx systemctl status/start/restart/stop xxx systemctl daemon-reload
(3)如何新增一个服务
【步骤:】 Step1:服务脚本必须存放在 /etc/systemd/system 目录下。 Step2:创建后缀名为[.service]的文件,并进行编辑。 Step3:使用 systemctl daemon-reload 重新加载 systemd 管理器配置。 注意: xx.service 有具体格式写法,不能乱写。 【xx.service 文件格式说明:】 [Unit] Description: 描述Unit的说明和依赖关系等 Before:此服务启动于右侧配置的组件之前 After:此服务启动于右侧配置的组件之后 [Service] Type: 服务过程启动完成的判定方法(默认为simple) PIDFile: 主进程PID文件 KillSignal: Systemctl stop命令发送哪个信号 TimeoutStopSec: 在停止结束前待机的时间 ExecStart: 服务的启动命令 ExexReload: 服务的重载命令 ExecStop: 服务的停止命令 ExecStartPre: 服务启动前的附加命令 ExecStartPost: 服务启动后的附加命令 ExecStopPost: 服务停止后执行的命令 Restart: 服务进程停止时的重启条件 PrivateTmp: 是否准备 /tmp 和 /var/tmp 专用于这个服务 KillMode: 如何使用未停止的进程 [Install] WantedBy: 启用时在此单元的 .wants 目录中创建链接 Requiredby: 启用时在此单元的 .required 目录中创建链接 【注意:(获取环境变量)】 systemd 的执行时不会加载用户 Shell 里的环境变量,如果需要从环境变量中取值,需要 service 中配置 Environment。 Environment= EnvironmentFile= 【注意:(Type=forking)】 Type 指定了在 ExecStart 中指定的命令启动服务进程时如何判断启动完成。 例如: 对于在 foie gras 中继续运行的命令, 使用 Type = simple, 表示执行命令时,判断启动完成。 或者: fork子进程并把它放在后台,如果第一个命令本身就是结束的类型, 设置 Type = forking, 在这种情况下,当执行的命令完成时,判断启动完成。
(4)举例
【vi /etc/systemd/system/test.service】 [Unit] Description=Test Service Server After=network.target remote-fs.target nss-lookup.target [Service] Type=simple PIDFile=/run/nginx.pid ExecStartPre=/usr/bin/rm -f /run/nginx.pid ExecStart=/usr/sbin/nginx ExecReload=/bin/kill -s HUP $MAINPID KillSignal=SIGQUIT TimeoutStopSec=5 Restart=always WorkingDirectory=/usr/local/test ExecStart=/usr/local/test/test.sh KillMode=process [Install] WantedBy=multi-user.target 【systemctl daemon-reload】 【systemctl list-unit-files | grep test】 test.service disabled