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
相关推荐
M4K01 小时前
Linux百度网盘优化三板斧
linux
好奇的菜鸟1 小时前
如何在 Ubuntu 24.04 (Noble) 上使用阿里源
linux·运维·ubuntu
bcbobo21cn2 小时前
初步了解Linux etc/profile文件
linux·运维·服务器·shell·profile
望获linux2 小时前
【实时Linux实战系列】CPU 隔离与屏蔽技术
java·linux·运维·服务器·操作系统·开源软件·嵌入式软件
0wioiw02 小时前
C#基础(项目结构和编译运行)
linux·运维·服务器
2401_873587824 小时前
Linux常见指令以及权限理解
linux·运维·服务器
Arthurmoo4 小时前
Linux系统之MySQL数据库基础
linux·数据库·mysql
李洋-蛟龙腾飞公司4 小时前
HarmonyOS NEXT应用元服务常见列表操作分组吸顶场景
linux·运维·windows
链上Sniper4 小时前
智能合约状态快照技术:实现 EVM 状态的快速同步与回滚
java·大数据·linux·运维·web3·区块链·智能合约
晨曦丿5 小时前
双11服务器
linux·服务器·网络