Описание и установка

Если требуется установка в "тихом режиме" (например, инсталляция нескольких однотипных систем), можно использовать штатное средство debian-based дистрибутивов — https://wiki.debian.org/DebianInstaller/Preseed и заранее подготовить файл ответов.

Для работы с базой ответов debconf необходимо установить пакет debconf-utils.

sudo apt install debconf-utils

Формат данных

Данные представляют собой набор строк. Строки, начинающиеся с символа #, считаются комментариями. Пустые строки игнорируются. Все остальные строки являются ответом на один вопрос и должны содержать четыре значения, каждое из которых отделяется от другого одним пробельным символом:

  • Первое значение — имя пакета, которому принадлежит вопрос;
  • Второе значение — имя вопроса;
  • Третье значение — тип вопроса;
  • Четвёртое значение (до конца строки) — значение, используемое для ответа на вопрос.

Также третье значение может быть равно "seen". Такая строка помечает вопрос в базе данных debconf как заданный.

Заметим, что автозаполнение ответов на вопросы по умолчанию помечает эти вопросы как заданные, поэтому для изменения ответа по умолчанию без пометки вопроса как заданного вам нужны две строки. Строки переходят и продлеваются на следующую строку, если оканчиваются символом "\".  

Использование

Основные команды

Ниже приведены примеры использования некоторых команд. Подробную информацию о команде можно получить из справки (man).

debconf-get-selections

Команда выводит содержимое базы данных debconf. Примеры:

sasha@ecss1:~/ssw1_3.14$ sudo debconf-get-selections | grep ecss-web-conf
ecss-web-conf	web-conf/mysql_db_port	string	3306
ecss-web-conf	web-conf/http_terminal_host	string	127.0.0.1
ecss-web-conf	web-conf/http_terminal_port	string	9999
ecss-web-conf	web-conf/mysql_db_host	string	127.0.0.1
ecss-web-conf	web-conf/docker_install	boolean	false
sasha@ecss1:~/ssw1_3.14$ sudo debconf-get-selections | grep mysql_ip
ecss-mysql	ecss-mysql/mysql_ip_pattern	string	192.168.%

В данном формате можно подготовить свой файл ответов с нужными настройками.

debconf-set-selections

Команда может быть использована для автоматической настройки ответов из базы данных debconf или для изменения имеющихся ответов. Каждый вопрос будет помечен как уже заданный, чтобы debconf больше не задавал его пользователю. В качестве параметра возможно указать имя файла ответов. Если задано имя файла, то оно рассматривается как файл для чтения, иначе данные берутся со стандартного входного потока (stdin).

Примеры:

debconf-set-selections ds-answer.txt
echo "ecss-node ecss-configuration/ntp_server string 192.168.1.21" | sudo debconf-set-selections

И после этого уже ставить пакет. Вопросов по внесенным настройкам задаваться не будет.

debconf-communicate

Команда позволяет обращаться к debconf из командной строки. В необязательном параметре «пакет» указывается название пакета, от имени которого производится обращение к debconf.

Debconf-communicate читает команды из стандартного входного потока (stdin), которые задаются в формате протокола команд debconf. Описание допустимых команд и их использование можно найти в спецификации к debconf.

Пример использования очистки базы от сохраненных ответов:

for pk in $(sudo debconf-get-selections | grep mysql | awk '{print $1}' | grep mysql | sort | uniq); do sudo echo PURGE | sudo debconf-communicate $pk; done

Получение значения сохраненного ответа:

sasha@ecss1:~/ssw1_3.14$ echo get ecss-configuration/ntp_server_external | sudo debconf-communicate
0 ntp.ubuntu.com

debconf-show

Команда позволяет выполнить запрос к базе данных debconf различными способами.

Наиболее распространённый запрос — «debconf-show имя-пакета», по которому выдаются все элементы базы данных debconf, принадлежащие этому пакету и их текущие значения. Вопросы, которые были уже заданы, отмечены символом «*».

Пример:

sasha@ecss1:~/ssw1_3.14$ sudo debconf-show ecss-mysql
* ecss-mysql/mysql_params_password: (password omitted)
  ecss-mysql/replica_password: (password omitted)
  ecss-mysql/delete_mysql_tc: false
  ecss-mysql/delete_mysql_ab: false
  ecss-mysql/snmp_port: 162
  ecss-mysql/mediator_host_ip: 127.0.0.1
  ecss-mysql/local_host_ip:
  ecss-mysql/remote_host_user: ssw
  ecss-mysql/delete_mysql_meet: false
  ecss-mysql/host1_ip:
  ecss-mysql/delete_mysql_wcf: false
  ecss-mysql/delete_mysql_calls: false
  ecss-mysql/delete_mysql_dialer: false
* ecss-mysql/mysql_ip_pattern: 192.168.%
  ecss-mysql/delete_mysql_audit: false
  ecss-mysql/remote_host_name: ecss2
  ecss-mysql/delete_mysql_stat: false
  ecss-mysql/host_ip_invalid_range:
  ecss-mysql/remote_host_ip:
  ecss-mysql/host2_ip:
  ecss-mysql/replica_user: replica
  ecss-mysql/delete_mysql_sub: false
  ecss-mysql/host2_user: ssw
* ecss-mysql/mysql_params_user: root
* ecss-mysql/configure_replication: false
  ecss-mysql/host2: ecss2