
У нас 1С развёрнут на Linux и PostgreSQL. Всё началось с запроса клиента на развёртывание 1С в Linux-среде. Мы создали первый кластер, а затем перевели всю облачную 1С на open source.
В этой статье расскажем о нашем пути, сложностях и результатах. Больше подробностей об особенностях работы облачной 1С вы узнаете на вебинаре — запись эфира открыта по ссылке.
Термины, используемые в статье
Remote Administration Server / Remote Administration Client (RAS/RAC)
Утилита для удалённого администрирования кластера серверов 1С, которая позволяет управлять им из командной строки или с помощью скриптов.
Multi-factor authentication (MFA)
Многофакторная аутентификация — метод контроля доступа, при котором для входа в систему требуется предоставить два или более независимых фактора подтверждения личности.
pgAdmin
Инструмент с графическим интерфейсом для управления базами данных PostgreSQL.
pg_dump / pg_basebackup
Инструменты для создания резервных копий базы данных PostgreSQL.
SQL Server Management Studio (SSMS)
Интегрированная среда для управления любой инфраструктурой SQL.
IIS и Apache
Веб-серверы; IIS является проприетарным решением Microsoft для Windows, а Apache — кроссплатформенным open-source проектом.
SSO (Single Sign-On)
Метод аутентификации, позволяющий пользователю получить доступ к нескольким приложениям или системам после однократного ввода учётных данных.
Linux для 1С: современные тенденции
Исторически Linux не был популярной платформой для серверов 1С. Этому есть несколько причин:
Квалификация администраторов
Развёртывание и поддержка 1С на Windows проще, чем на Linux. К тому же для Windows существует больше инструкций и руководств по решению проблем.
Сложность настройки
Сервер баз данных PostgreSQL, который часто используется с 1С в Linux-средах, требует нетривиальной настройки для оптимальной работы, что создавало дополнительные барьеры для внедрения.
Производительность
Раньше считалось, что работа 1С в среде Linux может вызывать проблемы с производительностью. Однако сейчас появились оптимизированные решения, которые демонстрируют повышенную эффективность при работе с типовыми задачами 1С. Например, Postgres Pro увеличивает производительность баз 1С на 25–30%.
Хотя решение пока не стало массовым, интерес к Linux-решениям для 1С стабильно растёт — особенно среди организаций с повышенными требованиями к безопасности и надёжности ИТ-инфраструктуры. Кроме того, дополнительными драйверами миграции стали сложности с лицензированием, требования импортозамещения, возможность полного размещения инфраструктуры на российских ОС.
Основные преимущества перехода на Linux
Linux в большинстве случаев не требует лицензионных отчислений и лучше подходит для масштабирования и автоматизации. Последнее особенно важно при быстром и массовом развёртывании услуг: с помощью скриптов и современных инструментов, вроде Docker, Kubernetes и Ansible, можно автоматизировать большинство задач, которые раньше выполнялись вручную.
1С полностью поддерживает работу в Linux — как серверную, так и клиентскую часть. Поддержка была добавлена ещё в версиях 8.3.х, а в современных релизах стала стабильной и полнофункциональной.
Среди поддерживаемых операционных систем — Ubuntu, Debian, CentOS, а также отечественные дистрибутивы Linux.
Кроме того, 1С поддерживает СУБД PostgreSQL, что обеспечивает дополнительную гибкость и помогает сократить затраты.
Опыт развёртывания кластера 1С на Linux
Ранее мы создали «Защищённый 1С-хостинг» и планировали перевести пользователей со старой платформы на новую. В ходе этого процесса мы также произвели миграцию с переходом на Linux.
На первом этапе мы развернули кластер из двух серверов на Ubuntu: первый для сервера приложений 1С, второй — для PostgreSQL.
При настройке системы нам пришлось осваивать новые подходы к администрированию. В отличие от Windows с её графическим интерфейсом, в Linux большинство операций выполняется через командную строку. Например, кластер серверов 1С управляется утилитами RAS и RAC через терминал, тогда как в Windows для этого есть графический интерфейс.
Основная проблема, с которой мы столкнулись: при клонировании ВМ сервера приложений 1С информация о кластере сохранялась, и в консоли администрирования отображалось старое имя. Поскольку переименовать кластер невозможно, пришлось полностью удалять его и создавать новый. В Windows эта операция выполняется в несколько кликов, а в Linux потребовала дополнительного изучения.
Реализация доступа к конфигуратору 1С через Linux
Кроме серверной части, нужно было обеспечить работу в Linux для пользователей, которым нужен доступ к конфигуратору 1С.
Стандартно мы предоставляем доступ к 1С через браузер или тонкий клиент по HTTPS, но конфигуратор в этом режиме не работает — ему нужен прямой доступ к серверу приложений через толстый клиент. Для этого клиенту приходится подключаться к терминальному серверу внутри тенанта хостинга и уже оттуда запускать толстый клиент 1С.
Сначала мы попробовали развернуть графический интерфейс на стандартном сервере Ubuntu, но столкнулись с проблемой: 1С выдавала ошибку нехватки памяти, хотя её было достаточно. Увеличение ресурсов не помогло — приложение не запускалось, несмотря на официальную поддержку этой ОС со стороны 1С.
Решение нашли с помощью десктопной версии Ubuntu 22.04 LTS с предустановленным графическим интерфейсом. На более новой версии 24.04 запустить 1С не получилось — вероятно, из-за того, что поддержку добавили только в последних версиях платформы 1С.
В итоге клиентская часть с графическим интерфейсом заработала. Хотя Linux выглядит непривычно, функциональность 1С полностью сохранилась: программа выглядит и работает так же, как и в Windows.
Сравнение подходов к резервному копированию в MS SQL и PostgreSQL
При миграции мы столкнулись с особенностями создания резервных копий баз данных 1С.
В Microsoft SQL Server используется гибкая система: можно создавать полные бэкапы (например, раз в неделю) и инкрементальные (ежедневно), которые сохраняют только изменения с момента последнего полного копирования, что экономит дисковое пространство.
В PostgreSQL инструмент pg_dump создаёт резервные копии отдельных баз, но не поддерживает инкрементальное копирование. Инструмент pg_basebackup поддерживает инкрементальные бэкапы, но создаёт копию всего кластера, то есть всех БД в инстансе.
Для решения этой пр��блемы в PostgreSQL мы экспериментировали с разными методами резервного копирования и восстановления. В результате процесс удалось автоматизировать скриптами, и теперь он работает стабильно, хотя MS SQL остаётся более удобным решением.
Кроме того, pgAdmin (инструмент администрирования PostgreSQL) уступает по функциональности SQL Server Management Studio, который предоставляет более комплексные средства управления базами данных.
Проблема с локалью при миграции на Linux
При миграции мы обнаружили неочевидную проблему — некорректную настройку русскоязычной локали в ОС. При создании базы данных 1С возникала ошибка о несовместимости языковых настроек. Причина заключалась в том, что локаль либо не была установлена, либо была настроена некорректно.
Проблему решили чистой установкой ОС с выбором русского языка как основного при инсталляции.
Публикация баз на веб-сервере Apache в Linux
Отдельно стоит упомянуть публикацию баз: в Windows мы использовали веб-сервер IIS, а в Linux перешли на Apache.
Настройка Apache не вызвала сложностей — процесс оказался простым и хорошо автоматизируется. Публикация базы выполняется несколькими командами, которые легко прописать в скрипты для полуавтоматического развёртывания.
Развёртывание VPN-сервера с поддержкой MFA и SSO
Нам нужно было развернуть собственный VPN-сервер для подключения пользователей к терминальным серверам. На предыдущей платформе использовался SSL VPN, который был встроен в сам тенант, однако в новой версии этот инструмент отсутствует. К тому же он не поддерживал многофакторную аутентификацию (MFA).
Мы решили проблему, развернув OpenVPN на Ubuntu. Это позволило реализовать не только MFA, но и единый вход (SSO) для авторизации в 1С. Последняя функция особенно важна для заказчиков, которые хотят интегрировать вход в 1С с помощью собственного домена.
Сравнение требований к ресурсам: Windows vs Linux
Linux менее требователен к ресурсам, чем альтернативные ОС. Windows Server не может стабильно работать на конфигурациях с одним ядром процессора и 1 ГБ оперативной памяти, тогда как Ubuntu успешно функционирует даже в таких условиях. Как результат, сокращаются эксплуатационные расходы и эффективнее распределяются вычислительные мощности.
При этом серверная часть 1С остаётся ресурсоёмкой. Даже для небольшого количества пользователей (до 10 человек) рекомендуется не менее 8 ГБ оперативной памяти, а при активной работе может потребоваться больше.
С ростом мощности сервера разница в потреблении ресурсов между ОС становится менее заметной, поскольку основную нагрузку создаёт сама 1С, а не операционная система.
Субъективно система на Linux работает быстрее, но универсального бенчмарка для 1С в этой среде не существует — доступные инструменты дают лишь приблизительную оценку. Например, тест Гилёва имеет серьёзные ограничения: некоторые операции 1С выполняются только на одном ядре. Качественное тестирование требует индивидуальной настройки под конкретную базу данных и задачи.
Кроме того, проблемы производительности часто возникают из-за неоптимальных запросов, которые программисты пишут для бухгалтерских задач. Каждый такой случай требует сложной индивидуальной диагностики и высокой квал��фикации специалистов.
Заключение
С точки зрения программиста или администратора 1С, работающего с клиентской частью (конфигуратором, консолью управления), разницы между платформами практически нет.
Пользователь запускает привычные инструменты в Windows, указывает адрес сервера и имя базы данных, не задумываясь о том, какая операционная система работает на серверной стороне.
Однако администрирование серверной части на Linux требует специальных знаний: работы с командной строкой, написания скриптов и понимания особенностей ОС, что создаёт сложности на начальном этапе.
Ключевое преимущество Linux — возможности тонкой настройки и автоматизации:
Командная строка и скрипты позволяют эффективно автоматизировать развёртывание и управление системами, включая интеграцию с Kubernetes для автоматического масштабирования и запуска новых серверов в несколько кликов.
Можно внедрить инструменты, которые в реальном времени добавляют или уменьшают процессорные мощности и объём оперативной памяти на серверах без их остановки. Функция особенно полезна для клиентов с сезонной нагрузкой, такой как формирование отчётности или закрытие учётных периодов. В такие моменты система автоматически выделяет дополнительные ресурсы, что позволяет избежать переплаты за постоянно зарезервированные мощности.
Хотя поначалу Linux кажется «чёрным ящиком» для Windows-админов, но после освоения — сплошные плюсы.
Ссылки на дополнительные материалы:
Системные требования «1С:Предприятия 8»
Postgres Pro Enterprise для 1С (преимущества редакции СУБД для 1C)
Смотрите запись вебинара «7 неудобных вопросов к облачным 1С»
