Shell的语法学习:
常用符号代码:
-eq //等于
-ne //不等于
-gt //大于 (greater)
-lt //小于 (less)
-ge //大于等于
-le //小于等于
--Cut
cut -f1 d, --- 表示以 , 进行分割,取第一个字符
-b :以字节为单位进行分割。这些字节位置将忽略多字节字符边界,除非也指定了 -n 标志。
-c :以字符为单位进行分割。
-d :自定义分隔符,默认为制表符。
-f :与-d一起使用,指定显示哪个区域。
echo 20200112 | cut -c 7,8 --结果 12
echo 20200112 | cut -c 1-4 --结果 2020
cut 配合grep使用:
jps >> 1.txt
```bash
81429 Jps
79814 DataNode
81209 RunJar
79737 NameNode
80299 ResourceManager
80379 NodeManager
79919 SecondaryNameNode
97315 Kafka
4482 Jps
81209 RunJar
96665 ResourceManager
97080 QuorumPeerMain
84395 SecondaryNameNode
96746 NodeManager
96410 NailgunRunner
84301 DataNode
96012
2478 RunJar
84223 NameNode
查找 96746 所在行的数据,并以空格进行分割,取第二个字符。
grep 96746 1.txt | cut -d' ' -f2
1、$#
表示执行脚本传入参数的个数
2、$*
表示执行脚本传入参数的列表(不包括$0)
3、$$
表示进程的id
4、$@
表示执行脚本传入参数的所有个数(不包括$0)
5、$0
表示执行的脚本名称
6、$1
表示第一个参数
7、$@
表示第二个参数
8、$?
表示脚本执行的状态,0表示正常,其他表示错误
Sed:
refer to :https://www.cnblogs.com/ctaixw/p/5860221.html
命令的逻辑关系:
在linux 中 命令执行状态:0 为真,其他为假
逻辑与: &&
第一个条件为假时,第二条件不用再判断,最终结果已经有;
第一个条件为真时,第二条件必须得判断;
逻辑或: ||
逻辑非: !
## 常见unix/linux问题
当使用windows系统时,脚本在windows编写好之后,上传到unix/linux,会出现格式问题
使用: `cat -v filename` 可以查看格式中的问题 : ‘^M’;
解决办法:
1. 执行入下脚本:
```powershell
perl -i -pe 's/\r//g' test.sh
- 如未能完全解决 使用notepad++
将上图中的红色框的内容进行双击,换成 unix 保存上传即可!
创建一个测试文本:
vi test.sh
一. 简单Helloword
#!/bin/bash
echo "Hello World !"
执行输出 Helloword!
二.for循环
#!/bin/bash
echo "Hello World !"
#循环输出 一串数字
for var in 1 2 3 5 6
do
echo "the code is : $var"
done
#输出某个文件路径下的所有文件
dirs=$(ls /opt/moduls/)
for filename in $dirs
do
echo $filename
done
三. If条件判断
a=10
b=11
#注意空格最好是能留出来
if [ $a == $b ]
then echo "a=b"
elif [ $a -gt $b ]
then echo "$a>b"
else
echo "a<b"
fi
if [[ -z ]] 判断字符非空
if [[-S ]] 判断文件是否非空
判断文件的大小是否非0. 如果文件存在并且大小非0,则返回true
mail :
mailx [-BDdEFintv~] [-s subject] [-a attachment ] [-c cc-addr] [-b bcc-addr] [-r from-addr] [-h hops] [-A account] [-S variable[=value]] to-addr . . .
mailx [-BDdeEHiInNRv~] [-T name] [-A account] [-S variable[=value]] -f [name]
mailx [-BDdeEinNRv~] [-A account] [-S variable[=value]] [-u user]