К основному контенту

Подключение к Oracle при работающем Data Guard

Метод организации подключения пользователей к БД работающей в режиме ACTIVE DATA GUARD.

Не актуален при использовании GRID Infrastructure.

1. Создание служб.

Для пользователей будут созданы службы(service), которые будут включаться в зависимости от режима работы базы.
  • prod - база находится в режиме PRIMARY, разрешены запись и чтение.
  • read - база в режиме PHYSICAL STANDBY, доступна только для чтения.
  • snap - режим SNAPSHOT STANDBY, разрешены запись и чтение, но после конвертации в PHYSICAL STANDBY все изменения будут отменены
execute dbms_service.create_service(
                   service_name=>'prod',
                   network_name=>'prod');

Остальные службы создаются аналогично.

2. Создание триггера для запуска служб при изменении состояния сервера.
Триггер будет срабатывать после запуска/перезапуска базы и в зависимости от роли
будет запускать необходимую службу.

CREATE or REPLACE TRIGGER client_connection AFTER startup ON DATABASE
DECLARE
    DB_ROLE V$DATABASE.DATABASE_ROLE%TYPE;
    OMODE V$DATABASE.OPEN_MODE%TYPE;
BEGIN
     SELECT DATABASE_ROLE INTO DB_ROLE FROM V$DATABASE;
     SELECT OPEN_MODE INTO OMODE FROM V$DATABASE;
     IF DB_ROLE = 'PRIMARY' THEN
       DBMS_SERVICE.START_SERVICE ('prod');
     DBMS_SERVICE.STOP_SERVICE ('read');
     ELSIF DB_ROLE = 'PHYSICAL STANDBY' AND OMODE = 'READ ONLY' THEN
         DBMS_SERVICE.START_SERVICE ('read');
     ELSIF DB_ROLE = ‘SNAPSHOT STANDBY’ AND OMODE = 'READ WRITE' THEN
     DBMS_SERVICE.START_SERVICE ('snap');
    DBMS_SERVICE.STOP_SERVICE ('read');
  END IF;
END;

3. Принудительный запуск службы.

EXECUTE DBMS_SERVICE.START_SERVICE(SERVICE_NAME=>'<SERVICE>');

4. Пример tnsnames файла.
В зависимости от указанной службы сессии будут направляться на сервер, на котором эта служба в данный момент работает.

prod =
  (DESCRIPTION =
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = TCP)(HOST = server1)(PORT = 1521))
      (ADDRESS = (PROTOCOL = TCP)(HOST = server2)(PORT = 1521))
      (load_balancing=no)
    )
    (CONNECT_DATA =
      (SERVICE_NAME = prod)
        (FAILOVER_MODE =
        (TYPE = SELECT)
        (METHOD = BASIC)
        (RETRIES = 180)
        (DELAY = 5)
     )
    )
  )

Комментарии

Популярные сообщения из этого блога

Установка и настройка pgAgent(планировщика заданий PostgreSQL)

Установка pgAgent Последняя версия скрипта для установки агента  тут . Перенести инструкцию по агенту в отдельную тему. 1. Создать пользователя ОС, и сделать ему домашний каталог: useradd -s /bin/false -r -M pgagent mkdir /home/pgagent 2. Установить и настроить демон: yum install pgagent_94 При наличии ошибок вида (была на Oracle Linux 6.8) Error: Package: pgagent_94-3.4.0-1.rhel6.x86_64 (pgdg94)            Requires: libwx_baseu-2.8.so.0(WXU_2.8)(64bit) Нужно установить EPEL systemctl enable pgagent_94 chown pgagent:pgagent /var/log/pgagent_94.log 3. Установить схему агента в базе: sudo -u postgres psql -f /usr/share/pgagent_94-3.4.0/pgagent.sql postgres 4. Создать файл паролей для подключения агента к базе. vi /home/pgagent/.pgpass localhost:5432:*:postgres:postgres chown pgagent.pgagent /home/pgagent -R chmod 600 /home/pagent/.pgpass 5. Запустить и проверить работу агента systemctl start pgagent_94.service systemctl status pga

Включение логирования для Haproxy

Изначально логирование в syslog в HaProxy отключено. Ниже пример настройки логирования для ОС Centos 7. Настройка: Добавить строку  log 127.0.0.1 local2 в секцию global файла /etc/haproxy/haproxy.cfg Раскомментировать $ModLoad imudp и $UDPServerRun 514 в файле  /etc/rsyslog.conf Создать файл  /etc/rsyslog.d/haproxy.conf со следующим содержимым:  local2.* /var/log/haproxy.log Перезапустить rsyslog и haproxy.

Использование oraenv для установки окружения.

Для настройки окружения в Linux можно все параметры базы указать в .bash_profile: ORACLE_HOME=/app/oracle/product/11.2.0.4/dbhome_1 export ORACLE_HOME ORACLE_BASE=/app/oracle export ORACLE_BASE ORACLE_SID=orcl export ORACLE_SID PATH=$PATH:$HOME/bin:$ORACLE_HOME/bin export PATH Но лучше использовать для этих целей утилиту oraenv. oraenv берет данные из файла /etc/oratab orcl:/app/oracle/product/12.1.0/dbhome_1:N И на ее основе задает параметры окружения: ORACLE_SID, ORACLE_BASE,ORACLE_HOME и PATH Использовать можно в интерактивном режиме: . oraenv ORACLE_SID = [orcl] ? orcl The Oracle base has been set to /app/oracle И в неинтерактивном режиме. Добавить в  .bash_profile: ORACLE_SID=orcl ORAENV_ASK=NO . oraenv Для ASM ситуация аналогичная. . oraenv ORACLE_SID = [orcl] ? +ASM1 The Oracle base has been set to /u01/app/oracle echo $ORACLE_HOME /app/11.2.0/grid