1. 对FD 0/1/2 操作是,先复制,再操作
exec 4<&1 备份
exec 1>b.txt 输出重定向
exec 1>&- 关闭
exec 1<&4 恢复
exec 4>&- 关闭
2. while getopts :abdx:o: var #告诉getopts此脚本有-a -b -d -x -o5个选项,-x和-o后面需要跟参数
do
case $var in
a)
echo "$OPTARG"
exit
;;
b)
;;
:)
;;
?)
;;
esac
3. grep -c xxx 出现的行数
grep -w xxx 精确匹配
grep -q xxx a.txt 是否匹配到
grep -e xxx 默认grep 无此参数 。。。
grep -r xxx 默认grep 无此参数 。。。
egrep 'a|b'
grep -n
4. scp -qC -P 23
- -1: 强制scp命令使用协议ssh1
- -2: 强制scp命令使用协议ssh2
- -4: 强制scp命令只使用IPv4寻址
- -6: 强制scp命令只使用IPv6寻址
- -B: 使用批处理模式(传输过程中不询问传输口令或短语)
- -C: 允许压缩。(将-C标志传递给ssh,从而打开压缩功能)
- -p:保留原文件的修改时间,访问时间和访问权限。
- -q: 不显示传输进度条。
- -r: 递归复制整个目录。
- -v:详细方式显示输出。scp和ssh(1)会显示出整个过程的调试信息。这些信息用于调试连接,验证和配置问题。
- -c cipher: 以cipher将数据传输进行加密,这个选项将直接传递给ssh。
- -F ssh_config: 指定一个替代的ssh配置文件,此参数直接传递给ssh。
- -i identity_file: 从指定文件中读取传输时使用的密钥文件,此参数直接传递给ssh。
- -l limit: 限定用户所能使用的带宽,以Kbit/s为单位。
- -o ssh_option: 如果习惯于使用ssh_config(5)中的参数传递方式,
- -P port:注意是大写的P, port是指定数据传输用到的端口号
- -S program: 指定加密传输时所使用的程序。此程序必须能够理解ssh(1)的选项。
5. ssh
ssh blj01 bash -c " 'sh /home/asus/a.sh $a $b ' "
ssh st01 'bash -s' < /home/xavier/a.sh 1 2 传参调用