2

我正在尝试通过 shell 脚本在 Ubuntu Natty 上安装 MySQL。但是,我一直遇到一个主要问题:当我尝试在 shell 脚本之外定义密码时。

下面是我的 shell 脚本的代码(我保存在 /etc/init.d/install_mysql 中:

export DEBIAN_FRONTEND=noninteractive
echo mysql-server-5.1 mysql-server/root_password password $dbpass | debconf-set-selections
echo mysql-server-5.1 mysql-server/root_password_again password $dbpass | debconf-set-selections
apt-get -y install mysql-server

所以我在终端输入的是:

dbpass="mysqlpass"
chmod +x /etc/init.d/install_mysql
/etc/init.d/install_mysql

MySQL 安装,但它没有密码安装,所以我可以做一些类似mysql -uroot访问 mysql 的事情(我不想要)。

有趣的是,如果我将密码作为常规文本放入 shell 脚本中,它就可以正常工作。因此,如果我的安装脚本如下,一切正常(即我必须指定密码才能访问 mysql):

export DEBIAN_FRONTEND=noninteractive
echo mysql-server-5.1 mysql-server/root_password password mysqlpass | debconf-set-selections
echo mysql-server-5.1 mysql-server/root_password_again password mysqlpass | debconf-set-selections
apt-get -y install mysql-server

有没有办法可以使用 shell 脚本变量在 shell 脚本中定义我的密码,而不是按字面输入密码?!

提前致谢。

编辑:

我刚刚将变量声明编辑$dbpass="mysqlpass"dbpass="mysqlpass". 这是一个错字。

4

2 回答 2

1
$dbpass="mysqlpass"

是的,这是几种错误。变量名不以 开头$,除非导出,否则变量不会传递到子进程的环境中。

dbpass="mysqlpass"
export dbpass

请注意,环境变量被视为共享数据的安全机制;您可能希望重新编写脚本以从标准输入读取密码,这样会更安全一些。

于 2011-11-15T15:22:04.327 回答
0
$dbpass="mysqlpass"

应该

dbpass="mysqlpass"

正如你所写, $dbpass 将被评估,并且没有被定义,所以作为一个空变量出来,归结为

="mysqlpass"

好吧,因为这是一个错字,所以这里是答案:

MySQL 寻找 envvar MYSQL_PWDhttp ://dev.mysql.com/doc/refman/5.0/en/environment-variables.html

于 2011-11-15T15:22:34.040 回答