Как настроить phpMyAdmin для доступа к нескольким серверам?

Что такое способ Ubuntu для настройки phpMyAdmin, чтобы я мог использовать его для администрирования нескольких серверов MySQL? Параметры базы данных установлены в /etc/dbconfig-common/phpmyadmin.conf, но там есть только место для параметров подключения для одного сервера. Я мог бы взломать его на /etc/phpmyadmin/config-db.php и /etc/phpmyadmin/config.inc.php, но я предполагаю, что должен быть более элегантный способ.

13
задан 4 January 2011 в 13:43

60 ответов

В этом уроке объясняется, как вы можете управлять несколькими серверами MySQL из одной установки phpMyAdmin. По соображениям безопасности связь между phpMyAdmin и любым удаленным сервером MySQL использует SSL-шифрование

0
ответ дан 4 August 2018 в 20:09

Я предположил следующее:

  • / etc / phpmyadmin / было бы самым логичным местом для добавления config
  • /etc/phpmyadmin/config-db.php - это местоположение для конфигурации по умолчанию (local?). Это потому, что он по умолчанию, один db только
  • /etc/phpmyadmin/config.inc.php читает базу данных по умолчанию, поэтому она имеет один. По крайней мере, этот используется, поэтому у вас есть база данных. Если что-то меняется в вашей конфигурации, изменяется config-db.php , поэтому «локальные» изменения в вашем файле не изменяются

Поэтому мой вывод заключался в том, что добавив дополнительный сервер под этой частью:

  / * Настроить в соответствии с dbconfig-common, если включено * / if (! empty ($ dbname)) {// чтение из config-db.php}  // $ i ++ было сделано уже, если выше // Добавление дополнительных серверов $ cfg ['Servers'] [$ i] ['host'] = 'serverhost.host.tld';  $ cfg ['Servers'] [$ i] ['extension'] = 'mysqli';  //...etc  

Это выглядит как лучшее место.

2
ответ дан 4 August 2018 в 20:09

Основной файл конфигурации хранится в /etc/phpmyadmin/config.inc.php . Этот файл включает в себя [!] D23

  • Blowfish секрет от /var/lib/phpmyadmin/blowfish_secret.inc.php
  • Сформирован конфигурации из PhpMyAdmin установки скрипта ( метод diegueus9 в) /var/lib/phpmyadmin/config.inc.php
  • [D21] значения из БД /etc/phpmyadmin/config-db.php , который генерируются из /etc/dbconfig-common/phpmyadmin.conf с помощью / usr / sbin / dbconfig-generate-include . [D6] /etc/dbconfig-common/phpmyadmin.conf может быть изменен с помощью DPKG-перенастроить -plow PHPMyAdmin
  • Дополнительные файлы конфигурации из / и т.д. /phpmyadmin/conf.d/*.php

Некоторые примеры фрагментов конфигурации находятся в / usr / share / doc / phpmyadmin / examples , включая config.manyhosts.inc.php . Этот файл можно добавить в /etc/phpmyadmin/conf.d . Он работает путем сброса переменной i назад до 1 перед созданием любых хостов, чтобы он переопределял набор узлов в /etc/phpmyadmin/config.inc.php .

Если вы хотите сделать более сложную конфигурацию, вы, вероятно, захотите изменить файл /etc/phpmyadmin/config.inc.php и, возможно, добавить другие расширения конфигурации, используя / etc / phpmyadmin / conf.d .

Чтобы добавить поддержку дополнительных конфигураций в более старые файлы конфигурации, вы можете создать каталог /etc/phpmyadmin/conf.d а затем добавьте ниже код PHP в конец /etc/phpmyadmin/config.inc.php :

  / * Поддержка дополнительных конфигураций * / foreach (glob (  '/etc/phpmyadmin/conf.d/*.php') в качестве $ filename) {include ($ filename);  }  
1
ответ дан 4 August 2018 в 20:09

Довольно старый вопрос, но все еще актуальный для поисков.

phpMyAdmin использует простой PHP для файлов конфигурации, а массив $ cfg ['Servers'] - для получения настроенных серверов .

Таким образом, правильный способ заключается в добавлении нового файла конфигурации в /etc/phpmyadmin/conf.d для каждого сервера, который вы хотите добавить. Это необходимо только для завершения имени файлов в .php , чтобы включить их, но рекомендуется использовать your_new_server.inc.php для согласованности.

Минимальным содержимым для данного файла конфигурации будет:

  $ cfg ['Servers'] [2] ['host'] = 'THE_HOST';  $ cfg ['Servers'] [2] ['user'] = 'THE_USER';  $ cfg ['Servers'] [2] ['password'] = 'THE_PASSWORD';   

Как указано выше, вы можете проверить /usr/share/doc/phpmyadmin/examples/config.manyhosts.inc.php для получения дополнительных параметров.

Важно: вам нужно увеличить индекс (2) массива для каждого нового файла и не использовать 1, если вы хотите продолжать подключение к localhost.

Если парень (и), который пакет phpMyAdmin подумал об этом, они могли бы добавить добавочную переменную $ i в foreach, которая включает файлы из каталога conf.d , поэтому вы можете просто использовать ее как индекс, и не беспокоиться о необходимости его увеличения вручную, но, к сожалению, это не так. Вы можете сделать это сами, хотя.

6
ответ дан 4 August 2018 в 20:09

Я думаю, что это самый точный способ сделать это:

Сначала установите пароль:

  sudo htpasswd -c /etc/phpmyadmin/htpasswd.setup admin   

Затем отключите защиту:

  sudo pma-configure  

Затем перейдите к http: // yourserver / phpmyadmin / setup (здесь браузеры запрашивают auth, пользователь - admin, а пароль - это то, что вы пишете в первой команде), когда этот мастер, который вы настраиваете на своих серверах, когда-то завершен, снова установите защиту:

  sudo pma-secure  
4
ответ дан 4 August 2018 в 20:09

Согласно документации phpMyAdmin , вы можете определить несколько серверов в массиве $ cfg ['Servers'] , определенном в config.inc.php .

1
ответ дан 4 August 2018 в 20:09

В этом уроке объясняется, как вы можете управлять несколькими серверами MySQL из одной установки phpMyAdmin. По соображениям безопасности связь между phpMyAdmin и любым удаленным сервером MySQL использует SSL-шифрование

0
ответ дан 6 August 2018 в 04:11

Я предположил следующее:

  • / etc / phpmyadmin / было бы самым логичным местом для добавления config
  • /etc/phpmyadmin/config-db.php - это местоположение для конфигурации по умолчанию (local?). Это потому, что он по умолчанию, один db только
  • /etc/phpmyadmin/config.inc.php читает базу данных по умолчанию, поэтому она имеет один. По крайней мере, этот используется, поэтому у вас есть база данных. Если что-то меняется в вашей конфигурации, изменяется config-db.php , поэтому «локальные» изменения в вашем файле не изменяются

Поэтому мой вывод заключался в том, что добавив дополнительный сервер под этой частью:

  / * Настроить в соответствии с dbconfig-common, если включено * / if (! empty ($ dbname)) {// чтение из config-db.php}  // $ i ++ было сделано уже, если выше // Добавление дополнительных серверов $ cfg ['Servers'] [$ i] ['host'] = 'serverhost.host.tld';  $ cfg ['Servers'] [$ i] ['extension'] = 'mysqli';  //...etc  

Это выглядит как лучшее место.

2
ответ дан 6 August 2018 в 04:11

Основной файл конфигурации хранится в /etc/phpmyadmin/config.inc.php . Этот файл включает в себя [!] D23

  • Blowfish секрет от /var/lib/phpmyadmin/blowfish_secret.inc.php
  • Сформирован конфигурации из PhpMyAdmin установки скрипта ( метод diegueus9 в) /var/lib/phpmyadmin/config.inc.php
  • [D21] значения из БД /etc/phpmyadmin/config-db.php , который генерируются из /etc/dbconfig-common/phpmyadmin.conf с помощью / usr / sbin / dbconfig-generate-include . [D6] /etc/dbconfig-common/phpmyadmin.conf может быть изменен с помощью DPKG-перенастроить -plow PHPMyAdmin
  • Дополнительные файлы конфигурации из / и т.д. /phpmyadmin/conf.d/*.php

Некоторые примеры фрагментов конфигурации находятся в / usr / share / doc / phpmyadmin / examples , включая config.manyhosts.inc.php . Этот файл можно добавить в /etc/phpmyadmin/conf.d . Он работает путем сброса переменной i назад до 1 перед созданием любых хостов, чтобы он переопределял набор узлов в /etc/phpmyadmin/config.inc.php .

Если вы хотите сделать более сложную конфигурацию, вы, вероятно, захотите изменить файл /etc/phpmyadmin/config.inc.php и, возможно, добавить другие расширения конфигурации, используя / etc / phpmyadmin / conf.d .

Чтобы добавить поддержку дополнительных конфигураций в более старые файлы конфигурации, вы можете создать каталог /etc/phpmyadmin/conf.d а затем добавьте ниже код PHP в конец /etc/phpmyadmin/config.inc.php :

  / * Поддержка дополнительных конфигураций * / foreach (glob (  '/etc/phpmyadmin/conf.d/*.php') в качестве $ filename) {include ($ filename);  }  
1
ответ дан 6 August 2018 в 04:11

Довольно старый вопрос, но все еще актуальный для поисков.

phpMyAdmin использует простой PHP для файлов конфигурации, а массив $ cfg ['Servers'] - для получения настроенных серверов .

Таким образом, правильный способ заключается в добавлении нового файла конфигурации в /etc/phpmyadmin/conf.d для каждого сервера, который вы хотите добавить. Это необходимо только для завершения имени файлов в .php , чтобы включить их, но рекомендуется использовать your_new_server.inc.php для согласованности.

Минимальным содержимым для данного файла конфигурации будет:

  $ cfg ['Servers'] [2] ['host'] = 'THE_HOST';  $ cfg ['Servers'] [2] ['user'] = 'THE_USER';  $ cfg ['Servers'] [2] ['password'] = 'THE_PASSWORD';   

Как указано выше, вы можете проверить /usr/share/doc/phpmyadmin/examples/config.manyhosts.inc.php для получения дополнительных параметров.

Важно: вам нужно увеличить индекс (2) массива для каждого нового файла и не использовать 1, если вы хотите продолжать подключение к localhost.

Если парень (и), который пакет phpMyAdmin подумал об этом, они могли бы добавить добавочную переменную $ i в foreach, которая включает файлы из каталога conf.d , поэтому вы можете просто использовать ее как индекс, и не беспокоиться о необходимости его увеличения вручную, но, к сожалению, это не так. Вы можете сделать это сами, хотя.

6
ответ дан 6 August 2018 в 04:11

Я думаю, что это самый точный способ сделать это:

Сначала установите пароль:

  sudo htpasswd -c /etc/phpmyadmin/htpasswd.setup admin   

Затем отключите защиту:

  sudo pma-configure  

Затем перейдите к http: // yourserver / phpmyadmin / setup (здесь браузеры запрашивают auth, пользователь - admin, а пароль - это то, что вы пишете в первой команде), когда этот мастер, который вы настраиваете на своих серверах, когда-то завершен, снова установите защиту:

  sudo pma-secure  
4
ответ дан 6 August 2018 в 04:11

Согласно документации phpMyAdmin , вы можете определить несколько серверов в массиве $ cfg ['Servers'] , определенном в config.inc.php .

1
ответ дан 6 August 2018 в 04:11

В этом уроке объясняется, как вы можете управлять несколькими серверами MySQL из одной установки phpMyAdmin. По соображениям безопасности связь между phpMyAdmin и любым удаленным сервером MySQL использует SSL-шифрование

0
ответ дан 7 August 2018 в 22:10

Я предположил следующее:

  • / etc / phpmyadmin / было бы самым логичным местом для добавления config
  • /etc/phpmyadmin/config-db.php - это местоположение для конфигурации по умолчанию (local?). Это потому, что он по умолчанию, один db только
  • /etc/phpmyadmin/config.inc.php читает базу данных по умолчанию, поэтому она имеет один. По крайней мере, этот используется, поэтому у вас есть база данных. Если что-то меняется в вашей конфигурации, изменяется config-db.php , поэтому «локальные» изменения в вашем файле не изменяются

Поэтому мой вывод заключался в том, что добавив дополнительный сервер под этой частью:

  / * Настроить в соответствии с dbconfig-common, если включено * / if (! empty ($ dbname)) {// чтение из config-db.php}  // $ i ++ было сделано уже, если выше // Добавление дополнительных серверов $ cfg ['Servers'] [$ i] ['host'] = 'serverhost.host.tld';  $ cfg ['Servers'] [$ i] ['extension'] = 'mysqli';  //...etc  

Это выглядит как лучшее место.

2
ответ дан 7 August 2018 в 22:10

Основной файл конфигурации хранится в /etc/phpmyadmin/config.inc.php . Этот файл содержит секрет

  • Blowfish из /var/lib/phpmyadmin/blowfish_secret.inc.php
  • Сгенерированная конфигурация из сценария установки phpMyAdmin ( метод diegueus9) /var/lib/phpmyadmin/config.inc.php
  • Значения DB из /etc/phpmyadmin/config-db.php , которые генерируются из /etc/dbconfig-common/phpmyadmin.conf с помощью / usr / sbin / dbconfig-generate-include . /etc/dbconfig-common/phpmyadmin.conf можно изменить с помощью dpkg-reconfigure -plow phpmyadmin
  • Дополнительные файлы конфигурации из / etc /phpmyadmin/conf.d/*.php

Некоторые примеры фрагментов конфигурации находятся в / usr / share / doc / phpmyadmin / examples , включая config.manyhosts.inc.php . Этот файл можно добавить в /etc/phpmyadmin/conf.d . Он работает путем сброса переменной i назад до 1 перед созданием любых хостов, чтобы он переопределял набор узлов в /etc/phpmyadmin/config.inc.php .

Если вы хотите сделать более сложную конфигурацию, вы, вероятно, захотите изменить файл /etc/phpmyadmin/config.inc.php и, возможно, добавить другие расширения конфигурации, используя / etc / phpmyadmin / conf.d .

Чтобы добавить поддержку дополнительных конфигураций в более старые файлы конфигурации, вы можете создать каталог /etc/phpmyadmin/conf.d а затем добавьте ниже код PHP в конец /etc/phpmyadmin/config.inc.php :

  / * Поддержка дополнительных конфигураций * / foreach (glob (  '/etc/phpmyadmin/conf.d/*.php') в качестве $ filename) {include ($ filename);  }  
1
ответ дан 7 August 2018 в 22:10

Согласно документации phpMyAdmin , вы можете определить несколько серверов в массиве $ cfg ['Servers'] , определенном в config.inc.php .

1
ответ дан 7 August 2018 в 22:10

Я думаю, что это самый точный способ сделать это:

Сначала установите пароль:

  sudo htpasswd -c /etc/phpmyadmin/htpasswd.setup admin   

Затем отключите защиту:

  sudo pma-configure  

Затем перейдите к http: // yourserver / phpmyadmin / setup (здесь браузеры запрашивают auth, пользователь - admin, а пароль - это то, что вы пишете в первой команде), когда этот мастер, который вы настраиваете на своих серверах, когда-то завершен, снова установите защиту:

  sudo pma-secure  
4
ответ дан 7 August 2018 в 22:10

Довольно старый вопрос, но все еще актуальный для поисков.

phpMyAdmin использует простой PHP для файлов конфигурации, а массив $ cfg ['Servers'] - для получения настроенных серверов .

Таким образом, правильный способ заключается в добавлении нового файла конфигурации в /etc/phpmyadmin/conf.d для каждого сервера, который вы хотите добавить. Это необходимо только для завершения имени файлов в .php , чтобы включить их, но рекомендуется использовать your_new_server.inc.php для согласованности.

Минимальным содержимым для данного файла конфигурации будет:

  $ cfg ['Servers'] [2] ['host'] = 'THE_HOST';  $ cfg ['Servers'] [2] ['user'] = 'THE_USER';  $ cfg ['Servers'] [2] ['password'] = 'THE_PASSWORD';   

Как указано выше, вы можете проверить /usr/share/doc/phpmyadmin/examples/config.manyhosts.inc.php для получения дополнительных параметров.

Важно: вам нужно увеличить индекс (2) массива для каждого нового файла и не использовать 1, если вы хотите продолжать подключение к localhost.

Если парень (и), который пакет phpMyAdmin подумал об этом, они могли бы добавить добавочную переменную $ i в foreach, которая включает файлы из каталога conf.d , поэтому вы можете просто использовать ее как индекс, и не беспокоиться о необходимости его увеличения вручную, но, к сожалению, это не так. Вы можете сделать это сами, хотя.

6
ответ дан 7 August 2018 в 22:10

В этом уроке объясняется, как вы можете управлять несколькими серверами MySQL из одной установки phpMyAdmin. По соображениям безопасности связь между phpMyAdmin и любым удаленным сервером MySQL использует SSL-шифрование

0
ответ дан 10 August 2018 в 10:24

Основной файл конфигурации хранится в /etc/phpmyadmin/config.inc.php . Этот файл содержит секрет

  • Blowfish из /var/lib/phpmyadmin/blowfish_secret.inc.php
  • Сгенерированная конфигурация из сценария установки phpMyAdmin ( метод diegueus9) /var/lib/phpmyadmin/config.inc.php
  • Значения DB из /etc/phpmyadmin/config-db.php , которые генерируются из /etc/dbconfig-common/phpmyadmin.conf с помощью / usr / sbin / dbconfig-generate-include . /etc/dbconfig-common/phpmyadmin.conf можно изменить с помощью dpkg-reconfigure -plow phpmyadmin
  • Дополнительные файлы конфигурации из / etc /phpmyadmin/conf.d/*.php

Некоторые примеры фрагментов конфигурации находятся в / usr / share / doc / phpmyadmin / examples , включая config.manyhosts.inc.php . Этот файл можно добавить в /etc/phpmyadmin/conf.d . Он работает путем сброса переменной i назад до 1 перед созданием любых хостов, чтобы он переопределял набор узлов в /etc/phpmyadmin/config.inc.php .

Если вы хотите сделать более сложную конфигурацию, вы, вероятно, захотите изменить файл /etc/phpmyadmin/config.inc.php и, возможно, добавить другие расширения конфигурации, используя / etc / phpmyadmin / conf.d .

Чтобы добавить поддержку дополнительных конфигураций в более старые файлы конфигурации, вы можете создать каталог /etc/phpmyadmin/conf.d а затем добавьте ниже код PHP в конец /etc/phpmyadmin/config.inc.php :

  / * Поддержка дополнительных конфигураций * / foreach (glob (  '/etc/phpmyadmin/conf.d/*.php') в качестве $ filename) {include ($ filename);  }  
1
ответ дан 10 August 2018 в 10:24

Я предположил следующее:

  • / etc / phpmyadmin / было бы самым логичным местом для добавления config
  • /etc/phpmyadmin/config-db.php - это местоположение для конфигурации по умолчанию (local?). Это потому, что он по умолчанию, один db только
  • /etc/phpmyadmin/config.inc.php читает базу данных по умолчанию, поэтому она имеет один. По крайней мере, этот используется, поэтому у вас есть база данных. Если что-то меняется в вашей конфигурации, изменяется config-db.php , поэтому «локальные» изменения в вашем файле не изменяются

Поэтому мой вывод заключался в том, что добавив дополнительный сервер под этой частью:

  / * Настроить в соответствии с dbconfig-common, если включено * / if (! empty ($ dbname)) {// чтение из config-db.php}  // $ i ++ было сделано уже, если выше // Добавление дополнительных серверов $ cfg ['Servers'] [$ i] ['host'] = 'serverhost.host.tld';  $ cfg ['Servers'] [$ i] ['extension'] = 'mysqli';  //...etc  

Это выглядит как лучшее место.

2
ответ дан 10 August 2018 в 10:24

Довольно старый вопрос, но все еще актуальный для поисков.

phpMyAdmin использует простой PHP для файлов конфигурации, а массив $ cfg ['Servers'] - для получения настроенных серверов .

Таким образом, правильный способ заключается в добавлении нового файла конфигурации в /etc/phpmyadmin/conf.d для каждого сервера, который вы хотите добавить. Это необходимо только для завершения имени файлов в .php , чтобы включить их, но рекомендуется использовать your_new_server.inc.php для согласованности.

Минимальным содержимым для данного файла конфигурации будет:

  $ cfg ['Servers'] [2] ['host'] = 'THE_HOST';  $ cfg ['Servers'] [2] ['user'] = 'THE_USER';  $ cfg ['Servers'] [2] ['password'] = 'THE_PASSWORD';   

Как указано выше, вы можете проверить /usr/share/doc/phpmyadmin/examples/config.manyhosts.inc.php для получения дополнительных параметров.

Важно: вам нужно увеличить индекс (2) массива для каждого нового файла и не использовать 1, если вы хотите продолжать подключение к localhost.

Если парень (и), который пакет phpMyAdmin подумал об этом, они могли бы добавить добавочную переменную $ i в foreach, которая включает файлы из каталога conf.d , поэтому вы можете просто использовать ее как индекс, и не беспокоиться о необходимости его увеличения вручную, но, к сожалению, это не так. Вы можете сделать это сами, хотя.

6
ответ дан 10 August 2018 в 10:24

Я думаю, что это самый точный способ сделать это:

Сначала установите пароль:

  sudo htpasswd -c /etc/phpmyadmin/htpasswd.setup admin   

Затем отключите защиту:

  sudo pma-configure  

Затем перейдите к http: // yourserver / phpmyadmin / setup (здесь браузеры запрашивают auth, пользователь - admin, а пароль - это то, что вы пишете в первой команде), когда этот мастер, который вы настраиваете на своих серверах, когда-то завершен, снова установите защиту:

  sudo pma-secure  
4
ответ дан 10 August 2018 в 10:24

Согласно документации phpMyAdmin , вы можете определить несколько серверов в массиве $ cfg ['Servers'] , определенном в config.inc.php .

1
ответ дан 10 August 2018 в 10:24

В этом уроке объясняется, как вы можете управлять несколькими серверами MySQL из одной установки phpMyAdmin. По соображениям безопасности связь между phpMyAdmin и любым удаленным сервером MySQL использует SSL-шифрование

0
ответ дан 13 August 2018 в 16:50
  • 1
    Это не говорит мне, как это сделать, используя способ настройки Ubuntu, поэтому он вообще не отвечает на вопрос. – Mike Scott 21 September 2012 в 15:14

Я предположил следующее:

  • / etc / phpmyadmin / было бы самым логичным местом для добавления config
  • /etc/phpmyadmin/config-db.php - это местоположение для конфигурации по умолчанию (local?). Это потому, что он по умолчанию, один db только
  • /etc/phpmyadmin/config.inc.php читает базу данных по умолчанию, поэтому она имеет один. По крайней мере, этот используется, поэтому у вас есть база данных. Если что-то меняется в вашей конфигурации, изменяется config-db.php , поэтому «локальные» изменения в вашем файле не изменяются

Поэтому мой вывод заключался в том, что добавив дополнительный сервер под этой частью:

  / * Настроить в соответствии с dbconfig-common, если включено * / if (! empty ($ dbname)) {// чтение из config-db.php}  // $ i ++ было сделано уже, если выше // Добавление дополнительных серверов $ cfg ['Servers'] [$ i] ['host'] = 'serverhost.host.tld';  $ cfg ['Servers'] [$ i] ['extension'] = 'mysqli';  //...etc  

Это выглядит как лучшее место.

2
ответ дан 13 August 2018 в 16:50

Основной файл конфигурации хранится в /etc/phpmyadmin/config.inc.php . Этот файл содержит секрет

  • Blowfish из /var/lib/phpmyadmin/blowfish_secret.inc.php
  • Сгенерированная конфигурация из сценария установки phpMyAdmin ( метод diegueus9) /var/lib/phpmyadmin/config.inc.php
  • Значения DB из /etc/phpmyadmin/config-db.php , которые генерируются из /etc/dbconfig-common/phpmyadmin.conf с помощью / usr / sbin / dbconfig-generate-include . /etc/dbconfig-common/phpmyadmin.conf можно изменить с помощью dpkg-reconfigure -plow phpmyadmin
  • Дополнительные файлы конфигурации из / etc /phpmyadmin/conf.d/*.php

Некоторые примеры фрагментов конфигурации находятся в / usr / share / doc / phpmyadmin / examples , включая config.manyhosts.inc.php . Этот файл можно добавить в /etc/phpmyadmin/conf.d . Он работает путем сброса переменной i назад до 1 перед созданием любых хостов, чтобы он переопределял набор узлов в /etc/phpmyadmin/config.inc.php .

Если вы хотите сделать более сложную конфигурацию, вы, вероятно, захотите изменить файл /etc/phpmyadmin/config.inc.php и, возможно, добавить другие расширения конфигурации, используя / etc / phpmyadmin / conf.d .

Чтобы добавить поддержку дополнительных конфигураций в более старые файлы конфигурации, вы можете создать каталог /etc/phpmyadmin/conf.d а затем добавьте ниже код PHP в конец /etc/phpmyadmin/config.inc.php :

  / * Поддержка дополнительных конфигураций * / foreach (glob (  '/etc/phpmyadmin/conf.d/*.php') в качестве $ filename) {include ($ filename);  }  
1
ответ дан 13 August 2018 в 16:50

Согласно документации phpMyAdmin , вы можете определить несколько серверов в массиве $ cfg ['Servers'] , определенном в config.inc.php .

1
ответ дан 13 August 2018 в 16:50
  • 1
    В общей установке phpMyAdmin, да. Но Ubuntu имеет свои собственные файлы конфигурации для создания этой части файла config.inc.php, и я хочу знать способ Ubuntu для его настройки без необходимости переопределять конфигурацию Ubuntu. – Mike Scott 4 January 2011 в 13:57
  • 2
    Понимаю. Комментарии в файле say Вы можете восстановить его, используя: dpkg-reconfigure -plow phpmyadmin . Думаю, вы это пробовали? (теперь это не будет сделано в производственной системе). Помимо этого ... при перезаписывании вручную необходимо обновить файлы вручную. – Carsten Thiel 4 January 2011 в 14:06
  • 3
    Да, я могу восстановить файл config-db.php, но файл конфигурации, из которого он ссылается на параметры подключения к базе данных (/etc/dbconfig-common/phpmyadmin.conf), имеет только место для настройки одного сервера базы данных. Я хочу знать, как настроить несколько серверов баз данных. – Mike Scott 4 January 2011 в 14:21
  • 4
    + Майк Скотт, я не мог получить $ cfg ['Servers'] для работы в файле conf.d /, но когда я положил его в config.inc.php, он работал нормально. Я думаю, что есть некоторая ошибка, которая включает в себя предложение include. – flickerfly 1 March 2016 в 21:09

Я думаю, что это самый точный способ сделать это:

Сначала установите пароль:

  sudo htpasswd -c /etc/phpmyadmin/htpasswd.setup admin   

Затем отключите защиту:

  sudo pma-configure  

Затем перейдите к http: // yourserver / phpmyadmin / setup (здесь браузеры запрашивают auth, пользователь - admin, а пароль - это то, что вы пишете в первой команде), когда этот мастер, который вы настраиваете на своих серверах, когда-то завершен, снова установите защиту:

  sudo pma-secure  
4
ответ дан 13 August 2018 в 16:50
  • 1
    Файл конфигурации, сгенерированный этим методом, хранится в /var/lib/phpmyadmin/config.inc.php. – Michael Lawton 9 May 2014 в 22:41
  • 2
    Этот файл конфигурации, сгенерированный этим методом, затем включается в основной файл конфигурации по адресу /etc/phpmyadmin/config.inc.php. Сценарий установки phpMyAdmin не работает на Ubuntu и не загружает существующую конфигурацию (заставляя вас начинать с нуля каждый раз, когда вы ее настраиваете). Также конфигурация, которую он создает, включает такие вещи, как секрет blowfish, который затем перезаписывается основным файлом конфигурации. Вы обнаружите, что первый сервер (1) перезаписывается основным файлом конфигурации, который использует значения сервера из config-db.php. – Michael Lawton 11 May 2014 в 21:22

Довольно старый вопрос, но все еще актуальный для поисков.

phpMyAdmin использует простой PHP для файлов конфигурации, а массив $ cfg ['Servers'] - для получения настроенных серверов .

Таким образом, правильный способ заключается в добавлении нового файла конфигурации в /etc/phpmyadmin/conf.d для каждого сервера, который вы хотите добавить. Это необходимо только для завершения имени файлов в .php , чтобы включить их, но рекомендуется использовать your_new_server.inc.php для согласованности.

Минимальным содержимым для данного файла конфигурации будет:

  $ cfg ['Servers'] [2] ['host'] = 'THE_HOST';  $ cfg ['Servers'] [2] ['user'] = 'THE_USER';  $ cfg ['Servers'] [2] ['password'] = 'THE_PASSWORD';   

Как указано выше, вы можете проверить /usr/share/doc/phpmyadmin/examples/config.manyhosts.inc.php для получения дополнительных параметров.

Важно: вам нужно увеличить индекс (2) массива для каждого нового файла и не использовать 1, если вы хотите продолжать подключение к localhost.

Если парень (и), который пакет phpMyAdmin подумал об этом, они могли бы добавить добавочную переменную $ i в foreach, которая включает файлы из каталога conf.d , поэтому вы можете просто использовать ее как индекс, и не беспокоиться о необходимости его увеличения вручную, но, к сожалению, это не так. Вы можете сделать это сами, хотя.

6
ответ дан 13 August 2018 в 16:50
  • 1
    Я попытался разместить минимальный контент, указанный в файле /etc/phpmyadmin/conf.d/slaveA.conf.php, и просто увидел содержимое в верхней части страницы PHPMyAdmin. Когда я отправил то же самое содержимое в конец config.inc.php, он сработал. Кажется, что-то в этом вопросе. В противном случае это выглядит как ожидаемый способ создания настраиваемой конфигурации, которая не будет убита при обновлениях. – flickerfly 1 March 2016 в 21:07
  • 2
    @flickerfly, поздний ответ, но код в файлах конфигурации должен начинаться с & lt;? php , как и любой другой скрипт PHP. – Marc 15 December 2016 в 19:34

Другие вопросы по тегам:

Похожие вопросы: