push ru help
All checks were successful
Deploy Static Site / deploy (push) Successful in 6m55s

This commit is contained in:
2025-05-28 05:24:40 +04:00
parent 0113fb8289
commit 041abbbd24
4459 changed files with 121310 additions and 86248 deletions

View File

@ -1,19 +1,20 @@
<!DOCTYPE html>
<html lang="en">
<html lang="ru">
<head>
<title>Updating PostgreSQL cluster 10 to 15</title>
<title>Обновление кластера PostgreSQL 10 до 15</title>
<meta name="generator" content="Help+Manual" />
<meta name="keywords" content="" />
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta name="description" content="When updating PostgreSQL to a major version, the pg_upgrade utility is used. This utility allows you to update the data stored in PostgreSQL data files to a newer version of..." />
<meta name="description" content="При обновлении PostgreSQL до основной версии используется утилита . Она позволяет обновлять данные, хранящиеся в файлах данных PostgreSQL, до более поздней версии PostgreSQL." />
<meta name="picture" content="" />
<meta property="og:type" content="website" />
<meta property="og:title" content="Full documentation for BRIX365 platform. Low-code developer guide. User guide. Admin guide. Developer guide." />
<meta property="og:url" content="https://brix365.com/en/help" />
<meta property="og:image" content="" />
<meta property="og:title" content="Cправка по Low-code платформе ELMA365" />
<meta property="og:url" content="https://elma365.com/ru/help" />
<meta property="og:image" content="" />
<meta property="og:site_name" content="ELMA365" />
<link rel="icon" href="favicon.png" type="image/png" />
<link href="https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap" rel="stylesheet" />
@ -23,6 +24,7 @@
<link rel="stylesheet" href="./article.css" />
<link rel="stylesheet" href="./glossary.css" />
<link rel="stylesheet" href="./theme.css" />
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="helpman_settings.js"></script>
<script type="text/javascript" src="helpman_topicinit.js"></script>
@ -34,16 +36,16 @@
</head>
<body>
<script async src="https://www.googletagmanager.com/gtag/js?id=G-M6ETBEC1R9"></script><script>window.dataLayer=window.dataLayer || []; function gtag(){dataLayer.push(arguments);}gtag('js', new Date()); gtag('config', 'G-M6ETBEC1R9');</script>
<script>!function(e,t,c,n,r,a,m){e.ym=e.ym||function(){(e.ym.a=e.ym.a||[]).push(arguments)},e.ym.l=1*new Date;for(var s=0;s<document.scripts.length;s++)if(document.scripts[s].src===n)return;a=t.createElement(c),m=t.getElementsByTagName(c)[0],a.async=1,a.src=n,m.parentNode.insertBefore(a,m)}(window,document,"script","https://mc.yandex.ru/metrika/tag.js"),ym(83179930,"init",{clickmap:!0,trackLinks:!0,accurateTrackBounce:!0,webvisor:!0})</script><noscript><div><img alt=""src=https://mc.yandex.ru/watch/83179930 style=position:absolute;left:-9999px></div></noscript>
<header class="header elma-365">
<div class="container">
<a class="header__logo" href="https://brix365.com/en/help">
<img src="./logo-en.svg" alt="header logo">
<a class="header__logo" href="https://elma365.com/ru/help">
<img src="./logo.svg" alt="header logo">
</a>
<!-- <div class="hero__search-form" id="search-panel">
<form class="search-form" onsubmit="ym(83180416,'reachGoal','poisk')">
<form class="search-form" onsubmit="ym(83179930,'reachGoal','poisk')">
<label class="search-form__label">
<span id="reset-search" class="search__icon"></span>
<input class="search-form__input" type="text">
@ -63,7 +65,7 @@
</div>
<div class="header__navi">
<ul class="header__list"><li><span class="solution-select"><span class="solution-select__selected"></span><svg width="7" height="4" viewBox="0 0 7 4" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M1 1L3.5 3.5L6 1" stroke="white" stroke-linecap="round" stroke-linejoin="round"/></svg><ul class="solution-select__list"><li><a class="project-link" href="https://brix365.com/en/help/platform/get-trial.html">Platform</a></li><li><a class="project-link" href="https://brix365.com/en/help/ecm/ecm-functions.html">ECM</a></li><li><a class="project-link" href="https://brix365.com/en/help/crm/crm_overview.html">CRM</a></li><li><a class="project-link" href="https://brix365.com/en/help/service/service-functions.html">Service</a></li><li><a class="project-link" href="https://brix365.com/en/help/projects/projects-functions.html">Projects</a></li><li><a class="project-link" href="https://brix365.com/en/help/business_solutions/-elma365-store.html">Business Solutions</a></li></ul></span></li><li><a href="https://api.brix365.com/en/" target="_blank">API</a></li><li><a href="https://tssdk.brix365.com/" target="_blank">SDK</a></li></ul>
<ul class="header__list"><li><span class="solution-select"><span class="solution-select__selected"></span><svg width="7" height="4" viewBox="0 0 7 4" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M1 1L3.5 3.5L6 1" stroke="white" stroke-linecap="round" stroke-linejoin="round"/></svg><ul class="solution-select__list"><li><a class="project-link" href="https://elma365.com/ru/help/platform/get-trial.html">Платформа</a></li><li><a class="project-link" href="https://elma365.com/ru/help/ecm/ecm-functions.html">ECM</a></li><li><a class="project-link" href="https://elma365.com/ru/help/crm/crm_overview.html">CRM</a></li><li><a class="project-link" href="https://elma365.com/ru/help/service/service-functions.html">Service</a></li><li><a class="project-link" href="https://elma365.com/ru/help/projects/projects-functions.html">Проекты</a></li><li><a class="project-link" href="https://elma365.com/ru/help/business_solutions/-elma365-store.html">Бизнес-решения</a></li></ul></span></li><li><a href="https://api.elma365.com/ru/"target="_blank">API</a></li><li><a href="https://tssdk.elma365.com/"target="_blank">SDK</a></li><li><a href="https://community.elma365.com/" target="_blank">Community</a></li><li><a href="https://elma-academy.com/ru/" target="_blank">Академия</a></li><li><a href="https://elma365.com/ru/" target="_blank">Сайт ELMA365</a></li></ul>
</div>
@ -78,8 +80,8 @@
<aside class="sidebar" id="sidebar">
<div class="sidebar__header">
<a class="header__logo" href="https://brix365.com/en/help">
<img src="./logo-light-en.svg">
<a class="header__logo" href="https://elma365.com/ru/help">
<img src="./logo-light.svg">
</a>
<span class="sidebar__close elma-365-close" id="close"></span>
</div>
@ -92,15 +94,15 @@
<div class="article-inner">
<div class="content">
<header class="article__header">
<div class="article__bread" style="display:flex; gap:10px;">
<div class="article__bread" style="display:flex; gap:10px;">
<span id="subcategory" class="search-res__item-category search-res__item-category_subcategory subcategory article__badge"></span>
<div class="topic__breadcrumbs">
<p><a href="elma365-on-premises.html">BRIX On-Premises</a> &gt; <a href="infrastructure-preparation.html">Prepare infrastructure</a> &gt; Databases &gt; <a href="discontinued-postgresql-support.html">Discontinued PostgreSQL support</a> / Updating PostgreSQL cluster 10 to 15</p>
<p><a href="elma365-on-premises.html">ELMA365 On-Premises</a> &gt; <a href="infrastructure-preparation.html">Подготовка инфраструктуры</a> &gt; Базы данных &gt; <a href="discontinued-postgresql-support.html">Прекращение поддержки PostgreSQL 10 в ELMA365</a> / Обновление кластера PostgreSQL 10 до 15</p>
</div>
</div>
<div class="topic__title"><h1 class="p_Heading1"><span class="f_Heading1">Updating PostgreSQL cluster 10 to 15</span></h1>
<div class="topic__title"><h1 class="p_Heading1"><span class="f_Heading1">Обновление кластера PostgreSQL 10 до 15</span></h1>
</div>
</header>
@ -109,42 +111,42 @@
<a href="#h1-article" class="scroll-top"></a>
</div>
<!-- Placeholder for topic body. -->
<p class="p_Normal">When updating PostgreSQL to a major version, the pg_upgrade utility is used. This utility allows you to update the data stored in PostgreSQL data files to a newer version of PostgreSQL.</p>
<p class="p_Normal">Updating a PostgreSQL cluster consists of six steps:</p>
<p class="p_Normal">При обновлении PostgreSQL до основной версии используется утилита <code><b>pg_upgrade</b></code>. Она позволяет обновлять данные, хранящиеся в файлах данных PostgreSQL, до более поздней версии PostgreSQL.</p>
<p class="p_Normal">Обновление кластера PostgreSQL состоит из шести этапов:</p>
<ol style="list-style-type:decimal">
<li value="1" class="p_Normal"><a href="upgrading-postgresql-cluster-10-to-15.html#database-backup" class="topiclink">Database backup</a>.</li><li value="2" class="p_Normal"><a href="upgrading-postgresql-cluster-10-to-15.html#install-postgresql15" class="topiclink">Installation of PostgreSQL 15</a>.</li><li value="3" class="p_Normal"><a href="upgrading-postgresql-cluster-10-to-15.html#updating-data" class="topiclink">Updating data in the database directory</a>.</li><li value="4" class="p_Normal"><a href="upgrading-postgresql-cluster-10-to-15.html#starting-patroni-cluster" class="topiclink">Starting the Patroni cluster</a>.</li><li value="5" class="p_Normal"><a href="upgrading-postgresql-cluster-10-to-15.html#check-after-installing" class="topiclink">Post-installation check</a>.</li><li value="6" class="p_Normal"><a href="upgrading-postgresql-cluster-10-to-15.html#clear-old-data" class="topiclink">Cleaning up old data</a>.</li></ol>
<h2 class="p_Heading2"><a id="database-backup" class="hmanchor"></a><span class="f_Heading2">Step 1. Database backup</span></h2>
<p class="p_Normal">Before carrying out any actions related to the update, create a backup of the PostgreSQL data and configuration. Read more about how to do this in <a href="database-backup-and-recovery.html" class="topiclink">Backup and recover databases</a>.</p>
<li value="1" class="p_Normal"><a href="upgrading-postgresql-cluster-10-to-15.html#database-backup" class="topiclink">Резервное копирование базы данных.</a></li><li value="2" class="p_Normal"><a href="upgrading-postgresql-cluster-10-to-15.html#install-postgresql15" class="topiclink">Установка PostgreSQL 15.</a></li><li value="3" class="p_Normal"><a href="upgrading-postgresql-cluster-10-to-15.html#updating-data" class="topiclink">Обновление данных в каталоге базы данных.</a></li><li value="4" class="p_Normal"><a href="upgrading-postgresql-cluster-10-to-15.html#starting-patroni-cluster" class="topiclink">Запуск кластера Patroni.</a></li><li value="5" class="p_Normal"><a href="upgrading-postgresql-cluster-10-to-15.html#check-after-installing" class="topiclink">Проверка после установки.</a></li><li value="6" class="p_Normal"><a href="upgrading-postgresql-cluster-10-to-15.html#clear-old-data" class="topiclink">Очистка старых данных.</a></li></ol>
<h2 class="p_Heading2"><a id="database-backup" class="hmanchor"></a><span class="f_Heading2">Шаг 1. Резервное копирование базы данных</span></h2>
<p class="p_Normal">Перед выполнением любых действий, связанных с обновлением, создайте резервную копию данных и конфигурации PostgreSQL. О том, как это сделать, читайте в статье <a href="database-backup-and-recovery.html" class="topiclink">«Резервное копирование и восстановление баз данных»</a>.</p>
<p class="p_CodeExample" style="page-break-inside: avoid;"><span class="f_CodeExample">начало&nbsp;внимание</span></p>
<p class="p_Normal">If there are third-party databases on the PostgreSQL server, backups of these databases should also be created.</p>
<p class="p_Normal">Если на сервере PostgreSQL имеются сторонние базы данных, их резервные копии также необходимо создать.</p>
<p class="p_CodeExample" style="page-break-inside: avoid;"><span class="f_CodeExample">конец&nbsp;внимание</span></p>
<p class="p_Normal"><a class="dropdown-toggle" style="font-style: normal; font-weight: normal; color: #000000; background-color: transparent; text-decoration: none;" href="javascript:HMToggle('toggle','TOGGLE0186A1')">Backup of the PostgreSQL database without using the </a><span style="font-weight: bold;"><a class="dropdown-toggle" style="font-style: normal; font-weight: bold; color: #000000; background-color: transparent; text-decoration: none;" href="javascript:HMToggle('toggle','TOGGLE0186A1')">elma365-backupper</a></span><a class="dropdown-toggle" style="font-style: normal; font-weight: normal; color: #000000; background-color: transparent; text-decoration: none;" href="javascript:HMToggle('toggle','TOGGLE0186A1')"> utility:</a></p>
<div id="TOGGLE0186A1" class="dropdown-toggle-body" style="text-align: left; text-indent: 0; line-height: 1.80; padding: 0 0 0 0; margin: 0 0 0 0;"><table style="border:none; border-spacing:0;">
<p class="p_Normal"><a class="dropdown-toggle" style="font-style: normal; font-weight: normal; color: #000000; background-color: transparent; text-decoration: none;" href="javascript:HMToggle('toggle','TOGGLE0186A1')">Резервное копирование базы данных PostgreSQL без использования утилиты elma365-backupper</a></p>
<div id="TOGGLE0186A1" class="dropdown-toggle-body" style="text-align: left; text-indent: 0; padding: 0 0 0 0; margin: 0 0 0 0;"><table style="border:none; border-spacing:0;">
<tr>
<td style="vertical-align:top; padding:0; border:none"><p class="p_Normal">You can create an <code><b>elma365</b></code> database backup using <code><b>pg_dump</b></code> :</p>
<td style="vertical-align:top; padding:0; border:none"><p class="p_Normal">Вы можете создать резервную копию базы данных <code><b>elma365</b></code> с помощью утилиты <code><b>pg_dump</b></code>:</p>
<p class="p_CodeExample" style="page-break-inside: avoid;"><span class="f_CodeExample">sudo&nbsp;-u&nbsp;postgres&nbsp;pg_dump&nbsp;elma365&nbsp;-Fc&nbsp;&gt;&nbsp;path/to/elma365.bak&nbsp;</span></p>
</td>
</tr>
</table>
</div>
<h2 class="p_Heading2"><a id="install-postgresql15" class="hmanchor"></a><span class="f_Heading2">Step 2. Installation of PostgreSQL 15</span></h2>
<p class="p_Normal">Install PostgreSQL 15 on all nodes of the cluster where version 10 is installed:</p>
<h2 class="p_Heading2"><a id="install-postgresql15" class="hmanchor"></a><span class="f_Heading2">Шаг 2. Установка PostgreSQL 15</span></h2>
<p class="p_Normal">Установите PostgreSQL 15 на все ноды кластера, в которых установлена версия 10:</p>
<p class="p_CodeExample" style="page-break-inside: avoid;"><span class="f_CodeExample">sudo&nbsp;apt&nbsp;install&nbsp;postgresql-15</span></p>
<h2 class="p_Heading2"><a id="updating-data" class="hmanchor"></a><span class="f_Heading2">Step 3. Updating data in the database directory</span></h2>
<h2 class="p_Heading2"><a id="updating-data" class="hmanchor"></a><span class="f_Heading2">Шаг 3. Обновление данных в каталоге базы данных</span></h2>
<ol style="list-style-type:upper-roman">
<li value="1" class="p_Normal" style="line-height: 1.20;">In the PostrgeSQL cluster, identify the Leader node::</li></ol>
<li value="1" class="p_Normal">В кластере PostrgeSQL определите Leader-ноду:</li></ol>
<p class="p_CodeExample" style="page-break-inside: avoid;"><span class="f_CodeExample">patronictl&nbsp;-c&nbsp;/etc/patroni/config.yml&nbsp;list</span></p>
<ol style="list-style-type:upper-roman">
<li value="2" class="p_Normal" style="line-height: 1.20;">Stop Patroni on all PostrgeSQL cluster nodes::</li></ol>
<li value="2" class="p_Normal">На всех нодах кластера PostrgeSQL остановите Patroni:</li></ol>
<p class="p_CodeExample" style="page-break-inside: avoid;"><span class="f_CodeExample">sudo&nbsp;systemctl&nbsp;stop&nbsp;patroni.service</span></p>
<ol style="list-style-type:upper-roman">
<li value="3" class="p_Normal" style="line-height: 1.20;">Stop PostgreSQL 10 and PostgreSQL 15 on all cluster nodes:</li></ol>
<li value="3" class="p_Normal">На всех нодах кластера остановите PostgreSQL 10 и PostgreSQL 15:</li></ol>
<p class="p_CodeExample" style="page-break-inside: avoid;"><span class="f_CodeExample">sudo&nbsp;systemctl&nbsp;stop&nbsp;postgresql@10&nbsp;postgresql@15</span></p>
<ol style="list-style-type:upper-roman">
<li value="4" class="p_Normal" style="line-height: 1.20;">Ensure that both PostgreSQL 10 and PostgreSQL 15 clusters are stopped:</li></ol>
<li value="4" class="p_Normal">Убедитесь, что кластеры PostgreSQL 10 и PostgreSQL 15 остановлены:</li></ol>
<p class="p_CodeExample" style="page-break-inside: avoid;"><span class="f_CodeExample">pg_lsclusters</span></p>
<ol style="list-style-type:upper-roman">
<li value="5" class="p_Normal" style="line-height: 1.20;">On the Leader node, perform a compatibility check of database configurations:</li></ol>
<li value="5" class="p_Normal">На Leader-ноде выполните проверку на предмет совместимости конфигураций баз данных:</li></ol>
<p class="p_CodeExample" style="page-break-inside: avoid;"><span class="f_CodeExample">sudo&nbsp;-iu&nbsp;postgres&nbsp;/usr/lib/postgresql/15/bin/pg_upgrade&nbsp;\</span><br />
<span class="f_CodeExample">-o&nbsp;&quot;-c&nbsp;config_file=/etc/postgresql/10/main/postgresql.conf&quot;\</span><br />
<span class="f_CodeExample">-O&nbsp;&quot;-c&nbsp;config_file=/etc/postgresql/15/main/postgresql.conf&quot;&nbsp;\</span><br />
@ -152,11 +154,11 @@
<span class="f_CodeExample">--new-datadir=/var/lib/postgresql/15/main/&nbsp;\</span><br />
<span class="f_CodeExample">--old-bindir=/usr/lib/postgresql/10/bin&nbsp;\</span><br />
<span class="f_CodeExample">--new-bindir=/usr/lib/postgresql/15/bin&nbsp;--check</span></p>
<p class="p_Normal" style="line-height: 1.20;">where:</p>
<p class="p_Normal">где:</p>
<ul style="list-style-type:disc">
<li class="p_Normal"><code><b>/usr/lib/postgresql/10/bin</b></code> and <code><b>/usr/lib/postgresql/15/bin</b></code> are the paths to the binary files of PostgreSQL versions 10 and 15;</li><li class="p_Normal"><code><b>/var/lib/postgresql/10/main</b></code> and <code><b>/var/lib/postgresql/15/main</b></code> are the paths to the data directories.</li></ul>
<li class="p_Normal"><code><b>/usr/lib/postgresql/10/bin</b></code> и <code><b>/usr/lib/postgresql/15/bin</b></code> <span style="font-size: 11px; color: #394149;"></span> пути к бинарным файлам PostgreSQL версий 10 и 15;</li><li class="p_Normal"><code><b>/var/lib/postgresql/10/main</b></code> и <code><b>/var/lib/postgresql/15/main</b></code> <span style="font-size: 11px; color: #394149;"></span> пути к каталогам данных.</li></ul>
<ol style="list-style-type:upper-roman">
<li value="6" class="p_Normal" style="line-height: 1.20;">On the Leader node, transfer data from PostgreSQL 10 to PostgreSQL 15:</li></ol>
<li value="6" class="p_Normal">На Leader-ноде выполните перенос данных из PostgreSQL 10 в PostgreSQL 15:</li></ol>
<p class="p_CodeExample" style="page-break-inside: avoid;"><span class="f_CodeExample">sudo&nbsp;-iu&nbsp;postgres&nbsp;/usr/lib/postgresql/15/bin/pg_upgrade&nbsp;\</span><br />
<span class="f_CodeExample">-o&nbsp;&quot;-c&nbsp;config_file=/etc/postgresql/10/main/postgresql.conf&quot;&nbsp;\</span><br />
<span class="f_CodeExample">-O&nbsp;&quot;-c&nbsp;config_file=/etc/postgresql/15/main/postgresql.conf&quot;&nbsp;\</span><br />
@ -164,50 +166,50 @@
<span class="f_CodeExample">--new-datadir=/var/lib/postgresql/15/main/&nbsp;\</span><br />
<span class="f_CodeExample">--old-bindir=/usr/lib/postgresql/10/bin&nbsp;\</span><br />
<span class="f_CodeExample">--new-bindir=/usr/lib/postgresql/15/bin</span></p>
<p class="p_Normal">where:</p>
<p class="p_Normal">где:</p>
<ul style="list-style-type:disc">
<li class="p_Normal"><code><b>/usr/lib/postgresql/10/bin</b></code> and <code><b>/usr/lib/postgresql/15/bin</b></code> are the paths to the binary files of PostgreSQL versions 10 and 15;</li><li class="p_Normal"><code><b>/var/lib/postgresql/10/main</b></code> and <code><b>/var/lib/postgresql/15/main</b></code> are the paths to the data directories.</li></ul>
<h2 class="p_Heading2"><a id="starting-patroni-cluster" class="hmanchor"></a><span class="f_Heading2">Step 4. Starting the Patroni cluster</span></h2>
<li class="p_Normal"><code><b>/usr/lib/postgresql/10/bin</b></code> и <code><b>/usr/lib/postgresql/15/bin</b></code> <span style="font-size: 11px; color: #394149;"></span> пути к бинарным файлам PostgreSQL версий 10 и 15;</li><li class="p_Normal"><code><b>/var/lib/postgresql/10/main</b></code> и <code><b>/var/lib/postgresql/15/main</b></code> <span style="font-size: 11px; color: #394149;"></span> пути к каталогам данных.</li></ul>
<h2 class="p_Heading2"><a id="starting-patroni-cluster" class="hmanchor"></a><span class="f_Heading2">Шаг 4. Запуск кластера Patroni</span></h2>
<ol style="list-style-type:upper-roman">
<li value="1" class="p_Normal" style="line-height: 1.20;">Open the Patroni configuration file on the path to PostgreSQL 15:</li></ol>
<li value="1" class="p_Normal">На пути до PostgreSQL 15 откройте файл конфигурации Patroni:</li></ol>
<p class="p_CodeExample" style="page-break-inside: avoid;"><span class="f_CodeExample">sudo&nbsp;nano&nbsp;/etc/patroni/config.yml</span></p>
<ol style="list-style-type:upper-roman">
<li value="2" class="p_Normal" style="line-height: 1.20;">Replace parameters <code><b>data_dir</b></code>, <code><b>bin_dir</b></code> and <code><b>config_dir</b></code> on each PostgreSQL cluster node, for example:</li></ol>
<li value="2" class="p_Normal">На каждой ноде кластера PostgreSQL замените параметры <code><b>data_dir</b></code>, <code><b>bin_dir</b></code> и <code><b>config_dir</b></code>, например:</li></ol>
<p class="p_CodeExample" style="page-break-inside: avoid;"><span class="f_CodeExample">...</span><br />
<span class="f_CodeExample">data_dir:&nbsp;/var/lib/postgresql/15/main</span><br />
<span class="f_CodeExample">bin_dir:&nbsp;/usr/lib/postgresql/15/bin</span><br />
<span class="f_CodeExample">config_dir:&nbsp;/etc/postgresql/15/main</span><br />
<span class="f_CodeExample">...</span></p>
<ol style="list-style-type:upper-roman">
<li value="3" class="p_Normal">Get the name of the PostgreSQL 10 cluster:</li></ol>
<li value="3" class="p_Normal">Получите наименование кластера PostgreSQL 10:</li></ol>
<p class="p_CodeExample" style="page-break-inside: avoid;"><span class="f_CodeExample">sudo&nbsp;cat&nbsp;/etc/patroni/config.yml&nbsp;|&nbsp;grep&nbsp;&quot;scope&quot;&nbsp;|&nbsp;awk&nbsp;'{&nbsp;print&nbsp;$2&nbsp;}'</span></p>
<ol style="list-style-type:upper-roman">
<li value="4" class="p_Normal">On the Leader node in Patroni, remove the PostgreSQL 10 cluster:</li></ol>
<li value="4" class="p_Normal">На Leader-ноде в Patroni удалите кластер PostgreSQL 10:</li></ol>
<p class="p_CodeExample" style="page-break-inside: avoid;"><span class="f_CodeExample">patronictl&nbsp;-c&nbsp;/etc/patroni/config.yml&nbsp;remove&nbsp;postgres-cluster</span></p>
<p class="p_Normal">where:</p>
<p class="p_Normal">где:</p>
<ul style="list-style-type:disc">
<li class="p_Normal"><code><b>postgres-cluster</b></code> is the name of the PostgreSQL 10 cluster obtained in the previous step.</li></ul>
<li class="p_Normal"><code><b>postgres-cluster</b></code> <span style="font-size: 11px; color: #394149;"></span> наименование кластера PostgreSQL 10, полученное на предыдущем этапе.</li></ul>
<ol style="list-style-type:upper-roman">
<li value="5" class="p_Normal">Start Patroni on the Leader node:</li></ol>
<li value="5" class="p_Normal">На Leader-ноде запустите Patroni:</li></ol>
<p class="p_CodeExample" style="page-break-inside: avoid;"><span class="f_CodeExample">sudo&nbsp;systemctl&nbsp;start&nbsp;patroni.service</span></p>
<ol style="list-style-type:upper-roman">
<li value="6" class="p_Normal">On Replica nodes, delete the PostgreSQL 15 data directory:</li></ol>
<li value="6" class="p_Normal">На Replica-нодах удалите каталог данных PostgreSQL 15:</li></ol>
<p class="p_CodeExample" style="page-break-inside: avoid;"><span class="f_CodeExample">sudo&nbsp;rm&nbsp;-rf&nbsp;/var/lib/postgresql/15/main</span></p>
<ol style="list-style-type:upper-roman">
<li value="7" class="p_Normal">On Replica nodes, start Patroni:</li></ol>
<li value="7" class="p_Normal">На Replica-нодах запустите Patroni:</li></ol>
<p class="p_CodeExample" style="page-break-inside: avoid;"><span class="f_CodeExample">sudo&nbsp;systemctl&nbsp;start&nbsp;patroni.service</span></p>
<h2 class="p_Heading2"><a id="check-after-installing" class="hmanchor"></a><span class="f_Heading2">Step 5. Post-installation check</span></h2>
<h2 class="p_Heading2"><a id="check-after-installing" class="hmanchor"></a><span class="f_Heading2">Шаг 5. Проверка после установки</span></h2>
<ol style="list-style-type:upper-roman">
<li value="1" class="p_Normal">Check the status of the cluster:</li></ol>
<li value="1" class="p_Normal">Проверьте состояние кластера:</li></ol>
<p class="p_CodeExample" style="page-break-inside: avoid;"><span class="f_CodeExample">patronictl&nbsp;-c&nbsp;/etc/patroni/config.yml&nbsp;list</span></p>
<ol style="list-style-type:upper-roman">
<li value="2" class="p_Normal" style="line-height: 1.20;">Ensure that PostgreSQL 15 is running correctly and the data is accessible. </li><li value="3" class="p_Normal" style="line-height: 1.20;">For database optimization, execute the command on the Leader node:</li></ol>
<li value="2" class="p_Normal">Убедитесь, что PostgreSQL 15 работает корректно и данные доступны. </li><li value="3" class="p_Normal">Для оптимизации базы данных выполните команду на Leader-ноде:</li></ol>
<p class="p_CodeExample" style="page-break-inside: avoid;"><span class="f_CodeExample">sudo&nbsp;-u&nbsp;postgres&nbsp;/usr/lib/postgresql/15/bin/vacuumdb&nbsp;--all&nbsp;--analyze-in-stages</span></p>
<h2 class="p_Heading2"><a id="clear-old-data" class="hmanchor"></a><span class="f_Heading2">Step 6. Cleaning up old data</span></h2>
<h2 class="p_Heading2"><a id="clear-old-data" class="hmanchor"></a><span class="f_Heading2">Шаг 6. Очистка старых данных</span></h2>
<p class="p_CodeExample" style="page-break-inside: avoid;"><span class="f_CodeExample">начало&nbsp;внимание</span></p>
<p class="p_Normal">Before starting the cleaning process, ensure you have a backup of the data and configuration.</p>
<p class="p_Normal">Перед началом процесса очистки убедитесь, что у вас есть резервная копия данных и конфигурации.</p>
<p class="p_CodeExample" style="page-break-inside: avoid;"><span class="f_CodeExample">конец&nbsp;внимание</span></p>
<p class="p_Normal">If necessary, after successful updating and checking PostgreSQL 15, you can clean up old data:</p>
<p class="p_Normal">При необходимости после успешного обновления и проверки PostgreSQL 15 вы можете очистить старые данные:</p>
<p class="p_CodeExample" style="page-break-inside: avoid;"><span class="f_CodeExample">sudo&nbsp;-u&nbsp;postgres&nbsp;./delete_old_cluster.sh</span></p>
<div class="bottom-nav">
@ -225,7 +227,7 @@
</div>
<!-- добавляет на страницу строку блок Была ли статья полезной? -->
<div class="feedback" id="feedback"><div class="feedback-help"><span><b>Was this helpful?</b></span><form action="" method="POST" class="feedback-form" id="feedback-form"><div class="feedback__popup feedback__popup-response" id="feedback__popup_thx" style="display: none;">Thanks for your feedback!</div><div class="feedback__popup" id="feedback__popup_why" style="display: none;"><div class="feedback__popup-header">Please specify why:</div><input type="radio" name="category" id="bad_recommendation" value="bad_recommendation"><label for="bad_recommendation">Recommendations did not help me</label><input type="radio" name="category" id="difficult_text" value="difficult_text"><label for="difficult_text">Article is hard to understand</label><input type="radio" name="category" id="no_answer" value="no_answer"><label for="no_answer">Didn`t answer my question</label><input type="radio" name="category" id="bad_header" value="bad_header"><label for="bad_header">Content does not match the topic</label><input type="radio" name="category" id="other_reason" value="other_reason"><label for="other_reason">Other</label></div><div class="feedback__popup" id="feedback__popup-other" style="display: none;"><div class="feedback__popup-header">How we can improve it?</div><textarea class="feedback__textarea" name="other" id=""></textarea><input type="submit" class="feedback__other-btn" value="Submit"></div><div class="feedback-form__btn-group"><input type="radio" name="useful" id="feedback__useful_yes" value="true"><label for="feedback__useful_yes"><img src="like.svg" class="small-img" alt="like"><spanclass="feedback-form__btn-group_yes-btn">Yes</spanclass="feedback-form__btn-group_yes-btn"></label><input type="radio" name="useful" id="feedback__useful_no" value="false"><label for="feedback__useful_no"><img src="dislike.svg" class="small-img" alt="dislike"><spanclass="feedback-form__btn-group_no-btn">No</spanclass="feedback-form__btn-group_no-btn"></label></div><select name="category"><option disabled="">Please specify why</option><option value="bad_recommendation" selected="">Recommendations did not help me</option><option value="difficult_text">Article is hard to understand</option><option value="no_answer">Didn`t answer my question</option><option value="bad_header">Content does not match the topic</option><option value="other_reason">Other</option></select><input type="submit"></form></div><div class="found_typo"><p style="margin: 0px; margin-top: 16px !important;"><span><b>Found a typo?</b></span> Select it and press <i>Ctrl+Enter</i> to send us feedback</p></div></div>
<div class="feedback-wrap"><div class="feedback" id="feedback"><span><b>Была ли статья полезной?</b></span><form action="" method="POST" class="feedback-form" id="feedback-form"><div class="feedback__popup feedback__popup-response" id="feedback__popup_thx">Спасибо за ваш отзыв!</div><div id="feedback-success-popup"><div class="wrap"><button type="button" class="feedback-popup-close">×</button><svg width="44" height="44" viewBox="0 0 44 44" fill="none" xmlns="http://www.w3.org/2000/svg"><g clip-path="url(#clip0_212_2187)"><path d="M22 0.6875C10.2294 0.6875 0.6875 10.2294 0.6875 22C0.6875 33.7706 10.2294 43.3125 22 43.3125C33.7706 43.3125 43.3125 33.7706 43.3125 22C43.3125 10.2294 33.7706 0.6875 22 0.6875ZM22 40.5625C11.8023 40.5625 3.4375 32.3078 3.4375 22C3.4375 11.8024 11.6922 3.4375 22 3.4375C32.1977 3.4375 40.5625 11.6922 40.5625 22C40.5625 32.1976 32.3078 40.5625 22 40.5625ZM34.1713 16.933L18.6613 32.3186C18.257 32.7197 17.604 32.7171 17.203 32.3128L9.82283 24.873C9.42176 24.4686 9.42434 23.8157 9.82867 23.4146L10.5609 22.6884C10.9652 22.2873 11.6181 22.2899 12.0192 22.6942L17.9468 28.6697L31.9926 14.7366C32.3969 14.3356 33.0498 14.3382 33.4509 14.7425L34.1772 15.4747C34.5783 15.879 34.5757 16.532 34.1713 16.933Z" fill="#27AE60"></path></g><defs><clipPath id="clip0_212_2187"><rect width="44" height="44" fill="white"></rect></clipPath></defs></svg><p>Ваш отзыв успешно отправлен!</p><span>Спасибо за обратную связь.</span></div></div><div class="feedback__popup" id="feedback__popup_why"><button type="button" class="feedback-popup-close">×</button><div class="feedback__popup-header">Уточните, почему:</div><input type="radio" name="category" id="bad_recommendation" value="bad_recommendation"><label for="bad_recommendation">Рекомендации не помогли</label><input type="radio" name="category" id="difficult_text" value="difficult_text"><label for="difficult_text">Текст трудно понять</label><input type="radio" name="category" id="no_answer" value="no_answer"><label for="no_answer">Нет ответа на мой вопрос</label><input type="radio" name="category" id="bad_header" value="bad_header"><label for="bad_header">Содержание статьи не соответствует заголовку</label><input type="radio" name="category" id="other_reason" value="other_reason"><label for="other_reason">Другая причина</label></div><div class="feedback__popup" id="feedback__popup-other"><button type="button" class="feedback-popup-close">×</button> <div class="feedback__popup-header">Расскажите, что вам не понравилось в статье:</div><textarea class="feedback__textarea" name="other" id=""></textarea><input type="submit" class="feedback__other-btn" value="Отправить"></div><div class="feedback-form__btn-group"><input type="radio" name="useful" id="feedback__useful_yes" value="true"><label for="feedback__useful_yes"><img src="like.svg"/><span class="feedback-form__btn-group_yes-btn">Да</span></label><input type="radio" name="useful" id="feedback__useful_no" value="false"><label for="feedback__useful_no"><img src="dislike.svg"/><span class="feedback-form__btn-group_no-btn">Нет</span></label></div><select name="category"><option disabled>Выберите вариант</option><option value="bad_recommendation" selected>Рекомендации не помогли</option><option value="difficult_text">Текст трудно понять</option><option value="no_answer">Нет ответа на мой вопрос</option><option value="bad_header">Содержание статьи не соответствует заголовку</option><option value="other_reason">Другая причина</option></select><input type="submit"></form></div></div>
</section>
</div>
@ -233,7 +235,7 @@
<input type="checkbox" />
<div class="article__arrow"></div>
<div class="table-of-contents elma365-right" id="toc2Content">
<h3 class="h3-toc">In this topic</h3>
<h3 class="h3-toc">В этой статье</h3>
<nav id="toc2"></nav>
</div>
</aside>
@ -244,30 +246,63 @@
<div class="footer-container">
<div class="footer-mobile">
<ul class="footer-mobile__list"><li><a href="https://brix365.com/en/" target="_blank">BRIX</a></li><li><a href="https://tssdk.brix365.com/en/latest/" target="_blank">SDK</a></li><li><a href="https://api.brix365.com/en/" target="_blank">API</a></li></ul><ul class="footer-mobile__list"><li><a href="https://brix365.com/en/help/platform/get-trial.html">Platform</a></li><li><a href="https://brix365.com/en/help/ecm/ecm-functions.html">ECM</a></li><li><a href="https://brix365.com/en/help/service/service-functions.html">Service</a></li><li><a href="https://brix365.com/en/help/projects/projects-functions.html">Projects</a></li></ul>
<ul class="footer-mobile__list"><li><a href="https://api.elma365.com/ru/" target="_blank">API</a></li><li><a href="https://tssdk.elma365.com/" target="_blank">TS SDK</a></li><li><a href="https://community.elma365.com/" target="_blank">Community</a></li><li><a href="https://elma-academy.com/ru/elma365" target="_blank">Академия</a></li></ul><ul class="footer-mobile__list"><li><a href="https://elma365.com/ru/help/platform/get-trial.html">Платформа</a></li><li><a href="https://elma365.com/ru/help/ecm/ecm-functions.html">ECM</a></li><li><a href="https://elma365.com/ru/help/service/service-functions.html">Service</a></li><li><a href="https://elma365.com/ru/help/projects/projects-functions.html">Проекты</a></li></ul>
</div>
<div class="footer-wrap">
<div><span class="mobile-question-popup">Send feedback</span><form method="POST" action class="question__popup question-xs" id="question__popup"><div class="question-wrap"><span class="close"></span><span class="title">Ask a question</span><label for="help_question" style="display: none;"></label><textarea name="help_question" id="help_question"></textarea><input type="submit" value="Send"></div></form><div class="hidden fade-in question-success-xs">Sent</div></div>
<div class="footer-flex-b">
<span class="footer-copy">&copy; 2025 BRIX</span>
<ul class="footer-list">
<li class="footer-item">
<a href="#" class="arrow-top" style="display: block;"></a>
</li>
</ul>
<div class="container">
<div class="footer-wrap">
<div><span class="mobile-question-popup">Отправить фидбэк</span><form method="POST" action class="question__popup question-xs" id="question__popup"><div class="question-wrap"><span class="close"></span><span class="title">Задать вопрос</span><label for="help_question" style="display: none;"></label><textarea name="help_question" id="help_question"></textarea><input type="submit" value="Отправить"></div></form><div class="hidden fade-in question-success-xs">Ваш фидбэк отправлен.</div></div>
<div class="footer-flex-b">
<div class="footer-top">
<span class="footer-copy">&copy; 2025
ELMA365
</span>
<a href="https://navigator.sk.ru/orn/1122971" target="_blank">
<img src="sk-resident.svg" alt="sk icon" class="footer-img" width="117" height="34">
</a>
</div>
<div class="footer-line">
<div class="footer-line-copy">
<span class="footer-copy">&copy; 2025
ELMA365
</span>
</div>
<ul class="footer-list">
<li class="footer-item"><a href="https://elma365.com/ru/" target="_blank" class="footer-link" style="color: #0D4A75;"><img src="browse.svg" alt="browse icon" class="footer-img">elma365.com</a></li><li class="footer-item"><a href="https://www.youtube.com/user/ELMABPM" target="_blank" class="footer-link"><img src="yt.svg" alt="youtube icon" class="footer-img"></a></li><li class="footer-item"><a href="https://vk.com/elma_bpm" target="_blank" class="footer-link"><img src="vk.svg" alt="vk icon" class="footer-img"></a></li><li class="footer-item"><a href="https://t.me/elmaday" target="_blank" class="footer-link"><img src="tg.svg" alt="telegram icon" class="footer-img"></a></li><li class="footer-item"><a href="https://dzen.ru/elma" target="_blank" class="footer-link"><img src="dzen.svg" alt="dzen icon" class="footer-img"></a></li>
<li class="footer-item">
<a href="https://navigator.sk.ru/orn/1122971" target="_blank">
<img src="sk-resident.svg" alt="sk icon" class="footer-img" width="117" height="34">
</a>
</li>
</ul>
</div>
</div>
</div>
</div>
<a href="#" class="arrow-top"></a>
</div>
</footer>
<!-- <script type="text/javascript" src="jquery1.min.js"></script>-->
<iframe name="hmnavigation" style="display:none!important"></iframe>
<script src="./jquery-ui.js"></script>
<!--<script src="./jquery-ui.js"></script> -->
<script src="./jquery-ui.min.js"></script>
<!--script src="//cdn.jsdelivr.net/npm/featherlight@1.7.14/release/featherlight.min.js" type="text/javascript" charset="utf-8"></script-->
<script src="./jquery.tocify.min.js"></script>
<script src="./TypoReporter.min.js"></script>
@ -275,8 +310,6 @@
<script src="./main.js"></script>
<script type="text/javascript">
HMInitToggle('TOGGLE0186A1','hm.type','dropdown','hm.state','0');
HMInitToggle('TOGGLE0186A1','hm.type','dropdown','hm.state','0');
HMInitToggle('TOGGLE0186A1','hm.type','dropdown','hm.state','0');
</script>
</body>