mysql bash 脚本,在bash脚本中创建mysql数据库和用户

在本文中,作者遇到了一个关于MySQL的问题:使用脚本创建数据库用户时,指定的密码并未生效。经过排查,提供了一个解决方案,即检查是否存在/root/.my.cnf文件,如果存在,则不会提示输入root密码;若不存在,则需要手动输入。这个脚本适用于MariaDB 10.0.22在Ubuntu 14.04上的环境。
摘要由CSDN通过智能技术生成

This seems like it should be simple and I swear this code has worked for months but it's not working now. I'm sure I'm just overly tired but I would appreciate a knowing nudge.

# create random password

PASSWDDB="$(openssl rand -base64 12)"

# replace "-" with "_" for database username

MAINDB=${USER_NAME//[^a-zA-Z0-9]/_}

# create database and user

mysql -e "CREATE DATABASE $MAINDB"

mysql -e "GRANT ALL PRIVILEGES ON $MAINDB.* TO $MAINDB@localhost IDENTIFIED BY '$PASSWDDB!'"

MAINDB is supplied previously in the script. What I end up with is a database, a user, and proper permissions and the user has a password - it's just not the password defined in $PASSWORDDB.

MariaDB 10.0.22

Ubuntu 14.04

解决方案

In your case you can use this:

# create random password

PASSWDDB="$(openssl rand -base64 12)"

# replace "-" with "_" for database username

MAINDB=${USER_NAME//[^a-zA-Z0-9]/_}

# If /root/.my.cnf exists then it won't ask for root password

if [ -f /root/.my.cnf ]; then

mysql -e "CREATE DATABASE ${MAINDB} /*\!40100 DEFAULT CHARACTER SET utf8 */;"

mysql -e "CREATE USER ${MAINDB}@localhost IDENTIFIED BY '${PASSWDDB}';"

mysql -e "GRANT ALL PRIVILEGES ON ${MAINDB}.* TO '${MAINDB}'@'localhost';"

mysql -e "FLUSH PRIVILEGES;"

# If /root/.my.cnf doesn't exist then it'll ask for root password

else

echo "Please enter root user MySQL password!"

echo "Note: password will be hidden when typing"

read -sp rootpasswd

mysql -uroot -p${rootpasswd} -e "CREATE DATABASE ${MAINDB} /*\!40100 DEFAULT CHARACTER SET utf8 */;"

mysql -uroot -p${rootpasswd} -e "CREATE USER ${MAINDB}@localhost IDENTIFIED BY '${PASSWDDB}';"

mysql -uroot -p${rootpasswd} -e "GRANT ALL PRIVILEGES ON ${MAINDB}.* TO '${MAINDB}'@'localhost';"

mysql -uroot -p${rootpasswd} -e "FLUSH PRIVILEGES;"

fi

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值