Приложение В. Debconf
Описание и установка
Если требуется установка в "тихом режиме" (например, инсталляция нескольких однотипных систем), можно использовать штатное средство 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