【问题标题】:How to execute a MySQL command using shell script from PHP page?如何使用 PHP 页面中的 shell 脚本执行 MySQL 命令?
【发布时间】:2015-02-03 09:48:44
【问题描述】:

我想从 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页面是runscript.php

<?php
    shell_exec("sudo /path/to/script/sqlscript.sh");
?>

现在,当我从 服务器控制台php 页面 runscript.php 调用 sqlscript.sh 时,它可以正常工作并按预期返回 200

但是当我在~/.my.cnf 中获取MYSQL 用户名和密码时,我根本不必将它放在命令行中:

[client]
user = root
password = XXXXXXXX

并在sudoer 中添加凭据以在没有密码的情况下执行此脚本。

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

它返回502,因为它无法执行 SQL 命令。

更新:

这里是 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)

所以,请帮我解决这个问题。

【问题讨论】:

  • 这可能是权限问题。您正在使用 web 服务器用户运行 php,并在控制台中使用不同的用户。要分析问题,您应该检查 apache 日志,并查看(也许也可以用它编辑您的问题)确切的错误消息。
  • 仍然,检查 error.log,相信我会有所帮助。
  • 这显然是权限问题。执行 PHP 脚本以及您的 bash 脚本(和 mysql)的用户不允许访问 my.cnf 文件。
  • 嗨,@VolkanUlukut 感谢您的支持。我更新了添加 Apache 错误日志的问题。但是为什么这个脚本会导致这个权限错误呢?
  • 您正在执行的命令不需要 root 权限。

标签: php mysql bash shell


【解决方案1】:

通过添加 --defaults-extra-file 选项解决。
mysql --defaults-extra-file=~/.my.cnf ...

或使用绝对路径(可能需要通过 apache,取决于服务器配置):
mysql --defaults-extra-file=/absolute/path/to/.my.cnf ...

【讨论】:

  • 感谢您的回答。我会检查并通知您。
【解决方案2】:

你试过了吗?

在你的 shell 脚本中,而不是

mysql -h "localhost" "database-name" < "/tmp/update.sql"

使用

mysql -h "localhost"-u root -ppassword "database-name" < "/tmp/update.sql"

基本上,尝试在您的 shell 脚本中传递 MySQL 用户名和密码。当然,您可以将它们放入 variables/configs/whatever 以保护它

MySQL 28000 错误表明您的脚本能够尝试以 root 身份登录,但由于没有参数密码,它失败了

【讨论】:

  • 感谢您的回答。是的,我试过了。在我的问题开始时,这种方式是有效的。但我不想直接在脚本中写密码。这就是我想要的。
  • 抱歉没有正确阅读问题。出于某种原因,我误读了原始脚本。您是否尝试将 .my.cnf 放入 www-data 主文件夹而不是用户的主文件夹?或者将 apache 用户设置为您的用户(可以说有些人不喜欢)
猜你喜欢
  • 1970-01-01
  • 2011-10-04
  • 2012-12-22
  • 2019-12-20
  • 1970-01-01
  • 2021-12-06
  • 2020-01-08
  • 1970-01-01
  • 2017-01-13
相关资源
最近更新 更多