shell 标准输出重定向

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        传参调用 

原文地址:https://www.cnblogs.com/jgmor/p/11353500.html