Скрипт для автоматического применения требований назначения функциональности

15.02.22

База данных - Журнал регистрации

Под конкретную задачу потребовалось сделать скрипт, который подключается на сервере приложений 1С к предварительно созданным службам RAS, обходит все кластера 1С на этом же сервере и применяет требования назначения функциональности (далее ТНФ).

Синопсис:

Есть два сервера приложений 1С на Windows, на каждом сервере по несколько служб 1С, на каждой службе 1С по одному локальному кластеру; между двумя серверами локальные кластеры собраны в кластеры из двух центральных серверов, уровень отказоустойчивости 0.

Требование:

Поставлена задача, чтобы журнал регистрации писался только на первом сервере приложений. Все просто. И как было бы круто просто настроить на первом сервере ТНФ «Сервис журналов регистрации» с типом «Назначать», а на втором это же требование с типом «Не назначать». Но если первый сервер будет выключен, то это ТНФ убьет всю отказоустойчивость, пользователи не смогут зайти на второй сервер т.к. журнал регистрации на него запрещено писать.

Кажется, опять все просто, на первом сервере для ТНФ «Сервис журналов регистрации» нужно поставить тип «Назначать», приоритет 1; на втором сервере для ТНФ «Сервис журналов регистрации» нужно поставить тип «Назначать», приоритет 0. Тогда посте применения ТНФ журнал регистрации пишется на первый сервер, а если первый сервер выключить, то начинает писаться на второй. НО когда первый сервер будет включен то журнал регистрации так и будет писаться на второй сервер, пока снова не применить ТНФ. Вот этот момент отслеживать и тыкать руками применение не очень-то прикольно, поэтому был создан скрипт на PowerShell, который, по расписанию в планировщике Windows, обходит все кластера 1С на сервере и применяет ТНФ.

При желании скрипт можно легко переделать на применение ТНФ не для всех кластеров сервера, а для конкретного. Так же легко изменить его назначение, заменив код применяющий ТНФ на любые другие команды сервера администрирования(rac.exe –help).

Важно: 1. писал выше, но повторюсь, чтобы скрипт работал, нужно чтобы для каждой службы 1С была создана служба RAS. Как создавать службу RAS, что это такое и как ей пользоваться есть статья //infostart.ru/1c/articles/810752/, но если потребуются пояснения, примеры и т.п. то пишите в комментарии.

2. Скрипт нужно добавить в планировщик.

Всем спасибо!

Скрипт:

cls
&chcp 1251
$srv_name = Get-WmiObject -Class win32_ComputerSystem | select name
$hostras = $srv_name.name
$rasservers = gwmi win32_service -Filter "PathName like '%ras.exe%'" | select PathName #получить все службы RAS
#получить параметры служб RAS с помощью регулярных выражений
$rasmas = $rasservers | select `
    "-",
    @{N="RasPort";E={[regex]::match($_.PathName,"(?<=--port=)\d+").value}},
    @{N="BinaryPath";E={[regex]::match($_.PathName,"^.*ras.exe").value -replace "`"",""}},
    @{N="RacBin";E={([regex]::match($_.PathName,"^.*ras.exe").value -replace "`"","" -replace "ras.exe", "rac.exe")}},
    @{N="HostPort";E={("$hostras`:"+[regex]::match($_.PathName,"(?<=--port=)\d+").value)}},
    #получить id кластеров
    @{N="Clusters";E={[regex]::Matches((&([regex]::match($_.PathName,"^.*ras.exe").value -replace "`"","" -replace "ras.exe", "rac.exe") ('cluster') ("$hostras`:"+[regex]::match($_.PathName,"(?<=--port=)\d+").value) ("list")|out-string),"[0-9a-fA-F]{8}[-][0-9a-fA-F]{4}[-][0-9a-fA-F]{4}[-][0-9a-fA-F]{4}[-][0-9a-fA-F]{12}")}},
    @{N="PathName";E={$_.PathName}}
$rasmas
#обход полученных кластеров ras
foreach($ras in $rasmas){
    foreach($clust in $ras.clusters){
        $adr = ""; $adr = $ras.HostPort
        $cluster = ""; $cluster = "--cluster="+$clust.Value
        $adr
        $cluster
        #применение ТНФ
       &$ras.RacBin 'rule' $adr $cluster 'apply' --full
    }
}

скрипт ТНФ требования назначения функциональности

См. также

LogManager - Внешний журнал регистрации в SQL

Журнал регистрации Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

Журнал регистрации платформы 1С в SQL. Общая база хранения всех журналов. Через com-подключение регламентным заданием периодически догружает журналы регистраций из рабочих баз. Предоставляет настраиваемый доступ к журналам по правам подразделений. Формирует отчеты по пользователям и данным.

10000 руб.

23.05.2014    54993    51    16    

43

Мониторинг баз и серверов 1С

Журнал регистрации Мониторинг Платформа 1С v8.3 Платные (руб)

В сферу обязанностей при работе с клиентами входит контроль работы баз данных и серверов 1С. Нужно понимать что происходит в базах, есть ли ошибки, зависания у пользователей и фоновых задач, блокировки или какое-то необычное поведение системы, получение информации о причинах возникновения проблем и их оперативное устранение и т.д. В качестве источников информации использую консоль кластеров 1С, технологический журнал 1С, журналы регистрации базы 1С. Для автоматизации части операций мониторинга и анализа создал инструмент на основе 1С.

9000 руб.

28.08.2019    29697    12    21    

59

LogiCH - хранение и анализ журнала регистрации в сверхбыстрой СУБД ClickHouse

Журнал регистрации Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

Конфигурация LogiCH эффективно решает проблему хранения и анализа записей журналов регистрации. Разработка использует столбцовую СУБД ClickHouse, одну из самых быстрых Big Data OLAP СУБД. Любой анализ журнала можно выполнить в одном отчете, в котором доступны все возможности СКД с учетом ограничений RLS. Количество подключаемых баз не ограничено и не влияет на скорость построения анализа.

5000 руб.

28.11.2018    19248    13    6    

35

Магия преобразований: ЖР, ТЖ, RAS/RAC, логи - универсальное решение Vector

Мониторинг Журнал регистрации Технологический журнал Абонемент ($m)

Как легко и быстро с помощью специализированных решений собирать, парсить и передавать логи и метрики.

1 стартмани

13.11.2023    1843    2    AlexSTAL    0    

33

Мониторинг состояния с отправкой в telegram

Журнал регистрации Инструменты администратора БД Мониторинг Мессенджеры и боты Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Управление холдингом 1С:Комплексная автоматизация 2.х Абонемент ($m)

Внешняя обработка для БСП-конфигураций с простым программным интерфейсом. Предназначена для мониторинга состояния системы. Базово реализована отправка ошибок из журнала регистрации, но можно легко добавить мониторинг других журналов, каких-либо действий пользователей, состояния системы (например закрытие месяца).

3 стартмани

26.09.2023    1203    5    doom2good    10    

11

История фоновых заданий

Журнал регистрации Статистика базы данных HighLoad оптимизация Конфигурации 1cv8 Абонемент ($m)

Удобный отчет по выполнению фоновых заданий в 1С с разбивкой по разным критериям, например по срокам, в какой последовательности, выполнение дольше всех, сколько одновременно и так далее.

5 стартмани

04.09.2023    445    5    Maxiko    0    

7

Перенаправление вывода журнала регистрации

Linux Журнал регистрации Платформа 1С v8.3 Бесплатно (free)

Экспериментируем с реализацией драйвера текстового устройства под Linux для перенаправления вывода журнала регистрации.

07.08.2023    997    Lars Ulrich    1    

16

Переносим все логи в журнал регистрации – реально ли и зачем?

Журнал регистрации Бесплатно (free)

Логирование позволяет иметь четкую картину о работе информационной системы: мониторить ошибки, отслеживать состояние обменов, детально изучать отладочную информацию в нагруженной системе, не включая отладку. О том, какие пределы производительности можно достичь с помощью журнала регистрации 1С и как на нем организовать единое решение по логированию, пойдет речь в статье.

25.07.2023    2492    skovpin_sa    9    

30
Оставьте свое сообщение