php - mysqlnd php_network_getaddresses : getaddrinfo failed: No such host is known

标签 php mysql cluster-computing getaddrinfo mysqlnd

我遵循了本教程 http://www.clusterdb.com/mysql-cluster/creating-a-simple-cluster-on-a-single-linux-host使用从 mysql 站点下载的内容:mysql-cluster-gpl-7.3.10-linux-glibc2.5-x86_64.tar.gz

我已经在 Ubuntu 14.04LTS 机器上启动并运行了它,这意味着我可以使用每个端口上的终端登录 mysql-cluster,以确认它运行良好。当我尝试使用/etc/mysqlnd_ms_cfg.ini 连接到它时,由于上述 PHP 错误,无法从 PHP 测试脚本连接到 mysql-cluster。在网上搜索了一整天没有解决这个问题,所以非常感谢您的帮助。

运行 www.test.loc/test.php 会生成错误:

$pdo = new PDO("mysql:host=myapp;dbname=test", "root", "");
printf("[%d] %s\n", mysqli_connect_errno(), mysqli_connect_error());
$result = $pdo->query("select * from assets");
var_dump($result->fetchAll());
die();

虽然这确实有效 www.test.loc/test.php:

$pdo = new PDO("mysql:unix_socket=/tmp/my.1.sock;dbname=test", "root", "");
printf("[%d] %s\n", mysqli_connect_errno(), mysqli_connect_error());
$result = $pdo->query("select * from assets");
var_dump($result->fetchAll());
die(); 

这证实了连接到其中一个节点确实有效,因为它返回了行结果。 只是这样我们就不会使用 mysqlnd_ms_cfg.ini ,它会以循环方式将负载平衡到不同的主服务器。

如果我将/etc/mysqlnd_ms_cfg.ini 中的“myapp”键更改为其他内容,那么我还会收到另一个错误,指出 php 找不到该文件,这意味着该文件的路径是正确的。还验证了 json 格式是否有拼写错误,但根据 https://jsonformatter.curiousconcept.com/这是有效的。

设置: /etc/mysqlnd_ms_cfg.ini

{
"myapp": {
"master": {
  "master_1": {
    "host": "localhost",
    "db": "test",
    "user": "root",
    "password": "",
"port": "3306",
"socket": "\/tmp\/my.1.sock"     
  },
  "master_2": {
    "host": "127.0.0.1",
    "db": "test",
    "user": "root",
    "password": "",
"port": "3307"          
  },
  "master_3": {
    "host": "127.0.0.1",
    "db": "test",
    "user": "root",
    "password": "", 
"port": "3308"         
  }
},
"slave": {
},
"filters": {
  "roundrobin": []
},
"failover": {
  "strategy": "loop_before_master",
  "remember_failed": true
}
}
}

安装了 php5-mysqlnd:

sudo apt-get install php5-mysqlnd

将设置添加到 10-mysqlnd.ini 并重新启动 apache2:

; configuration for php MySQL module
; priority=10
extension=mysqlnd.so
mysqlnd_ms.enable=1
mysqlnd_ms.force_config_usage=1
mysqlnd_ms.config_file=/etc/mysqlnd_ms_cfg.ini
;mysqlnd_ms.ini_file=/etc/mysqlnd_ms_cfg.ini

;Disabling built-in read-write splitting.
mysqlnd_ms.disable_rw_split=1

;Configure masters only.
;mysqlnd_ms.multi_master=1

PHPINFO 输出:检查 phpinfo() 和所有有关 mysqlnd 的部分是否有含义:

  • 解析的其他 .ini 文件:/etc/php5/apache2/conf.d/10-mysqlnd.ini
  • 客户端 API 版本:mysqlnd 5.0.11-dev - 20120503
  • mysqlnd 的整个 block :版本 mysqlnd 5.0.11-dev - 20120503
  • 已加载插件:mysqlnd

我的主机文件/etc/hosts 的内容:

127.0.0.1   localhost
127.0.1.1   dev-pc
127.0.0.1   www.test.loc

# The following lines are desirable for IPv6 capable hosts
::1     ip6-localhost ip6-loopback
fe00::0 ip6-localnet
ff00::0 ip6-mcastprefix
ff02::1 ip6-allnodes
ff02::2 ip6-allrouters

最佳答案

您的问题中有很多不相关的信息。

这与集群无关。

与 PHP 无关。

与MySQL无关。

重要的部分是:

new PDO("mysql:host=myapp;dbname=test", "root", "");

$pdo = new PDO("mysql:unix_socket=/tmp/my.1.sock;dbname=test", "root", "");

mysqlnd php_network_getaddresses: getaddrinfo failed: No such host is known

127.0.0.1   localhost
127.0.1.1   dev-pc
127.0.0.1   www.test.loc

# The following lines are desirable for IPv6 capable hosts
::1     ip6-localhost ip6-loopback
fe00::0 ip6-localnet
ff00::0 ip6-mcastprefix
ff02::1 ip6-allnodes
ff02::2 ip6-allrouters

您的主机文件中没有“myapp”条目(上面第一个连接字符串中使用的主机名)。将其更改为 127.0.0.1 或您定义的除 localhost 以外的别名之一,它应该按您的预期工作(假设这不仅仅掩盖了其他地方的进一步配置问题)。

关于php - mysqlnd php_network_getaddresses : getaddrinfo failed: No such host is known,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33276502/

相关文章:

php - 数据库中的多个条目

mysql - 大表的 PostgreSQL 到 MySQL 转换

mysql - 错误查询更新mysql

hadoop - 为Java webapp内嵌的客户端设置hadoop系统用户

redis - 如何搭建一个简化的redis集群(支持数据分片、负载均衡)?

python - 在 Python 中的 Kmeans 之后确定簇的大小

php - 如何使用 php 和 html 将 csv 表导入 mysql 数据库

php - 如何使用 PHP 获取数据表

php - 检查行是否在 while 循环中分组

MySQL 查询最近 2 次尝试的平均值