phpMyAdmin多服务器配置详解:解决登录界面不显示多个数据库连接问题

phpMyAdmin多服务器配置详解:解决登录界面不显示多个数据库连接问题

本教程旨在解决phpMyAdmin登录界面无法显示多个数据库服务器选项的问题。通过详细解析config.inc.php配置文件,我们将演示如何采用官方推荐的多主机配置方法,利用循环结构定义多个数据库连接,确保所有服务器都能在phpMyAdmin登录时正常显示并可供选择,从而提升数据库管理效率。

引言

phpmyadmin是广泛使用的mysql/mariadb数据库管理工具。在日常开发和运维中,我们常常需要管理多个数据库服务器,例如本地开发环境的数据库、docker容器中的数据库以及远程生产环境的数据库。然而,许多用户在尝试配置多个服务器时,会遇到phpmyadmin登录界面只显示一个服务器,或者配置不生效的问题。这通常是由于config.inc.php配置文件中的服务器定义方式不正确导致的。

本文将深入探讨phpMyAdmin多服务器配置的正确方法,基于官方推荐的配置模式,指导您如何有效地管理多个数据库连接。

常见配置误区与问题分析

用户在配置多个服务器时,通常会尝试手动递增$i变量来定义$cfg[‘Servers’][$i],或者将服务器配置放置在不恰当的条件语句中。例如,以下是常见的错误尝试:

// 错误的配置尝试示例if (!empty($dbname)) {    $cfg['Servers'][$i]['host'] = 'localhost';    // ... 其他配置    $i++; // 在条件块内递增,可能导致第二个服务器无法被正确识别}// 第二个服务器的配置// $i++; // 如果这里再次递增,可能导致跳过索引$cfg['Servers'][$i]['host'] = '172.18.0.1:3307';// ... 其他配置

这种配置方式的问题在于:

$i变量的生命周期和作用域:如果在条件语句或特定逻辑块中递增$i,可能导致其值在后续的全局配置中不连续或不符合预期。配置覆盖或跳过:不正确的$i管理可能导致phpMyAdmin只识别到第一个或最后一个定义的服务器,或者出现空白页面,因为配置数组的索引被错误地处理了。缺乏统一管理:当服务器数量增多时,这种手动维护的方式变得繁琐且容易出错。

正确配置多服务器的方法

phpMyAdmin官方提供了一种优雅且健壮的多主机配置方案,它通过循环遍历一个主机列表来动态生成服务器配置。这种方法确保了每个服务器都被正确地分配了独立的配置索引,并且易于扩展和维护。

立即学习“PHP免费学习笔记(深入)”;

通常,您可以在phpMyAdmin的安装目录(例如/etc/phpmyadmin/或phpmyadmin/libraries/)找到名为config.inc.php的主配置文件。请编辑此文件。

示例配置代码

以下是基于官方推荐模式的config.inc.php多服务器配置示例:

<?php/* * Generated by phpMyAdmin * all config for servers */declare(strict_types=1);// 确保服务器索引从1开始,phpMyAdmin不使用$cfg['Servers'][0]$i = 0;// 定义所有需要管理的数据库主机列表// 格式为 '主机名:端口' 或 '主机名'$hosts = [    'localhost',          // 本地MySQL服务器    '172.18.0.1:3307',    // Docker容器或其他远程MySQL服务器    // 更多服务器可以在这里添加    // 'remote.database.com:3306',];// 遍历主机列表,为每个主机配置phpMyAdmin服务器连接foreach ($hosts as $host) {    $i++; // 每次循环递增服务器索引,确保从1开始且连续    // 基本连接参数    $cfg['Servers'][$i]['host'] = $host;    $cfg['Servers'][$i]['port'] = ''; // 如果主机名已包含端口,此处留空    $cfg['Servers'][$i]['socket'] = '';    $cfg['Servers'][$i]['connect_type'] = 'tcp'; // 连接类型,通常为tcp    $cfg['Servers'][$i]['extension'] = 'mysqli'; // 推荐使用mysqli扩展    $cfg['Servers'][$i]['compress'] = false; // 是否启用压缩    // 认证方式和用户凭据    $cfg['Servers'][$i]['auth_type'] = 'cookie'; // 推荐使用cookie认证,安全性高    // 如果使用'config'认证类型,则需在此处直接指定用户和密码    // $cfg['Servers'][$i]['auth_type'] = 'config';    // $cfg['Servers'][$i]['user'] = 'your_username';    // $cfg['Servers'][$i]['password'] = 'your_password';    // 可选:为每个服务器设置一个易于识别的别名    $cfg['Servers'][$i]['verbose'] = ($host === 'localhost') ? '本地开发数据库' : 'Docker容器数据库';    // phpMyAdmin高级功能所需的控制用户和数据库    // 这些是phpMyAdmin内部用于存储书签、关系等功能的,需要一个专门的用户和数据库。    // 如果您不使用这些高级功能,可以留空或注释掉。    $cfg['Servers'][$i]['controluser'] = 'pma'; // 控制用户,需在MySQL中创建    $cfg['Servers'][$i]['controlpass'] = 'pmapass'; // 控制用户密码    // phpMyAdmin控制数据库名称    $cfg['Servers'][$i]['pmadb'] = '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]['table_uiprefs'] = 'pma__table_uiprefs';    $cfg['Servers'][$i]['tracking'] = 'pma__tracking';    $cfg['Servers'][$i]['userconfig'] = 'pma__userconfig';    $cfg['Servers'][$i]['recent'] = 'pma__recent';    $cfg['Servers'][$i]['favorite'] = 'pma__favorite';    $cfg['Servers'][$i]['users'] = 'pma__users';    $cfg['Servers'][$i]['usergroups'] = 'pma__usergroups';    $cfg['Servers'][$i]['navigationhiding'] = 'pma__navigationhiding';    $cfg['Servers'][$i]['savedsearches'] = 'pma__savedsearches';    $cfg['Servers'][$i]['central_columns'] = 'pma__central_columns';    $cfg['Servers'][$i]['designer_settings'] = 'pma__designer_settings';    $cfg['Servers'][$i]['export_templates'] = 'pma__export_templates';    // 其他可选配置    $cfg['Servers'][$i]['only_db'] = ''; // 限制此服务器只显示特定数据库    // $cfg['Servers'][$i]['AllowNoPassword'] = true; // 允许无密码登录,极不推荐在生产环境使用}

配置详解

$i = 0;: 初始化服务器索引计数器。phpMyAdmin的服务器数组$cfg[‘Servers’]从索引1开始。$hosts = […]: 定义一个包含所有数据库主机地址的数组。每个元素可以是’主机名’或’主机名:端口’的形式。foreach ($hosts as $host): 遍历$hosts数组。在每次循环中:$i++;: 递增$i,确保为每个服务器分配一个唯一的、从1开始的连续索引。$cfg[‘Servers’][$i][‘host’] = $host;: 设置当前服务器的主机地址。$cfg[‘Servers’][$i][‘port’] = ”;: 如果主机名中已包含端口(如172.18.0.1:3307),则此处留空;否则,如果端口不是默认的3306,需要在此处明确指定。$cfg[‘Servers’][$i][‘connect_type’] = ‘tcp’;: 指定连接类型,通常为TCP/IP。$cfg[‘Servers’][$i][‘extension’] = ‘mysqli’;: 推荐使用mysqli扩展以获得更好的性能和安全性。$cfg[‘Servers’][$i][‘auth_type’] = ‘cookie’;: 强烈推荐使用cookie认证。这意味着每次登录时用户都需要输入用户名和密码。config认证类型:如果您选择’config’认证(如原问题中的第二个服务器),则必须在配置中直接提供$cfg[‘Servers’][$i][‘user’]和$cfg[‘Servers’][$i][‘password’]。这种方式将凭据硬编码到配置文件中,安全性较低,尤其不适用于生产环境。$cfg[‘Servers’][$i][‘verbose’]: 为每个服务器设置一个易于识别的别名,它将显示在phpMyAdmin登录界面的下拉菜单中。$cfg[‘Servers’][$i][‘controluser’] / $cfg[‘Servers’][$i][‘controlpass’] / $cfg[‘Servers’][$i][‘pmadb’]: 这些是phpMyAdmin高级功能(如书签、关系图等)所需的配置。您需要在MySQL中创建一个名为pma(或您指定的其他名称)的用户,并授予其对phpmyadmin(或您指定的其他名称)数据库的必要权限。如果不需要这些高级功能,可以不配置。

注意事项

配置文件位置:config.inc.php通常位于phpMyAdmin的安装目录或/etc/phpmyadmin/。请确保您修改的是正确的配置文件。权限问题:确保Web服务器用户(如www-data或apache)对config.inc.php文件具有读取权限。Web服务器重启:修改config.inc.php后,有时需要重启Web服务器(如Apache或Nginx)以及PHP-FPM服务,以确保配置生效。安全性:始终优先使用cookie认证类型。避免在生产环境中使用config认证类型,因为它将数据库凭据明文存储在配置文件中。为controluser设置强密码,并限制其权限仅限于phpmyadmin控制数据库。Valet等开发环境:如果您使用Valet或其他本地开发工具,phpMyAdmin的访问地址可能会从localhost/phpmyadmin变为phpmyadmin.test等自定义域名。这不会影响多服务器的配置逻辑,但请确保您是通过正确的URL访问phpMyAdmin。端口与主机名:当主机名包含端口时(如172.18.0.1:3307),$cfg[‘Servers’][$i][‘port’]可以留空。如果主机名不包含端口,且端口不是默认的3306,则必须显式设置$cfg[‘Servers’][$i][‘port’]。

总结

通过采用上述基于foreach循环的配置方法,您可以清晰、高效地在phpMyAdmin中管理多个数据库服务器。这种方法不仅解决了登录界面不显示所有服务器的问题,还提高了配置的可读性和可维护性。遵循本教程的指导,您将能够轻松地在不同数据库环境之间切换,从而极大地提升您的数据库管理体验。

以上就是phpMyAdmin多服务器配置详解:解决登录界面不显示多个数据库连接问题的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1292854.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月11日 08:37:03
下一篇 2025年12月11日 08:37:16

相关推荐

  • 如何使用 Ant Design 实现自定义的 UI 设计?

    如何使用 Ant Design 呈现特定的 UI 设计? 一位开发者提出: 我希望使用 Ant Design 实现如下图所示的 UI。作为一个前端新手,我不知从何下手。我尝试使用 a-statistic,但没有任何效果。 为此,提出了一种解决方案: 可以使用一个图表库,例如 echarts.apac…

    2025年12月24日
    000
  • 您不需要 CSS 预处理器

    原生 css 在最近几个月/几年里取得了长足的进步。在这篇文章中,我将回顾人们使用 sass、less 和 stylus 等 css 预处理器的主要原因,并向您展示如何使用原生 css 完成这些相同的事情。 分隔文件 分离文件是人们使用预处理器的主要原因之一。尽管您已经能够将另一个文件导入到 css…

    2025年12月24日
    000
  • Antdv 如何实现类似 Echarts 图表的效果?

    如何使用 antdv 实现图示效果? 一位前端新手咨询如何使用 antdv 实现如图所示的图示: antdv 怎么实现如图所示?前端小白不知道怎么下手,尝试用了 a-statistic,但没有任何东西出来,也不知道为什么。 针对此问题,回答者提供了解决方案: 可以使用图表库 echarts 实现类似…

    2025年12月24日
    300
  • 如何使用 antdv 创建图表?

    使用 antdv 绘制如所示图表的解决方案 一位初学前端开发的开发者遇到了困难,试图使用 antdv 创建一个特定图表,却遇到了障碍。 问题: 如何使用 antdv 实现如图所示的图表?尝试了 a-statistic 组件,但没有任何效果。 解答: 虽然 a-statistic 组件不能用于创建此类…

    2025年12月24日
    200
  • 如何在 Ant Design Vue 中使用 ECharts 创建一个类似于给定图像的圆形图表?

    如何在 ant design vue 中实现圆形图表? 问题中想要实现类似于给定图像的圆形图表。这位新手尝试了 a-statistic 组件但没有任何效果。 为了实现这样的图表,可以使用 [apache echarts](https://echarts.apache.org/) 库或其他第三方图表库…

    好文分享 2025年12月24日
    100
  • React 嵌套组件中,CSS 样式会互相影响吗?

    react 嵌套组件 css 穿透影响 在 react 中,嵌套组件的 css 样式是否会相互影响,取决于采用的 css 解决方案。 传统 css 如果使用传统的 css,在嵌套组件中定义的样式可能会穿透影响到父组件。例如,在给出的代码中: 立即学习“前端免费学习笔记(深入)”; component…

    2025年12月24日
    000
  • React 嵌套组件中父组件 CSS 修饰会影响子组件样式吗?

    对嵌套组件的 CSS 修饰是否影响子组件样式 提问: 在 React 中,如果对嵌套组件 ComponentA 配置 CSS 修饰,是否会影响到其子组件 ComponentB 的样式?ComponentA 是由 HTML 元素(如 div)组成的。 回答: 立即学习“前端免费学习笔记(深入)”; 在…

    2025年12月24日
    000
  • echarts地图中点击图例后颜色变化的原因和修改方法是什么?

    图例颜色变化解析:echarts地图的可视化配置 在使用echarts地图时,点击图例会触发地图颜色的改变。然而,选项中并没有明确的配置项来指定此颜色。那么,这个颜色是如何产生的,又如何对其进行修改呢? 颜色来源:可视化映射 echarts中有一个名为可视化映射(visualmap)的对象,它负责将…

    2025年12月24日
    000
  • 在 React 项目中实现 CSS 模块

    react 中的 css 模块是一种通过自动生成唯一的类名来确定 css 范围的方法。这可以防止大型应用程序中的类名冲突并允许模块化样式。以下是在 react 项目中使用 css 模块的方法: 1. 设置 默认情况下,react 支持 css 模块。你只需要用扩展名 .module.css 命名你的…

    2025年12月24日
    000
  • 网络进化!

    Web 应用程序从静态网站到动态网页的演变是由对更具交互性、用户友好性和功能丰富的 Web 体验的需求推动的。以下是这种范式转变的概述: 1. 静态网站(1990 年代) 定义:静态网站由用 HTML 编写的固定内容组成。每个页面都是预先构建并存储在服务器上,并且向每个用户传递相同的内容。技术:HT…

    2025年12月24日
    000
  • 为什么多年的经验让我选择全栈而不是平均栈

    在全栈和平均栈开发方面工作了 6 年多,我可以告诉您,虽然这两种方法都是流行且有效的方法,但它们满足不同的需求,并且有自己的优点和缺点。这两个堆栈都可以帮助您创建 Web 应用程序,但它们的实现方式却截然不同。如果您在两者之间难以选择,我希望我在两者之间的经验能给您一些有用的见解。 在这篇文章中,我…

    2025年12月24日
    000
  • action在css中的用法

    CSS 中 action 关键字用于定义鼠标悬停或激活元素时的行为,语法:element:action { style-property: value; }。它可以应用于 :hover 和 :active 伪类,用于创建交互效果,如更改元素外观、显示隐藏元素或启动动画。 action 在 CSS 中…

    2025年12月24日
    000
  • css规则的类型有哪些

    CSS 规则包括:通用规则:选择所有元素类型选择器:根据元素类型选择元素类选择器:根据元素的 class 属性选择元素ID 选择器:根据元素的 id 属性选择元素(唯一)后代选择器:选择特定父元素内的元素子选择器:选择作为特定父元素的直接子元素的元素伪类:基于元素的状态或特性选择元素伪元素:创建元素…

    2025年12月24日
    000
  • css网页设计模板怎么用

    通过以下步骤使用 CSS 网页设计模板:选择模板并下载到本地计算机。了解模板结构,包括 index.html(内容)和 style.css(样式)。编辑 index.html 中的内容,替换占位符。在 style.css 中自定义样式,修改字体、颜色和布局。添加自定义功能,如 JavaScript …

    2025年12月24日
    000
  • 网页设计css样式代码大全,快来收藏吧!

    减少很多不必要的代码,html+css可以很方便的进行网页的排版布局。小伙伴们收藏好哦~ 一.文本设置    1、font-size: 字号参数  2、font-style: 字体格式 3、font-weight: 字体粗细 4、颜色属性 立即学习“前端免费学习笔记(深入)”; color: 参数 …

    2025年12月24日
    000
  • css中id选择器和class选择器有何不同

    之前的文章《什么是CSS语法?详细介绍使用方法及规则》中带了解CSS语法使用方法及规则。下面本篇文章来带大家了解一下CSS中的id选择器与class选择器,介绍一下它们的区别,快来一起学习吧!! id选择器和class选择器介绍 CSS中对html元素的样式进行控制是通过CSS选择器来完成的,最常用…

    2025年12月24日
    000
  • nginx的css不起作用怎么办

    nginx的css不起作用是因为误删文件导致的,其解决办法就是打开相应的文件并添加代码“include /etc/nginx/mime.types;”,然后重启Nginx守护即可。 本文操作环境:windows7系统、css3版,DELL G3电脑。 nginx的css不起作用是什么原因? 最近部署…

    2025年12月24日 好文分享
    000
  • apache不加载css文件怎么办

    apache不加载css文件的解决办法:1、删除中文字符,使用unicode代替;2、将css文件另存为utf-8格式;3、检查css路径,打开浏览器看是否报404错误;4、使用chmod 777 css文件,给文件添加读取权限。 本教程操作环境:Windows7系统、HTML5&&…

    2025年12月24日
    000
  • CSS如何实现任意角度的扇形(代码示例)

    本篇文章给大家带来的内容是关于CSS如何实现任意角度的扇形(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 扇形制作原理,底部一个纯色原形,里面2个相同颜色的半圆,可以是白色,内部半圆按一定角度变化,就可以产生出扇形效果 扇形绘制 .shanxing{ position:…

    2025年12月24日
    000
  • php约瑟夫问题如何解决

    “约瑟夫环”是一个数学的应用问题:一群猴子排成一圈,按1,2,…,n依次编号。然后从第1只开始数,数到第m只,把它踢出圈,从它后面再开始数, 再数到第m只,在把它踢出去…,如此不停的进行下去, 直到最后只剩下一只猴子为止,那只猴子就叫做大王。要求编程模拟此过程,输入m、n, 输出最后那个大王的编号。…

    好文分享 2025年12月24日
    000

发表回复

登录后才能评论
关注微信