shell 接收长参数

以备份 mysql 脚本为例,如下

bash 复制代码
#!/bin/bash
# 分隔符
str="-"

# 定义分割线函数
FenGeLine() {
	## 获取屏幕宽度
	ScreenLen=$(stty size |awk '{print $2}')

	## 标题宽度
	TitleLen=$(echo -n $1 |wc -c)
	#echo $TitleLen
	## 左右分割线长度
	LineLen=$(((${ScreenLen} - ${TitleLen})/2))        # 一半长度,标题居中。

    if [ ${LineLen} -gt 0 ];then
        #echo $LineLen
	    # 打印分割线
	    yes ${str} |sed ''''${LineLen}'''q' |tr -d "\n" && echo -n $1 && yes ${str} |sed ''''${LineLen}'''q' |tr -d "\n" && echo
    else
        echo "$1"
    fi

}

# 定义短选项和长选项
SHORT_OPTS="h"
LONG_OPTS="help,host:,user:,port:,password:,db:,backfile:,"

# 解析命令行选项
PARSED_OPTS=$(getopt -o $SHORT_OPTS -l $LONG_OPTS -- "$@")
if [[ $? -ne 0 ]]; then
  exit 1
fi

# 将解析结果设置为位置参数
eval set -- "$PARSED_OPTS"



# 处理选项
while true; do
  case "$1" in
    -h|--help)
      echo "Usage: $0 [options]"
      echo "  -h, --help      Show help"
      echo "  --host connect mysql ip address"
      echo "  --user connect mysql user"
      echo "  --port connect mysql port"
      echo "  --password connect mysql password"
      echo "  --db backup mysql database"
      echo "  --backfile backup file"
      shift
      exit 0
      ;;
    --host)
      host="$2"
      shift 2
      ;;
    --user)
      user="$2"
      shift 2
      ;;
    --port)
      port="$2"
      shift 2
      ;;
    --password)
      password="$2"
      shift 2
      ;;
    --db)
      db="$2"
      shift 2
      ;;
    --backfile)
      backfile="$2"
      shift 2
      ;;
    --)
      shift
      break
      ;;
    *)
      echo "Invalid option: $1"
      exit 1
      ;;
  esac
done
host=${host:-localhost}
user=${user:-root}
port=${port:-3306}
password=${password:-123456}
backfile=${backfile:-/opt/mysql-${db}.sql}

FenGeLine "host 默认值为 localhost"
FenGeLine "user 默认值为 root"

FenGeLine "port 默认值为 3306"
FenGeLine "password 默认值为 123456"
FenGeLine "backfile 默认值为 /opt/mysql${db}.sql}"

FenGeLine "传入的 host 为 $host"
FenGeLine "传入的 user 为 $user"
FenGeLine "传入的 port 为 $port"
FenGeLine "传入的 password 为 $password"
FenGeLine "传入的 db 为 $db"
FenGeLine "传入的 backfile 为 $backfile"

if [ -z "$db" ];then
mysqldump  -h$host -u$user -P$port -p$password -A > $backfile
else
mysqldump  -h$host -u$user -P$port -p$password -B $db > $backfile
fi
相关推荐
白书宇1 小时前
13.100ASK_T113-PRO RTC实验
linux·arm开发·驱动开发·嵌入式硬件·物联网·硬件工程
qzWsong1 小时前
hadoop+wsl 10.255.255.254,BlockMissingException: Could not obtain block: 踩坑
linux·hadoop
清风~徐~来2 小时前
【Linux】指令 + 压缩与解压
linux·运维·服务器
学Linux的语莫2 小时前
配置Nginx实现用IP测试灰度发,通过不同用户ID测试灰度发布
linux·运维·服务器·nginx
BlackPercy2 小时前
【ubuntu】Geogebra
java·linux·运维·ubuntu
ichdream2 小时前
【Linux内核深度解析】TCP协议栈之tcp_recvmsg
linux·网络·后端·网络协议·tcp/ip·软件工程
luciferau3 小时前
evbuffer
linux·服务器·网络·c++
x-cmd3 小时前
[241115] Debian 12.8 发布 | Mistral AI 推出批量 API,成本降低 50%
linux·人工智能·windows·安全·ai·debian·mistral
致奋斗的我们3 小时前
RHCE的学习(22)
linux·服务器·学习·shell·redhat·rhce·rhcsa