我想从PHP页面执行一个shell脚本,它将执行一个MySQL命令.
要做到这一点,我按照这里显示的方式:https://stackoverflow.com/a/8055745/2117868
这是我的sqlscript.sh
#!/bin/sh
sudo wget -t 50 -O /tmp/update.sql http://example.com/update.sql
if [ $? -eq 0 ]; then
MysqL -h "localhost" -u "root" "-pXXXXXXXX" "database-name" < "/tmp/update.sql"
if [ $? -eq 0 ]; then
sudo rm /tmp/update.sql
echo "200"
else
echo "502"
fi
else
echo "404"
fi
<?PHP
shell_exec("sudo /path/to/script/sqlscript.sh");
?>
现在,当我从服务器控制台或PHP页面runcript.PHP调用sqlscript.sh时,它完美地运行并按预期返回200.
但是当我在〜/ .my.cnf中使用MysqL用户和密码时,我根本不需要把它放在命令行上:
[client]
user = root
password = XXXXXXXX
User_Alias WWW_USER = www-data
Cmnd_Alias WWW_COMMANDS_sql = /path/to/script/sqlscript.sh
WWW_USER ALL = (ALL) nopASSWD: WWW_COMMANDS_sql
这是我的sqlscript.sh
#!/bin/sh
sudo wget -t 50 -O /tmp/update.sql http://example.com/update.sql
if [ $? -eq 0 ]; then
MysqL -h "localhost" "database-name" < "/tmp/update.sql"
if [ $? -eq 0 ]; then
sudo rm /tmp/update.sql
echo "200"
else
echo "502"
fi
else
echo "404"
fi
现在,当我从服务器控制台调用sqlscript.sh时,它可以正常工作并按预期返回200.但是如果我从PHP页面调用它
http://example.com/runscript.PHP
更新:
这是Apache error.log
--2014-12-05 10:51:55-- http://example.com/update.sql
Resolving example.com (example.com)... 162.144.71.XXX
Connecting to example.com (example.com)|162.144.71.XXX|:80... connected.
HTTP request sent, awaiting response... 200 OK
Length: 146 [text/x-sql]
Saving to: `/tmp/update.sql'
0K 100% 10.9M=0s
2014-12-05 10:51:55 (10.9 MB/s) - `/tmp/update.sql' saved [146/146]
ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO)
所以,请帮我解决这个问题.
解决方法:
通过添加–defaults-extra-file选项解决.@H_404_71@MysqL –defaults-extra-file =〜/ .my.cnf …
或者使用绝对路径(可能需要通过apache,取决于服务器配置):
MysqL –defaults-extra-file = / absolute / path / to / .my.cnf …
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。