
本文档旨在解决 phpMyAdmin 中无法显示多个服务器的问题。通过修改 config.inc.php 文件,利用循环结构配置多个服务器连接,并提供详细的配置示例,确保用户能够在登录界面选择不同的数据库服务器,从而方便地管理多个数据库实例。
配置 phpMyAdmin 以连接多个服务器
phpMyAdmin 允许您管理多个 MySQL 或 MariaDB 服务器。默认情况下,它可能只配置为连接到一个服务器。要启用服务器选择下拉列表,您需要编辑 phpMyAdmin 的配置文件 config.inc.php。
步骤 1: 找到 config.inc.php 文件
该文件的位置取决于您的 phpMyAdmin 安装方式和操作系统。常见的路径包括:
立即学习“PHP免费学习笔记(深入)”;
- /etc/phpmyadmin/config.inc.php (Debian/Ubuntu)
- /usr/local/etc/phpmyadmin/config.inc.php (FreeBSD)
- 在 phpMyAdmin 安装目录中,通常在 config/ 目录下。
步骤 2: 编辑 config.inc.php 文件
使用文本编辑器打开 config.inc.php 文件。您需要添加或修改 $cfg[‘Servers’] 数组来定义您的服务器。
配置方法:使用循环
推荐使用循环来配置多个服务器,这使得配置更加简洁和易于维护。以下是一个示例配置:
<?php
$i = 0;
$hosts = [
'172.18.0.1:3307',
'localhost'
];
foreach($hosts as $host) {
$i++;
$cfg['Servers'][$i]['host'] = $host;
$cfg['Servers'][$i]['port'] = ''; // 留空使用默认端口
$cfg['Servers'][$i]['socket'] = ''; // 留空使用默认 socket
$cfg['Servers'][$i]['connect_type'] = 'tcp';
$cfg['Servers'][$i]['extension'] = 'mysqli';
$cfg['Servers'][$i]['compress'] = FALSE;
$cfg['Servers'][$i]['controluser'] = 'pma'; // phpMyAdmin 控制用户
$cfg['Servers'][$i]['controlpass'] = 'pmapass'; // phpMyAdmin 控制用户密码
$cfg['Servers'][$i]['auth_type'] = 'cookie'; // 认证类型,可选 'cookie', 'config', 'http' 等
$cfg['Servers'][$i]['user'] = ''; // MySQL 用户名,如果 auth_type 为 'config',则必须设置
$cfg['Servers'][$i]['password'] = ''; // MySQL 密码,如果 auth_type 为 'config',则必须设置
$cfg['Servers'][$i]['only_db'] = ''; // 限制用户只能访问的数据库
$cfg['Servers'][$i]['verbose'] = 'Server ' . $i; // 服务器的显示名称
$cfg['Servers'][$i]['pmadb'] = 'phpmyadmin'; // phpMyAdmin 数据库
$cfg['Servers'][$i]['bookmarktable'] = 'pma_bookmark';
$cfg['Servers'][$i]['relation'] = 'pma_relation';
$cfg['Servers'][$i]['table_info'] = 'pma_table_info';
$cfg['Servers'][$i]['table_coords'] = 'pma_table_coords';
$cfg['Servers'][$i]['pdf_pages'] = 'pma_pdf_pages';
$cfg['Servers'][$i]['column_info'] = 'pma_column_info';
$cfg['Servers'][$i]['history'] = 'pma_history';
$cfg['Servers'][$i]['designer_coords'] = 'pma_designer_coords';
}
?>
配置项说明:
- $i: 服务器索引,必须从 1 开始。
- $hosts: 一个数组,包含了要连接的服务器地址,可以是 IP 地址或主机名,以及端口号(如果不是默认端口)。
- host: 服务器主机名或 IP 地址。
- port: MySQL 服务器端口(默认为 3306)。
- connect_type: 连接类型,通常为 tcp。
- extension: 使用的 MySQL 扩展,推荐使用 mysqli。
- auth_type: 认证类型,cookie 是最常见的选择。其他选项包括 config (直接在配置文件中设置用户名和密码), http (HTTP 认证) 等。
- user: MySQL 用户名 (如果 auth_type 设置为 config,则需要设置此项)。
- password: MySQL 密码 (如果 auth_type 设置为 config,则需要设置此项)。
- verbose: 在服务器选择下拉列表中显示的服务器名称。
步骤 3: 调整权限(如果需要)
确保 phpMyAdmin 能够读取 config.inc.php 文件。如果遇到权限问题,您可能需要更改文件的所有者或权限。
步骤 4: 重启 Web 服务器
为了使配置生效,请重启您的 Web 服务器(例如 Apache 或 Nginx)。
步骤 5: 验证配置
打开 phpMyAdmin,您应该看到一个服务器选择下拉列表,其中包含您配置的所有服务器。
注意事项:
- 安全: 如果您使用 config 作为 auth_type,请务必保护好 config.inc.php 文件,因为其中包含了数据库用户名和密码。建议使用 cookie 认证方式,并设置一个安全的 phpMyAdmin 控制用户。
- phpMyAdmin 数据库: 确保 phpMyAdmin 数据库 (pmadb) 已经创建,并且 controluser 拥有访问该数据库的权限。
- 错误排查: 如果您遇到问题,请检查 phpMyAdmin 的错误日志和 Web 服务器的错误日志,以获取更多信息。
总结:
通过修改 config.inc.php 文件,并使用循环结构配置多个服务器,您可以轻松地在 phpMyAdmin 中管理多个 MySQL 或 MariaDB 服务器。记住要关注安全性,并确保正确配置了所有必要的参数。
以上就是配置 phpMyAdmin 显示多个服务器的详细内容,更多请关注php中文网其它相关文章!