Это старая версия документа!
В этом документе описываются шаги, необходимые для обновления автономного хоста Security Server с версии Ubuntu 18.04 LTS до Ubuntu 20.04 LTS. Пожалуйста, внимательно прочитайте весь документ перед началом процесса обновления. Предполагается, что читатель знаком с дистрибутивом Ubuntu Linux и имеет опыт обновления версии Ubuntu.
С обновлением до Ubuntu 20.04 LTS PostgreSQL обновляется с версии 10 до 12.
Альтернативный метод: Обновление Security Server до Ubuntu 20.04 с использованием резервной копии конфигурации
При обновлении системы, в которой используется аппаратный модуль безопасности: убедитесь, что HSM совместим с Ubuntu 20.04, и ознакомьтесь с документацией по модулю HSM для получения инструкций по обновлению.
apt update && apt full-upgrade
$systemctl stop "xroad-*" $systemctl disable xroad-proxy xroad-signer xroad-confclient xroad-jetty xroad-monitor xroad-opmonitor $systemctl list-units "xroad-*"
$sudo -iu postgres pg_dump -d messagelog -F c -f <dump_file>
$sudo -iu postgres pg_dump -d "op-monitor" -F c -f <dump_file>
$dpkg -l | grep "update-manager-core"
$grep "Prompt=lts" /etc/update-manager/release-upgrades
$do-release-upgrade
$pg_dropcluster --stop <version, e.g. 12> main
$pg_lsclusters Ver Cluster Port Status Owner Data directory Log file 10 main 5432 online postgres /var/lib/postgresql/10/main /var/log/postgresql/postgresql-10-main.log 12 main 5433 online postgres /var/lib/postgresql/12/main /var/log/postgresql/postgresql-12-main.log $pg_dropcluster --stop 12 main
$pg_upgradecluster --method=upgrade --link 10 main
$ sudo pg_upgradecluster --method=upgrade --link 10 main $ sudo pg_lsclusters Ver Cluster Port Status Owner Data directory Log file 10 main 5433 down postgres /var/lib/postgresql/10/main /var/log/postgresql/postgresql-10-main.log 12 main 5432 online postgres /var/lib/postgresql/12/main /var/log/postgresql/postgresql-12-main.log
$apt-add-repository -r "deb https://artifactory.niis.org/xroad-release-deb bionic-current main" $apt-add-repository "deb https://artifactory.niis.org/xroad-release-deb focus-current main"
(или отредактируйте файл /etc/apt/sources.list напрямую)
$apt update && apt full-upgrade
$systemctl enable "xroad-*" $systemctl start "xroad-*"
$systemctl list-unit-files | grep "xroad" $systemctl enable xroad-base.service xroad-confclient.service xroad-monitor.service xroad-opmonitor.service xroad-proxy-ui-api.service xroad-proxy.service xroad-signer.service
systemctl list-units "xroad-*" "postgresql@*" UNIT LOAD ACTIVE SUB DESCRIPTION postgresql@12-main.service loaded active running PostgreSQL Cluster 12-main xroad-base.service loaded active exited X-Road initialization xroad-confclient.service loaded active running X-Road confclient xroad-monitor.service loaded active running X-Road Monitor* xroad-opmonitor.service loaded active running X-Road opmonitor daemon* xroad-proxy.service loaded active running X-Road Proxy xroad-proxy-ui-api.service loaded active running X-Road Proxy UI REST API xroad-signer.service loaded active running X-Road signer
* если установлены надстройки для мониторинга
Убедившись, что обновление базы данных прошло успешно, удалите старую базу данных и удалите устаревшие пакеты PostgreSQL.
$pg_dropcluster 10 main $apt purge postgresql-10 $apt autoremove
pg_upgradecluster --method=upgrade --link 10 main Stopping old cluster... perl: warning: Setting locale failed. perl: warning: Please check that your locale settings: LANGUAGE = (unset), LC_ALL = (unset), LC_ADDRESS = "ru_RU.UTF-8", LC_NAME = "ru_RU.UTF-8", LC_MONETARY = "ru_RU.UTF-8", LC_PAPER = "ru_RU.UTF-8", LC_IDENTIFICATION = "ru_RU.UTF-8", LC_TELEPHONE = "ru_RU.UTF-8", LC_MEASUREMENT = "ru_RU.UTF-8", LC_TIME = "ru_RU.UTF-8", LC_NUMERIC = "ru_RU.UTF-8", LANG = "en_US.UTF-8" are supported and installed on your system. perl: warning: Falling back to a fallback locale ("en_US.UTF-8"). Error: The locale requested by the environment is invalid: LANG: en_US.UTF-8 LC_ADDRESS: ru_RU.UTF-8 LC_IDENTIFICATION: ru_RU.UTF-8 LC_MEASUREMENT: ru_RU.UTF-8 LC_MONETARY: ru_RU.UTF-8 LC_NAME: ru_RU.UTF-8 LC_NUMERIC: ru_RU.UTF-8 LC_PAPER: ru_RU.UTF-8 LC_TELEPHONE: ru_RU.UTF-8 LC_TIME: ru_RU.UTF-8 Error: Could not create target cluster
Решение:
export LANG=en_US.UTF-8 export LC_ALL=en_US.UTF-8 export LC_ADDRESS=en_US.UTF-8 export LC_IDENTIFICATION=en_US.UTF-8 export LC_MEASUREMENT=en_US.UTF-8 export LC_MONETARY=en_US.UTF-8 export LC_NAME=en_US.UTF-8 export LC_NUMERIC=en_US.UTF-8 export LC_PAPER=en_US.UTF-8 export LC_TELEPHONE=en_US.UTF-8 export LC_TIME=en_US.UTF-8 update-locale
Автор Даниил Горбенко