PDO连接时,提示"unknown mysql server host"

本文解决了一个在CentOS7环境下运行项目时遇到的“SQLSTATE[HY000][2005]Unknown MySQL server host‘127.0.0.1:3306’”的错误问题。通过调整PDO连接字符串中的端口设置解决了该问题。

在 CentOS7 上运行项目,但是不断的提示报错“SQLSTATE[HY000] [2005] Unknown MySQL server host ‘127.0.0.1:3306’ (110)”,找到报错位置后,发现代码如下:

$dsn = "mysql:host=127.0.0.1:3306;dbname=test";
try {
    $pdo = new PDO($dsn, root, root); //初始化一个PDO对象,就是创建了数据库连接对象
    $pdo->exec("SET NAMES 'utf8';");
    self::$link[$rand] = $pdo;

} catch (PDOException $e) {
    if($auto_connect) {
        //省略
    }
    die ($e->getMessage() . "<br/>");
}

参考 PDO connect to localhost (unknown mysql server host) ,把第一行代码的端口修改下,就可以运行了,奇怪的是在windows下面,这样写却没有问题。

$dsn = "mysql:host=127.0.0.1;port=3306;dbname=test";
### 问题分析与解决方法 MySQL 错误 `2005 Unknown server host` 表示 MySQL 客户端无法解析提供的主机名或 IP 地址。此错误通常与 DNS 解析问题、网络配置问题或主机不可达有关。以下是对该问题的详细分析和解决方案[^1]。 #### 1. **DNS 解析问题** 如果主机名(如 `172.16.104.226`)无法通过 DNS 正确解析为 IP 地址,则会导致此错误。可以尝试以下步骤: - 确认主机名是否正确。 - 使用命令行工具(如 `ping` 或 `nslookup`)测试主机名的解析能力。 ```bash ping 172.16.104.226 nslookup 172.16.104.226 ``` - 如果主机名无法解析,尝试直接使用 IP 地址代替主机名连接数据库。 #### 2. **网络配置问题** 确保客户端和服务器之间的网络连接正常。检查以下内容: - 防火墙规则:确认防火墙未阻止 MySQL 端口(默认为 3306)。 - 路由配置:确保网络路由允许从客户端到服务器的通信。 - 子网掩码和网关设置:验证网络配置是否正确。 #### 3. **MySQL 配置问题** 检查 MySQL 服务器的配置文件(通常是 `my.cnf` 或 `my.ini`),确保以下参数正确设置: - `bind-address`:确认 MySQL 服务绑定到正确的 IP 地址。如果需要远程访问,应将 `bind-address` 设置为 `0.0.0.0` 或目标 IP 地址。 ```ini [mysqld] bind-address = 0.0.0.0 ``` - 重启 MySQL 服务以应用更改。 ```bash sudo systemctl restart mysql ``` #### 4. **客户端配置问题** 在客户端连接字符串中,确保提供了正确的主机名或 IP 地址。例如,在 Python 中使用 `peewee` 连接,可以指定如下参数: ```python from peewee import MySQLDatabase db = MySQLDatabase('database_name', user='root', password='password', host='172.16.104.226', port=3306) ``` #### 5. **其他可能原因** 如果上述方法无效,可以考虑以下因素: - **服务器无互联网访问**:根据引用信息[^2],某些服务器由于缺乏互联网访问可能导致类似问题。确认服务器是否需要特定的网络配置或代理设置。 - **超问题**:引用信息提到首次连接可能会有超问题。可以尝试增加连接间,例如在连接字符串中添加 `connect_timeout` 参数: ```python db = MySQLDatabase('database_name', user='root', password='password', host='172.16.104.226', port=3306, connect_timeout=30) ``` ### 示例代码 以下是一个完整的 Python 示例,展示如何处理连接问题并捕获异常: ```python from peewee import MySQLDatabase, OperationalError try: db = MySQLDatabase('database_name', user='root', password='password', host='172.16.104.226', port=3306, connect_timeout=30) db.connect() print("Connection successful") except OperationalError as e: print(f"Connection failed: {e}") finally: if not db.is_closed(): db.close() ``` ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值