Работа 1С в режиме 24/7 с http-сервисами
Коллеги.
Столкнулся с необходимостью создать решение на 1С 8, которое будет работать
1) 24/7 без перерывов.
2) без существенных просадок времени отклика http-сервисов.
1С 8.3.2х, винда, MS SQL, IIS. Все это в VM на базе Proxmox, все это на серверном железе в ЦОД.
Разнесено по разным сервакам по факту, меж ними 10Гб локалка, не существенно.
Как реализовать инфраструктуру правильно, чтобы контрагенты с жесткими требованиями к даунтайму и времени отклика пользовали мой http-сервис 24/7,
но я при этом мог и обновляться, и индексы пересчитывать, и ОС обновлять, и платформу и любые работы проводить?
P.S. Ценой можно пренебречь. Любые серверы, любые лицензии КОРП и т.п.
Столкнулся с необходимостью создать решение на 1С 8, которое будет работать
1) 24/7 без перерывов.
2) без существенных просадок времени отклика http-сервисов.
1С 8.3.2х, винда, MS SQL, IIS. Все это в VM на базе Proxmox, все это на серверном железе в ЦОД.
Разнесено по разным сервакам по факту, меж ними 10Гб локалка, не существенно.
Как реализовать инфраструктуру правильно, чтобы контрагенты с жесткими требованиями к даунтайму и времени отклика пользовали мой http-сервис 24/7,
но я при этом мог и обновляться, и индексы пересчитывать, и ОС обновлять, и платформу и любые работы проводить?
P.S. Ценой можно пренебречь. Любые серверы, любые лицензии КОРП и т.п.
По теме из базы знаний
- Выгрузка-загрузка любых данных из 1С (и измененных) в XML между похожими конфигурациями (ФАЙЛ, HTTP, COM) ЛЮБЫХ баз 1С 8.1-8.3 с обработкой и поиском данных по произвольным полям поиска
- Облачные кассы и 1С. Интеграция, которой не было
- Многопоточный CI-контур для 1С c Packer, Vagrant и Jenkins. Часть 1. Описание системы и обзор инструментария
- 1С:Аналитика как BI-система: обзор инструмента и кейсы внедрения в IT-компании
- NativeAPI – это (не) страшно. Как и зачем мы используем websocket в EmplDocs
Ответы
Подписаться на ответы
Инфостарт бот
Сортировка:
Древо развёрнутое
Свернуть все
(3) Ничего не изменилось у 1Сников за за последние 20 лет. Как на Мисте давали непрошенные советы, так и продолжают.
Если бы я хотел go, я бы не писал на Инфостарт.
Интересуют решения на 1С, работающие без перерыва, но имеющие возможнось проведения при этом регламентных работ любого уровня
Если бы я хотел go, я бы не писал на Инфостарт.
Интересуют решения на 1С, работающие без перерыва, но имеющие возможнось проведения при этом регламентных работ любого уровня
(7) Варианты:
1) Создать миниатюрную базу, в которой и реализовать все нужные сервисы
2) Сделать то же самое (миниатюрную базу) в 1С:Элемент, или его подмножестве 1С:Шина
Сами 1С-ники в аналогичной ситуации пошли по второму варианту. Делают как раз на "Элемент" (например, developer.1c.ru )
1) Создать миниатюрную базу, в которой и реализовать все нужные сервисы
2) Сделать то же самое (миниатюрную базу) в 1С:Элемент, или его подмножестве 1С:Шина
Сами 1С-ники в аналогичной ситуации пошли по второму варианту. Делают как раз на "Элемент" (например, developer.1c.ru )
Временные интервалы зависят от объема данных, конфигурации, железа и как пойдет.
Предположим такая инфраструктура и три подхода на выбор:
Серверы 1С - для параллельного кластера требуется минимум два сервера приложений в каждом кластере (основной и параллельный), что в сумме дает четыре сервера.
Конфигурация каждого сервера:
CPU: 8-16 ядер.
RAM: 32-64 ГБ.
Диск: SSD или NVMe объемом 500 ГБ и более.
Серверы баз данных (MS SQL) - настроенные в режиме Always On Availability Groups, чтобы обеспечить высокую доступность и репликацию данных.
Конфигурация:
CPU: 16-32 ядер.
RAM: 128 ГБ и выше.
Диск: высокопроизводительное NVMe-хранилище объемом 500 ГБ и более.
Серверы IIS - необходимо 2-4 узла для параллельной обработки запросов и балансировки нагрузки.
Конфигурация:
CPU: 4-8 ядер.
RAM: 16-32 ГБ.
Диск: SSD объемом 100 ГБ.
Серверы виртуализации (Proxmox) - для размещения виртуальных машин 1С, SQL и IIS с поддержкой высокой доступности.
Конфигурация каждого узла:
CPU: 16-32 ядер.
RAM: 128-256 ГБ.
Диск: SSD или NVMe на 1 ТБ и более.
Подходы (архитектура):
1. Создается параллельный кластер 1С с новой версией платформы, который работает вместе с текущим (подробнее: Blue-Green Deployment). После настройки и синхронизации данных с основной базой данных, переключение трафика на новый кластер позволяет обновить систему без остановок.
Процесс:
Настраивается второй кластер с новой версией 1С (приложение и IIS).
Базы данных синхронизируются, например, через SQL Always On Availability Group, чтобы параллельный кластер имел актуальные данные.
После тестирования нового кластера балансировщик переключает трафик на него, после чего старый кластер можно отключить.
Временные интервалы:
Развертывание параллельного кластера занимает от 2 до 6 часов, но этот процесс можно выполнить заранее.
Репликация данных в режиме Always On происходит в реальном времени.
Само переключение занимает 10-30 минут.
2. Обновление с дублирующим контуром (Ночное обновление)
Тут используется тестовый сервер, на котором проводится подготовка и тестирование обновлений. Само обновление выполняется ночью на основном кластере, чтобы минимизировать простой.
Процесс:
На тестовом сервере проводится тестирование обновлений.
В ночное время текущий кластер отключается и обновляется, а затем запускается обновленная версия.
Отключение и обновление кластера (платформа, конфигурация, перезапуск) занимают от 2 до 4 часов.
Временные интервалы:
Подготовка и тестирование занимают от 1 до 3 часов.
Сам процесс обновления с остановкой кластера — от 2 до 4 часов, если сделано заранее.
3. Мультикластерная архитектура. Включает несколько кластеров 1С, каждый из которых работает с общей базой данных, с применением технологий репликации данных. Это позволяет обновлять один кластер, пока другой продолжает обрабатывать запросы.
Процесс:
На начальном этапе разворачиваются два кластера 1С с поддержкой синхронизации данных (например, с использованием SQL Always On).
Обновление проходит поэтапно, при этом отключается и обновляется только один кластер, в то время как другой продолжает работу.
Временные интервалы:
Настройка занимает больше времени (от 6 до 12 часов для всей системы), однако дальнейшее обновление каждого кластера будет занимать 1-2 часа.
***
Малый объем данных (до 100 ГБ): базу можно поддерживать на серверах с 8 ядрами CPU и 32 ГБ RAM. Рекомендуется использовать один кластер с регулярным ночным обновлением.
Средний объем данных (от 100 до 500 ГБ): потребуется кластеризация с SQL Always On и распределение серверов приложений, IIS и балансировщиков. Это обеспечит высокую отказоустойчивость и производительность.
Крупный объем данных (от 500 ГБ): для поддержания скорости и отказоустойчивости потребуется мультикластерная архитектура или Blue-Green Deployment с высокой мощностью серверов и отказоустойчивым хранилищем.
Предположим такая инфраструктура и три подхода на выбор:
Серверы 1С - для параллельного кластера требуется минимум два сервера приложений в каждом кластере (основной и параллельный), что в сумме дает четыре сервера.
Конфигурация каждого сервера:
CPU: 8-16 ядер.
RAM: 32-64 ГБ.
Диск: SSD или NVMe объемом 500 ГБ и более.
Серверы баз данных (MS SQL) - настроенные в режиме Always On Availability Groups, чтобы обеспечить высокую доступность и репликацию данных.
Конфигурация:
CPU: 16-32 ядер.
RAM: 128 ГБ и выше.
Диск: высокопроизводительное NVMe-хранилище объемом 500 ГБ и более.
Серверы IIS - необходимо 2-4 узла для параллельной обработки запросов и балансировки нагрузки.
Конфигурация:
CPU: 4-8 ядер.
RAM: 16-32 ГБ.
Диск: SSD объемом 100 ГБ.
Серверы виртуализации (Proxmox) - для размещения виртуальных машин 1С, SQL и IIS с поддержкой высокой доступности.
Конфигурация каждого узла:
CPU: 16-32 ядер.
RAM: 128-256 ГБ.
Диск: SSD или NVMe на 1 ТБ и более.
Подходы (архитектура):
1. Создается параллельный кластер 1С с новой версией платформы, который работает вместе с текущим (подробнее: Blue-Green Deployment). После настройки и синхронизации данных с основной базой данных, переключение трафика на новый кластер позволяет обновить систему без остановок.
Процесс:
Настраивается второй кластер с новой версией 1С (приложение и IIS).
Базы данных синхронизируются, например, через SQL Always On Availability Group, чтобы параллельный кластер имел актуальные данные.
После тестирования нового кластера балансировщик переключает трафик на него, после чего старый кластер можно отключить.
Временные интервалы:
Развертывание параллельного кластера занимает от 2 до 6 часов, но этот процесс можно выполнить заранее.
Репликация данных в режиме Always On происходит в реальном времени.
Само переключение занимает 10-30 минут.
2. Обновление с дублирующим контуром (Ночное обновление)
Тут используется тестовый сервер, на котором проводится подготовка и тестирование обновлений. Само обновление выполняется ночью на основном кластере, чтобы минимизировать простой.
Процесс:
На тестовом сервере проводится тестирование обновлений.
В ночное время текущий кластер отключается и обновляется, а затем запускается обновленная версия.
Отключение и обновление кластера (платформа, конфигурация, перезапуск) занимают от 2 до 4 часов.
Временные интервалы:
Подготовка и тестирование занимают от 1 до 3 часов.
Сам процесс обновления с остановкой кластера — от 2 до 4 часов, если сделано заранее.
3. Мультикластерная архитектура. Включает несколько кластеров 1С, каждый из которых работает с общей базой данных, с применением технологий репликации данных. Это позволяет обновлять один кластер, пока другой продолжает обрабатывать запросы.
Процесс:
На начальном этапе разворачиваются два кластера 1С с поддержкой синхронизации данных (например, с использованием SQL Always On).
Обновление проходит поэтапно, при этом отключается и обновляется только один кластер, в то время как другой продолжает работу.
Временные интервалы:
Настройка занимает больше времени (от 6 до 12 часов для всей системы), однако дальнейшее обновление каждого кластера будет занимать 1-2 часа.
***
Малый объем данных (до 100 ГБ): базу можно поддерживать на серверах с 8 ядрами CPU и 32 ГБ RAM. Рекомендуется использовать один кластер с регулярным ночным обновлением.
Средний объем данных (от 100 до 500 ГБ): потребуется кластеризация с SQL Always On и распределение серверов приложений, IIS и балансировщиков. Это обеспечит высокую отказоустойчивость и производительность.
Крупный объем данных (от 500 ГБ): для поддержания скорости и отказоустойчивости потребуется мультикластерная архитектура или Blue-Green Deployment с высокой мощностью серверов и отказоустойчивым хранилищем.
(17)
Итак, что в сухом остатке.
1. На 4 сервера приложений надо иметь 4 доп. лицензии на сервер, как решается это вопрос?
(17)
Тут понятно, берём полностью настроенную новую версию и перенаправляем на неё.
(17)
Ммм, а как обновляется резервный кластер?
Поясните.
(17)
Тут, получается, что из 4-х серверов приложений, 1-2 часа будут работать только 2 сервера, в принципе терпимо, если под "ночью" подразумевается 1-2 часа низкой нагрузки, если такая есть.
Серверы 1С - для параллельного кластера требуется минимум два сервера приложений в каждом кластере (основной и параллельный), что в сумме дает четыре сервера.
Итак, что в сухом остатке.
1. На 4 сервера приложений надо иметь 4 доп. лицензии на сервер, как решается это вопрос?
(17)
1. Создается параллельный кластер 1С с новой версией платформы,
Тут понятно, берём полностью настроенную новую версию и перенаправляем на неё.
(17)
2. Обновление с дублирующим контуром (Ночное обновление)
Ммм, а как обновляется резервный кластер?
Поясните.
(17)
3. Мультикластерная архитектура.
Тут, получается, что из 4-х серверов приложений, 1-2 часа будут работать только 2 сервера, в принципе терпимо, если под "ночью" подразумевается 1-2 часа низкой нагрузки, если такая есть.
1. Изначально финансовых ограничений не предусматривалось, на эту тему можно отдельную статью написать, т.к. есть разные подходы, чтобы оптимизировать затраты на лицензии, Вообще в кластере с несколькими серверами приложений лицензия на сервер платформы обычно нужна только для одного основного серверного узла, который управляет кластером, а остальные серверы в роли серверов рабочих процессов используют лицензии этого основного узла. Еще вариант, можно использовать редакцию корп.
2. Тоже отдельная тема. Примерно делается это так:
Создается копия основного кластера 1С с актуальной базой данных через репликацию SQL. Синхронизация и обновление данных временно приостанавливается, после чего на резервный кластер устанавливается новая версия платформы и обновляется конфигурация. После успешного обновления резервный кластер становится основным. Балансировщик направляет пользователей на него. Бывший основной кластер обновляется и снова синхронизируется, становясь резервным.
3. Да, именно так. При мультикластерной архитектуре 1-2 сервера можно отключить для обновления, в то время как оставшиеся продолжают обрабатывать запросы. Это позволяет поддерживать работу системы с минимальными потерями производительности.
Если низкая нагрузка действительно приходится на определенные ночные часы, то временная работа на двух серверах не скажется на качестве обслуживания. По завершении обновления первый кластер возвращается в строй, и затем обновляется второй кластер, сохраняя 24/7 доступность без полной остановки системы.
2. Тоже отдельная тема. Примерно делается это так:
Создается копия основного кластера 1С с актуальной базой данных через репликацию SQL. Синхронизация и обновление данных временно приостанавливается, после чего на резервный кластер устанавливается новая версия платформы и обновляется конфигурация. После успешного обновления резервный кластер становится основным. Балансировщик направляет пользователей на него. Бывший основной кластер обновляется и снова синхронизируется, становясь резервным.
3. Да, именно так. При мультикластерной архитектуре 1-2 сервера можно отключить для обновления, в то время как оставшиеся продолжают обрабатывать запросы. Это позволяет поддерживать работу системы с минимальными потерями производительности.
Если низкая нагрузка действительно приходится на определенные ночные часы, то временная работа на двух серверах не скажется на качестве обслуживания. По завершении обновления первый кластер возвращается в строй, и затем обновляется второй кластер, сохраняя 24/7 доступность без полной остановки системы.
Для получения уведомлений об ответах подключите телеграм бот:
Инфостарт бот