update help elma

This commit is contained in:
2025-05-27 21:32:35 +04:00
parent a6b05d6789
commit 898b22bf32
4500 changed files with 89372 additions and 120699 deletions

View File

@ -1,20 +1,19 @@
<!DOCTYPE html>
<html lang="ru">
<html lang="en">
<head>
<title>Пользовательские микросервисы</title>
<title>Custom microservices</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="Для решения специфичных и сложных технических задач вам может понадобиться разработка отдельного сервиса. Например, для решения задач обработки данных или для задач, связанных..." />
<meta name="description" content="For some unconventional and technically complex solutions, you may need to develop a separate service. For example, to process data or to manage heavy use of a servers..." />
<meta name="picture" content="" />
<meta property="og:type" content="website" />
<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" />
<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="" />
<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" />
@ -24,7 +23,6 @@
<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>
@ -36,16 +34,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://elma365.com/ru/help">
<img src="./logo.svg" alt="header logo">
<a class="header__logo" href="https://brix365.com/en/help">
<img src="./logo-en.svg" alt="header logo">
</a>
<!-- <div class="hero__search-form" id="search-panel">
<form class="search-form" onsubmit="ym(83179930,'reachGoal','poisk')">
<form class="search-form" onsubmit="ym(83180416,'reachGoal','poisk')">
<label class="search-form__label">
<span id="reset-search" class="search__icon"></span>
<input class="search-form__input" type="text">
@ -65,7 +63,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://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>
<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>
</div>
@ -80,8 +78,8 @@
<aside class="sidebar" id="sidebar">
<div class="sidebar__header">
<a class="header__logo" href="https://elma365.com/ru/help">
<img src="./logo-light.svg">
<a class="header__logo" href="https://brix365.com/en/help">
<img src="./logo-light-en.svg">
</a>
<span class="sidebar__close elma-365-close" id="close"></span>
</div>
@ -94,15 +92,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="solutions-building.html">Разработка решений на платформе ELMA365</a> / Пользовательские микросервисы</p>
<p><a href="solutions-building.html">Build solutions in BRIX</a> / Custom microservices</p>
</div>
</div>
<div class="topic__title"><h1 class="p_Heading1"><span class="f_Heading1">Пользовательские микросервисы</span></h1>
<div class="topic__title"><h1 class="p_Heading1"><span class="f_Heading1">Custom microservices</span></h1>
</div>
</header>
@ -111,52 +109,49 @@
<a href="#h1-article" class="scroll-top"></a>
</div>
<!-- Placeholder for topic body. -->
<p>Для решения специфичных и сложных технических задач вам может понадобиться разработка отдельного сервиса. Например, для решения задач обработки данных или для задач, связанных с интенсивным использованием ресурсов сервера (процессор, память, видеокарты).</p>
<p style="line-height: 1.38; margin: 16px 0 1px 0;">Платформа ELMA365 полностью готова к тому, чтобы соединить в единый ландшафт множество существующих систем и сервисов. Для этого выделяется два потока обмена информацией.</p>
<h2 class="p_Heading2"><span class="f_Heading2">Сторонний сервис вызывает платформу ELMA365</span></h2>
<p style="margin: 0 0 16px 0;">Для этого используются готовые <a href="https://api.elma365.com/ru/public-api/guides/IntroWebAPI/" target="_blank" class="weblink">Web API</a> платформы, а также <a href="extention-api.html" class="topiclink">методы API</a>, которые пользователь может разработать самостоятельно в модуле. Типовыми сценариями взаимодействия в данном случае считаются:</p>
<p style="line-height: 1.20; margin: 7px 0 16px 0;"><span style="font-family: Inter;">For some unconventional and technically complex solutions, you may need to develop a separate service. For example, to process data or to manage heavy use of a servers resources (processor, memory, and video cards).</span></p>
<p style="line-height: 1.20; margin: 7px 0 16px 0;"><span style="font-family: Inter;">The BRIX platform has all the things needed to unite all the existing systems and services into a single structure. Communication can be set up in two directions.</span></p>
<h2 class="p_Heading2"><span class="f_Heading2">An external service calls BRIX</span></h2>
<p style="line-height: 1.20; margin: 0 0 16px 0;"><span style="font-family: Inter;">To set up this type of communication, you can use the <a href="https://api.brix365.com/en/public-api/guides/IntroWebAPI/" target="_blank" class="weblink">web API</a> available on the platform and custom <a href="extention-api.html" class="topiclink">API methods</a> that a user can create in a module. Common communication scenarios in this case are the following:</span></p>
<ul style="list-style-type:disc">
<li style="margin-top: 0; margin-right: 0; margin-bottom: 0;">получение элементов приложения для хранения и обработки;</li><li style="margin-top: 0; margin-right: 0; margin-bottom: 0;">обновление значений в элементах по результатам событий во внешней системе;</li><li style="margin-top: 0; margin-right: 0; margin-bottom: 0;">запуск процесса или создание элемента приложения по событию внешней системы;</li><li style="margin-top: 0; margin-right: 0; margin-bottom: 16px;">хранение и обработка файлов и документов.</li></ul>
<p style="margin: 0 0 16px 0;">Благодаря возможностям <a href="type-script.html" class="topiclink">скриптов и TypeScript SDK</a> пользователь может создавать свои собственные методы API в модулях, которые будут исполнять значительную часть логики внутри платформы. Это позволяет сократить количество вызовов из внешней системы до минимума.</p>
<h2 class="p_Heading2"><span class="f_Heading2">Процессы и виджеты вызывают сторонний сервис</span></h2>
<p style="line-height: 1.50; margin: 20px 0 0 0;">Для интеграции в этом направлении в процессах и виджетах можно использовать скрипты на TypeScript, которые будут выполняться в платформе и вызывать внешний сервис. Для вызова сервиса по HTTPпротоколу в TS SDK есть метод <a href="https://tssdk.elma365.com/ru/latest/pages/quick-start/intro_fetch.html" target="_blank" class="weblink">fetch()</a>. Используя этот метод, можно быстро вызвать любой внешний сервис и тут же прочитать ответ. </p>
<p style="line-height: 1.50; margin: 20px 0 0 0;">Например, можно написать такой скрипт для получения курса доллара с сайта ЦБ РФ:</p>
<p class="p_Normal">&nbsp;</p>
<p class="p_CodeExample" style="page-break-inside: avoid;"><span class="f_CodeExample" style="font-weight: bold;">const</span><span class="f_CodeExample">&nbsp;res&nbsp;=&nbsp;await&nbsp;fetch(&quot;https://www.cbr-xml-daily.ru/daily_json.js&quot;);</span><br />
<span class="f_CodeExample">&nbsp;</span><span class="f_CodeExample" style="font-weight: bold;">if</span><span class="f_CodeExample">&nbsp;(res.ok)&nbsp;{</span><br />
<span class="f_CodeExample">&nbsp;&nbsp;&nbsp;&nbsp;</span><span class="f_CodeExample" style="font-weight: bold;">const</span><span class="f_CodeExample">&nbsp;cbrData&nbsp;=&nbsp;await&nbsp;res.json();</span><br />
<span class="f_CodeExample">&nbsp;&nbsp;&nbsp;&nbsp;</span><span class="f_CodeExample" style="font-weight: bold;">const</span><span class="f_CodeExample">&nbsp;usdPrice&nbsp;=&nbsp;cbrData[&quot;Valute&quot;][&quot;USD&quot;][&quot;Value&quot;]&nbsp;as&nbsp;number;</span><br />
<span class="f_CodeExample">&nbsp;&nbsp;&nbsp;&nbsp;data.items.push({name:&nbsp;'USD',&nbsp;price:&nbsp;usdPrice.toString()});</span><br />
<li style="line-height: 1.20; margin-top: 0; margin-right: 0; margin-bottom: 16px;"><span style="font-family: Inter;">Getting app items to store and process them.</span></li><li style="line-height: 1.20; margin-top: 0; margin-right: 0; margin-bottom: 16px;"><span style="font-family: Inter;">Updating values in app items based on events in an external system.</span></li><li style="line-height: 1.20; margin-top: 0; margin-right: 0; margin-bottom: 16px;"><span style="font-family: Inter;">Starting a process or creating an app item based on an event in an external system.</span></li><li style="line-height: 1.20; margin-top: 0; margin-right: 0; margin-bottom: 16px;"><span style="font-family: Inter;">Storing and processing files and documents.</span></li></ul>
<p style="line-height: 1.20; margin: 0 0 16px 0;"><span style="font-family: Inter;">Thanks to <a href="type-script.html" class="topiclink">scripts and TypeScript SDK</a>, users can create their own API methods in modules. These methods can execute a large part of the required logic within the platform. This allows minimizing the number of calls from the external system.</span></p>
<h2 class="p_Heading2"><span class="f_Heading2">Processes and widgets calls an external system</span></h2>
<p style="line-height: 1.20; margin: 20px 0 0 0;"><span style="font-family: Inter;">For this type of communication, you can use TypeScript scripts in processes and widgets. They will be executed on the platform and used to call the external service. To call a service using the HTTP protocol, use the <a href="https://tssdk.brix365.com/en/" target="_blank" class="weblink">fetch method</a>. With this method you can quickly call any external service and read the response right away.</span></p>
<p style="line-height: 1.20; margin: 20px 0 0 0;"><span style="font-family: Inter;">For example, the following script allows you to get the US dollar exchange rate:</span></p>
<p class="p_CodeExample" style="white-space: normal; page-break-inside: avoid;"><span class="f_CodeExample" style="font-weight: bold;">const</span><span class="f_CodeExample" style="color: #ffffff;"> </span><span class="f_CodeExample">res</span><span class="f_CodeExample" style="color: #ffffff;"> </span><span class="f_CodeExample">=</span><span class="f_CodeExample" style="color: #ffffff;"> </span><span class="f_CodeExample">await</span><span class="f_CodeExample" style="color: #ffffff;"> </span><span class="f_CodeExample">fetch(&quot;http://www.floatrates.com/daily/usd.json&quot;);</span><br />
<span class="f_CodeExample">if (res.ok) {</span><br />
<span class="f_CodeExample"> &nbsp; &nbsp;const ratesData = await res.json();</span><br />
<span class="f_CodeExample"> &nbsp; &nbsp;const eurData = ratesData.eur;</span><br />
<span class="f_CodeExample"> &nbsp; &nbsp;data.items.push({ name: 'EUR', price: eurData.rate.toString() });</span><br />
<span class="f_CodeExample">}</span></p>
<p style="margin: 16px 0 16px 0;"><span style="font-size: 15px;">Метод </span><span style="font-size: 15px; font-weight: bold;">fetch</span><span style="font-size: 15px;"> также поддерживает параметры, если требуется выполнить более сложный запрос:</span></p>
<p class="p_CodeExample" style="page-break-inside: avoid;"><span class="f_CodeExample" style="font-weight: bold;">const</span><span class="f_CodeExample">&nbsp;res&nbsp;=&nbsp;await&nbsp;fetch(&quot;https://my.server.name/api/products&quot;,&nbsp;{</span><br />
<span class="f_CodeExample">&nbsp;&nbsp;&nbsp;&nbsp;method:&nbsp;&quot;POST&quot;,</span><br />
<span class="f_CodeExample">&nbsp;&nbsp;&nbsp;&nbsp;headers:&nbsp;{</span><br />
<span class="f_CodeExample">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&quot;Authorization&quot;:&nbsp;'Bearer&nbsp;SOME-TOKEN-HERE',</span><br />
<span class="f_CodeExample">&nbsp;&nbsp;&nbsp;&nbsp;},</span><br />
<span class="f_CodeExample">&nbsp;&nbsp;&nbsp;&nbsp;body:&nbsp;JSON.stringify({</span><br />
<span class="f_CodeExample">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;name:&nbsp;&quot;New&nbsp;product&quot;,</span><br />
<span class="f_CodeExample">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;cost:&nbsp;13.20,</span><br />
<span class="f_CodeExample">&nbsp;&nbsp;&nbsp;&nbsp;})</span><br />
<p style="line-height: 1.20; margin: 16px 0 16px 0;"><span style="font-size: 15px; font-family: Inter;">The </span><code><b>fetch()</b></code><span style="font-size: 15px; font-family: Inter;"> method also supports additional parameters if you need a more complex request:</span></p>
<p class="p_CodeExample" style="page-break-inside: avoid;"><span class="f_CodeExample">const res = await fetch(&quot;https://my.server.name/api/products&quot;, {</span><br />
<span class="f_CodeExample"> &nbsp;&nbsp;&nbsp;method: &quot;POST&quot;,</span><br />
<span class="f_CodeExample"> &nbsp;&nbsp;&nbsp;headers: {</span><br />
<span class="f_CodeExample"> &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&quot;Authorization&quot;: 'Bearer SOME-TOKEN-HERE',</span><br />
<span class="f_CodeExample"> &nbsp;&nbsp;&nbsp;},</span><br />
<span class="f_CodeExample"> &nbsp;&nbsp;&nbsp;body: JSON.stringify({</span><br />
<span class="f_CodeExample"> &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;name: &quot;New product&quot;,</span><br />
<span class="f_CodeExample"> &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;cost: 13.20,</span><br />
<span class="f_CodeExample"> &nbsp;&nbsp;&nbsp;})</span><br />
<span class="f_CodeExample">});</span><br />
<span class="f_CodeExample">&nbsp;</span><br />
<span class="f_CodeExample" style="font-weight: bold;">if</span><span class="f_CodeExample">&nbsp;(!res.ok)&nbsp;{</span><br />
<span class="f_CodeExample">&nbsp;&nbsp;&nbsp;&nbsp;</span><span class="f_CodeExample" style="font-style: italic;">//&nbsp;Обработка&nbsp;ошибок</span><br />
<span class="f_CodeExample">if (!res.ok) {</span><br />
<span class="f_CodeExample"> &nbsp;&nbsp;&nbsp;// Error&nbsp;handling</span><br />
<span class="f_CodeExample">}</span><br />
<span class="f_CodeExample">&nbsp;</span><br />
<span class="f_CodeExample" style="font-weight: bold;">const</span><span class="f_CodeExample">&nbsp;resData&nbsp;=&nbsp;res.json();</span></p>
<p class="p_Normal">&nbsp;</p>
<p class="p_Normal">Таким образом, взаимодействие с вашим сервисом может быть выполнено в самых разных скриптах:</p>
<span class="f_CodeExample">const resData = res.json();</span></p>
<p style="line-height: 1.20; margin: 7px 0 16px 0;"><span style="font-family: Inter;">As a result, the platform can interact with your service in various situations: </span></p>
<ul style="list-style-type:disc">
<li class="p_Normal">при создании элемента приложения;</li><li class="p_Normal">в рамках <a href="360027203731.html" class="topiclink">выполнения процесса</a>;</li><li class="p_Normal">в <a href="client_server_scripts.html" class="topiclink">скриптах виджета или страницы</a>;</li><li class="p_Normal">при обработке системных событий в модуле.</li></ul>
<p class="p_Normal">В редакции OnPremises для интеграции с внешними сервисами дополнительно существуют следующие возможности:</p>
<li style="line-height: 1.20; margin-top: 7px; margin-right: 0; margin-bottom: 7px;"><span style="font-family: Inter;">When an app item is created.</span></li><li style="line-height: 1.20; margin-top: 7px; margin-right: 0; margin-bottom: 7px;"><span style="font-family: Inter;">Within a <a href="360027203731.html" class="topiclink">business process</a>.</span></li><li style="line-height: 1.20; margin-top: 7px; margin-right: 0; margin-bottom: 7px;"><span style="font-family: Inter;">In <a href="client_server_scripts.html" class="topiclink">widget or page scripts</a>.</span></li><li style="line-height: 1.20; margin-top: 7px; margin-right: 0; margin-bottom: 7px;"><span style="font-family: Inter;">When system events are processed in a module.</span></li></ul>
<p style="line-height: 1.20; margin: 7px 0 16px 0;"><span style="font-family: Inter;">In the On-Premises edition, there are two additional possibilities for integration with external services:</span></p>
<ul style="list-style-type:disc">
<li class="p_Normal"><a href="delegated-activities.html" class="topiclink">делегированное действие</a> в бизнес-процессе;</li><li class="p_Normal">делегированный обработчик событий в модуле.</li></ul>
<h2 class="p_Heading2"><a id="support" class="hmanchor"></a><span class="f_Heading2">Развертывание и поддержка сервиса</span></h2>
<p class="p_Normal">Следует учитывать, что платформа и вендор никак не регламентируют способы разработки, размещения, поддержки и обеспечения безопасности для вашего собственного сервиса. Однако, мы можем дать некоторые рекомендации по размещению и изоляции сервисов в локальном кластере, исходя из собственной практики.</p>
<li style="line-height: 1.20; margin-top: 7px; margin-right: 0; margin-bottom: 7px;"><span style="font-family: Inter;">A <a href="extention-activities.html" class="topiclink">business process activity</a> performed by an external service.</span></li><li style="line-height: 1.20; margin-top: 7px; margin-right: 0; margin-bottom: 7px;"><span style="font-family: Inter;">Event handling in a module performed by an external service.</span></li></ul>
<h2 class="p_Heading2"><a id="support" class="hmanchor"></a><span class="f_Heading2">Deployment and support of a service</span></h2>
<p style="line-height: 1.20; margin: 7px 0 16px 0;"><span style="font-family: Inter;">You should note that BRIX does not regulate development, deployment, support, and security control methods you use for your custom services in any way. However, we can provide some guidelines for locating and isolating services in a local cluster based on our own experience.</span></p>
<ul style="list-style-type:disc">
<li class="p_Normal">разрабатывайте сервис с использованием <a href="https://www.docker.com/" target="_blank" class="weblink">Docker контейнеров</a>. Этот подход позволит создавать повторяемые и обновляемые сервисы. Такие сервисы очень просто установить в кластер Kubernetes, который является основным оркестратором для системы;</li><li class="p_Normal">оставляйте свой сервис внутри <a href="https://ru.wikipedia.org/wiki/DMZ_(%D0%BA%D0%BE%D0%BC%D0%BF%D1%8C%D1%8E%D1%82%D0%B5%D1%80%D0%BD%D1%8B%D0%B5_%D1%81%D0%B5%D1%82%D0%B8)" target="_blank" class="weblink">закрытой сетевой зоны</a>. Не прокидывайте в общий доступ любые порты и точки доступа до сервиса без крайней необходимости. Соблюдайте <a href="https://ru.wikipedia.org/wiki/OWASP" target="_blank" class="weblink">правила безопасной разработки сервисов</a>;</li><li class="p_Normal">по возможности, изучите рекомендации разработки облачных приложений в статье <a href="https://12factor.net/ru/" target="_blank" class="weblink">«Двенадцать факторов»</a>.</li></ul>
<p class="p_Normal">Кроме того, ознакомьтесь со статьей <a href="create-service.html" class="topiclink">«Создание собственного микросервиса»</a>, где приведен пример создания и установки простого микросервиса в кластер ELMA365 OnPremises.</p>
<li style="line-height: 1.20; margin-top: 7px; margin-right: 0; margin-bottom: 7px;"><span style="font-family: Inter;">Develop your service using <a href="https://www.docker.com/" target="_blank" class="weblink">Docker containers</a>. This approach allows creating services that can be replicated and updated. They can be quite easily installed to a Kubernetes cluster, which is helpful as Kubernetes is the systems main orchestrator.</span></li><li style="line-height: 1.20; margin-top: 7px; margin-right: 0; margin-bottom: 7px;"><span style="font-family: Inter;">Locate your service in a <a href="https://en.wikipedia.org/wiki/DMZ_(computing)" target="_blank" class="weblink">DMZ</a>. Dont throw any ports or access points of the service publicly unless absolutely necessary. Comply with <a href="https://en.wikipedia.org/wiki/OWASP" target="_blank" class="weblink">OWASP</a>.</span></li><li style="line-height: 1.20; margin-top: 7px; margin-right: 0; margin-bottom: 7px;"><span style="font-family: Inter;">Preferably study the guidelines for cloud application development in this article: <a href="https://12factor.net/" target="_blank" class="weblink">The Twelve-Factor App</a>.</span></li></ul>
<div class="bottom-nav">
@ -173,7 +168,7 @@
</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>
<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>
</section>
</div>
@ -181,7 +176,7 @@
<input type="checkbox" />
<div class="article__arrow"></div>
<div class="table-of-contents elma365-right" id="toc2Content">
<h3 class="h3-toc">В этой статье</h3>
<h3 class="h3-toc">In this topic</h3>
<nav id="toc2"></nav>
</div>
</aside>
@ -192,63 +187,30 @@
<div class="footer-container">
<div class="footer-mobile">
<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>
<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>
</div>
<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 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>
</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.min.js"></script>
<script src="./jquery-ui.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>