Вызов 32-bit внешних процедур из PL/SQL на Oracle 11g R2 64-bit

в 13:01, , рубрики: oracle, oracle 11.2, oracle 11g, метки: , ,

Сразу скажу, что теперь можно одновременно использовать как 32 так и 64 разрядные внешние процедуры, а разобравшись в проблеме конфигурирование выполняется весьма несложно.

Столкнувшись с необходимостью организовать работу библиотек используемых ранее на 32 разрядом Oracle обнаружил, что в новой версии Oracle данный аспект сильно изменен в отличие от предшествующих версий.


Конфигурирование было выполнено для следующих компонентов:
• Windows 2008 R2 64-bit
• Oracle 11g R2 64-bit
• Oracle Instance Client 11.2.0.2 32-bit

Вот перечень некоторых отличий настройки от предшествующих версий Oracle:
• extproc32.exe – теперь не используется;
• оснастку Instance Client теперь необходимо устанавливать в отдельный ORACLE_HOME;
• появился новый конфигурационный файл настройки extproc — %ORACLE_HOME%hsadminextproc.ora;
• файлы логов LISTNER размещаются в — %ORACLE_HOME%diagtnslsnr[hostname].

Приступим к настройке Oracle

Первое, что необходимо сделать – выполнить выборочную установку 32-bit Oracle Instance Client. Достаточно выбрать для установки: Oracle Database Utilities и Oracle Net Listener. В качестве пути установки я установил: [диск]:oracleproduct11.2.0client_32. В завершении установки автоматически будет запущен Net Configuration Assistant – которым, рекомендуется воспользоваться, что бы избежать впоследствии возможных ошибок, как например использование утилиты netca, которая будет запущена для конфигурирования прослушивателя (LISTNER) из ORACLE_HOME по умолчанию, а он окажется 64-разрядный.

Опишу процесс настройки нового прослушивателя через Net Configuration Assistant:

• В окне конфигурации выбрать пункт: Listener configuration и далее
• Выбрать Add и далее
• Задать имя LISTENER_32 и далее
• Из колонки Selected Protocols убрать протокол TCP и добавить протокол IPC и далее
• Ввести в поле IPC Key value: IPC_EXT32 и далее
• Отказаться от конфигурирования другого прослушивателя и далее, далее, готово

После завершения работы Net Configuration Assistant, можно проверить сформировавшийся файл конфигурации прослушивателя %ORACLE_HOME%client_32NETWORKADMINlistener.ora, выглядеть он должен так, как указано в примере, разве что за исключением пути до директории Oracle:

LISTENER_32 =
  (DESCRIPTION_LIST =
    (DESCRIPTION =
      (ADDRESS = (PROTOCOL = IPC)(KEY = IPC_EXT32))
      (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC))
    )
  )

SID_LIST_LISTENER_32 =
  (SID_LIST =
    (SID_DESC =
      (SID_NAME = callout32)
      (ORACLE_HOME = [диск]:oracleproduct11.2.0client_32)
      (PROGRAM = extproc)
    )
  )

ADR_BASE_LISTENER_32 = [диск]:oracle

В завершении конфигурации прослушивателя необходимо сконфигурировать сервисы, выполнив, например, services.msc. Вновь созданный прослушиватель, по умолчанию не запускается автоматически, что логично будет исправить.
В том числе, нужно дополнить файл конфигурации tnsnames.ora, причем это можно сделать в основном инстансе установленной БД, например: %ORACLE_HOME%dbhome_1NETWORKADMINtnasnames.ora. Файл конфигурации необходимо дополнить следующей записью:

extproc_connection_data32b =
     (DESCRIPTION =
        (ADDRESS = (PROTOCOL = IPC)(KEY = IPC_EXT32))
        (CONNECT_DATA =
        (SID = callout32)
        )
     )

Последнее, о чем стоит упомянуть в описании системной конфигурации – это новый файл конфигурации extproc.ora. Данный файл необходимо сконфигурировать как в 32-bit, так и в 64-bit инстансах Oracle. Конфигурационный файл, оснащен вполне исчерпывающим описанием конфигурации, и я лишь приведу пример настройки. Самое простое, это указать значение параметра EXTPROC_DLLS=ANY; либо указать точный путь, используя опцию ONLY:[MY_PATHmy.dll].

Особенности конфигурирования библиотеки Oracle

Для 64-bit библиотек всё остается, без каких либо изменений, но для указания Oracle, какие библиотеки необходимо запустить, используя 32-bit extproc, необходимо создать символическую ссылку и переконфигурировать скрипт создания библиотеки.

Создадим символическую ссылку:

CREATE DATABASE LINK AGENT_LINK_32B USING 'extproc_connection_data32b';

Используя пример, изменим скрипт создания объекта библиотеки:

CREATE OR REPLACE LIBRARY MY_SCHEMA.MY_NAME IS '[диск]:oracleproduct11.2.0client_32BINmy.dll' AGENT ‘agent_link_32b’;

На этом особенности конфигурировния библиотек заканчиваются.

Настройка переменных окружения

Я не выполнял тестирования с использованием переменных окружения, таких как TNS_ADMIN, ORACLE_HOME, LD_LIBRARY_PATH и прочих. В моем случае в переменных окружения они отсутствуют, а переменная окружения Path содержит последовательно путь до 64-bit инстанса базы данных, а затем до 32-bit инстанс клиента.

Автор: AndyBW

Источник

* - обязательные к заполнению поля


https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js