Доступно с лицензией Standard или Advanced.
Для создания базы геоданных в DB2 на операционной системе z (z/OS) вам следует выполнить следующее:
- Установить клиент ArcGIS и DB2.
- Настроить ZPARMs в DB2.
- Создание пользователя sde и группу в z/OS.
- Переместить набор данных в z/OS.
- Создать по крайней мере две базы данных.
- Предоставить права доступа пользователю sde и группе.
- Настройте файл dbtune.sde для указания хранилища системной таблицы.
- Создайте базу геоданных.
Настройка клиента ArcGIS
Необходимо установить клиент ArcGIS для получения файлов, необходимых для установки базы данных DB2 и для запуска инструмента и скрипта для создания базы геоданных.
Вы можете запустить скрипт Python из ArcGIS for Desktop (Стандартный или Дополнительно), ArcGIS Engine Runtime с дополнительным модулем Geodatabase Update или ArcGIS for Server (Standard или Advanced) для создания базы геоданных. Если вы хотите запустить инструмент геообработки Включить многопользовательскую базу геоданных (Enable Enterprise Geodatabase) вместо скрипта, то используйте ArcGIS for Desktop.
- Установите клиента ArcGIS, которого вы собираетесь использовать для создания базы геоданных.
Следуйте инструкциям руководств по установке программного обеспечения.
- В большинстве случаев ваш клиент ArcGIS будет установлен на компьютере, отличном от сервера DB2; поэтому, установите и настройте клиент DB2 на компьютере с клиентом ArcGIS.
IBM Data Server Runtime Client for DB2 может быть загружен с My Esri, или вы можете использовать свой собственный файл установки клиента DB2. Для получения инструкций по установке обратитесь к документации по DB2. Если вы устанавливаете клиент DB2 на 64-разрядную ОС, запустите 64-разрядный exe-файл; он установит 32- и 64-разрядные файлы.
- Вы можете подключиться непосредственно из ArcGIS Server к базе данных DB2 с использованием строки подключения DSNless. Однако, если вместо этого вы хотите использовать имя источника данных для подключения, то вам необходимо каталогизировать базу данных, тем самым настроив имя источника данных. Инструкции по созданию имени источника данных смотри в документации по IBM DB2.
Далее, настройте систему DB2.
Настройка ZPARMs
Для того чтобы ArcGIS мог запускаться в качестве распределенного клиента для IBM DB2 на z/OS, необходимо запустить утилиту распределенных данных (DDF). Настоятельно рекомендуется использовать следующие значения DB2 ZPARM для оптимизации производительности базы геоданных в ArcGIS и в других клиентах.
- Осуществите вход в DB2 как администратор z/OS.
- Установите следующие параметры в разделе DSN6FAC для DSNTIJUZ:
- CMTSTAT=INACTIVE
- IDTHTOIN=3600
- TCPKPALV=120
- Установите следующие параметры в разделе DSN6SYSP для DSNTIJUZ:
- CONDBAT=10000
- EXTSEC=YES
- IMPDSDEF=YES
- IXQTY=0
- MAXDBAT=1000
- TSQTY=0
- XMLVALA=204800
- XMLVALS=10240
- Также необходимо задать действующую по умолчанию WLM-среду в WLMENV, а именно в разделе DSN6SPRM настроек DSNTIJUZ. К ним относятся:
- CACHEDYN=YES
- EDMDBDC=102400
- EDMPOOL=32000
- EDMSTMTC=102400
- EDM_SKELETON_POOL=102400
- После изменения вышеописанных значений ZPARM, также необходимо убедиться, что для SYSLMOD в шаге настроек DSNTIZL указано правильное имя набора данных, которое гарантирует при старте DB2 осуществление загрузки требуемого модуля ZPARM.
- Остановите и запустите DB2, используя команду SET SYSPARM для незамедлительного применения изменений.
Создайте пользователя sde и группу
Создайте ID первичной авторизации в RACF на z/OS (sde по умолчанию) с доступом к Time Sharing Option (TSO). Дополнительную информацию о создании пользователей по RACF см. в руководстве администратора z/OS.
IBM рекомендует вам использовать вторичный ID авторизации (группы пользователей в RACF на z/OS) для упрощения управления правами пользователей. Вам необходимо включить вторичный ID авторизации на z/OS. Дополнительную информацию о включении вторичной авторизации см. в руководстве z/OS.
Только один пользователь, который отвечает за управление ГИС данными и базами геоданных, должен войти в систему как пользователь sde. Другим пользователям ArcGIS следует подключаться по учетным записям, отличным от sde.
- Используя RACF, создайте в системе отдельную учетную запись с именем sde.
- Создайте группу пользователей, например GISUSERS, на z/OS с применением RACF. Чтобы это сделать, укажите имя группы на VM14 вашему EC.
- Добавьте пользователя sde в группу GISUSERS с использованием RACF.
Чтобы подключиться к базе геоданных как пользователь sde с клиентского компьютера с Windows, на которой установлен клиент ArcGIS, на клиентской машине должен быть представлен локальный пользователь Windows с тем же именем (sde), что и при подключении к серверу. Этому пользователю не требуется специальных прав доступа. Для создания локального пользователя Windows обратитесь к документации по Microsoft Windows.
Перемещение набора данных в IBM z/OS
Для создания базы геоданных в DB2 версии 9.1 для системы z/OS, вы должны переместить набор данных – esriobj.XMIT – в целевую систему z/OS. Файл esriobj.XMIT можно найти в папке DB2zOS, внутри директории DatabaseSupport клиента ArcGIS. Файл содержит образы программ, которые должны быть присоединены к загрузочным библиотекам в системе z/OS. Для проведения такой настройки необходимо выполнить следующие действия.
- Войдите в систему z/OS с помощью ID учетной записи пользователя SYSADM.
- Загрузите набор данных esriobj.XMIT в систему z/OS с помощью FTP.
Данные имеют формат отправки и получения TSO/E (Time Sharing Option/Extension) и должны быть загружены в систему z/OS с помощью ДВОИЧНОЙ (BINARY) передачи. Набор данных доступен в папке DatabaseSupport\DB2zOS каталога установки ArcGIS в ОС Windows.
- Если допустить, что для переноса используется FTP, набор данных должен быть в итоге определен в z/OS со следующими характеристиками.
RECFM=FB,LRECL=80,BLKSIZE=3120
Обычно FTP-системы настроены так, что для любых данных, которые принимаются и сохраняются в новом наборе данных, получающийся в результате новый набор данных не имеет требуемый формат. Однако это можно изменить, используя FTP-команды. Команда для FTP из ОС Windows:
quote site recfm=fb lrecl=80 blksize=3120
Если пользователь вошел в систему z/OS и получает данные с помощью FTP, команда будет следующей:
locsite recfm=fm lrecl=80 blksize=3120
- Набор данных должен быть ПОЛУЧЕН (RECEIVED) в режиме TSO/E учетной записью пользователя в системе z/OS. Войдите в систему z/OS с помощью ID учетной записи пользователя SYSADM и откройте опцию 6 (панель команд) интерфейса диалогового взаимодействия с пользователем (Interactive System Productivity Facility, ISPF).
- Загруженному набору данных присвоено имя esriobj.XMIT, поэтому для получения набора данных необходимо выполнить следующую команду TSO/E.
RECEIVE INDA('SYSADM.ESRIOBJ.XMIT')
Для этой команды возвращается запрос на уточнение переопределений при создании набора данных. Если переопределения не выполняются, набор данных будет создан с помощью квалификатора верхнего уровня (HLQ) для ID пользователя, от имени которого выполнен вход в систему.
Теперь набор данных в SCR03: <пользователь>.ESRI.OBJLIB должен быть получен.
- Проверьте имя набора данных. Если имя указано правильно, оно будет связано с заданием установки ESRI UDF, которое на этом этапе должно быть загружено в систему z/OS, отредактировано и запущено в z/OS, как описано в следующем разделе.
Создание баз данных
Для хранения базы геоданных вам понадобится не менее двух баз данных DB2 в подсистеме базы данных с включенным пространством: для хранения репозитория базы геоданных и пользовательских данных. База данных с репозиторием базы геоданных совместно с базой или базами данных, содержащими пользовательские данные, составляют одну базу геоданных. Поэтому эти базы данных должны быть созданы до начала установки базы геоданных.
Скрипт JCL, ESRIUDFI, предоставляет возможность формирования баз данных и UDF для создания базы геоданных. Этот скрипт установлен в папку DatabaseSupport\DB2zOS, которая находится в установочной папке клиента ArcGIS. Необходимо отредактировать скрипт ESRIUDFI, используя необходимую в вашем случае информацию, загрузить скрипт и запустить его на z/OS. В самом скрипте содержатся инструкции по созданию двух баз данных.
Чтобы отредактировать ESRIUDFI, обратитесь к инструкциям в скрипте JCL и внимательно проверьте следующие строки.
- В теле скрипта ESRIUDFI имеется несколько строк, которые должны быть заменены параметрами среды, соответствующими данному пользователю. Дополнительную информацию о значении строк и о правилах их замены можно найти в верхней части скрипта ESRIUDFI.
- Шаг ESRIS1 скрипта JCL создает две базы данных и устанавливает сопоставление. Чтобы использовать эти строки, необходимо удалить комментарии и предоставить имена и сопоставления для баз данных. Ниже приведен пример для этого случая.
CREATE DATABASE SDEDBR00 CCSID UNICODE; CREATE DATABASE SDEDBU00 CCSID UNICODE;
- Если требуется, вы можете создать группу хранилищ для более эффективного управления данными базы геоданных. Для этого необходимо сначала создать группу хранилищ, добавив дополнительную строку в скрипт ESRIUDFI, как показано в следующем примере:
CREATE STOGROUP ARCSDE VOLUMES (VOL1, VOL2, …) VCAT SDECAT; CREATE DATABASE SDEDBR00 CCSID UNICODE STOGROUP ARCGIS; CREATE DATABASE SDEDBU00 CCSID UNICODE STOGROUP ARCGIS;
- По завершении редактирования скрипта ESRIUDFI необходимо отправить его на целевую машину.
После завершения установки ESRI UDF вы увидите, что на последнем этапе состыковка пакета и создание процедуры SDE.SDE_UPDT_LMOD прошли успешно, но есть предупреждения. Эти предупреждения указывают на то, что системные таблицы базы геоданных еще не были созданы в базе данных. Вы можете игнорировать эти предупреждения, так как после запуска инструмента Включить многопользовательскую базу геоданных (Enable Enterprise Geodatabase) таблицы будут созданы, и объект пакета будет автоматически привязан после того, как утилита создаст на него ссылку.
- Подсистема базы данных со включенным пространством. Для получения инструкций обратитесь к документации по DB2 z/OS.
Предоставление прав доступа
После создания баз данных и UDF пользователю sde и группе пользователей ArcGIS необходимо выдать разрешения и права доступа к базе данных.
- Войдите в DB2 под учетной записью с ролью SYSADM для выдачи необходимых разрешений группе пользователей ArcGIS и пользователю sde. В данном примере используется оператор GRANT, а группа называется GISUSERS.
GRANT SELECT ON SYSIBM.SYSTABAUTH TO GISUSERS; GRANT SELECT ON SYSIBM.SYSDBAUTH TO GISUSERS; GRANT SELECT ON SYSIBM.SYSROUTINES TO GISUSERS; GRANT SELECT ON SYSIBM.SYSTABCONST TO GISUSERS; GRANT SELECT ON SYSIBM.SYSINDEXES TO GISUSERS; GRANT SELECT ON SYSIBM.SYSKEYS TO GISUSERS; GRANT SELECT ON SYSIBM.SYSCOLUMNS TO GISUSERS; GRANT SELECT ON SYSIBM.SYSCHECKS TO GISUSERS; GRANT SELECT ON SYSIBM.SYSSCHEMAAUTH TO GISUSERS; GRANT SELECT ON SYSIBM.SYSTABLES TO GISUSERS; GRANT SELECT ON SYSIBM.SYSSEQUENCES TO GISUSERS; GRANT SELECT ON SYSIBM.SYSDUMMY1 TO GISUSERS;
- Предоставьте пользователю sde следующие дополнительные разрешения:
GRANT BINDADD TO SDE; GRANT CREATE ON COLLECTION SDE TO SDE; GRANT DBADM ON DATABASE <repository_database_name> TO SDE; GRANT DBADM ON DATABASE <user_data_database_name> TO SDE;
- Предоставьте роли PUBLIC следующие права доступа:
GRANT EXECUTE ON PACKAGE SYSPROC.* TO PUBLIC;
- Следующий оператор нужен при использовании группы хранения. В данном примере группа хранения названа ARCGIS.
GRANT USE OF STOGROUP ARCGIS to SDE;
Настройка dbtune.sde
Измените файл dbtune.sde в <ArcGIS client installation directory>\DatabaseSupport\DB2zOS для указания подсистемы вашей базы данных.
Файл dbtune.sde заполняет системную таблицу базы геоданных DBTUNE ключевыми словами конфигурации, параметрами и значениями, которые управляют хранением таблиц в базе данных на физическом уровне. Для баз данных DB2 под управлением z/OS, вы должны отредактировать этот файл до запуска инструмента геообработки Включить многопользовательскую базу геоданных (Enable Enterprise Geodatabase) для указания базы данных, в которой требуется создать определенные таблицы.
- Откройте файл dbtune.sde в текстовом редакторе.
- Раскомментируйте и измените значения конфигурационных строк в разделе DATA_DICTIONARY, чтобы указать, в какой базе данных вы хотите создать определенные системные таблицы базы геоданных. Ниже приведены предлагаемые настройки. База данных с именем SDEDBR00 – это база данных, в которой будут храниться таблицы репозитория базы геоданных.
B_STORAGE "IN DATABASE SDEDBR00" MVTABLES_MODIFIED_TABLE "IN DATABASE SDEDBR00" STATES_TABLE "IN DATABASE SDEDBR00" STATE_LINEAGES_TABLE "IN DATABASE SDEDBR00" VERSIONS_TABLE "IN DATABASE SDEDBR00" XML_INDEX_TAGS_TABLE "IN DATABASE SDEDBR00"
- Убедитесь, что параметры BLOB_OPTION и CLOB_OPTION в разделе DEFAULTS заданы как пустые строки.
- Раскомментируйте и измените значения конфигурационных строк в разделе DEFAULTS, чтобы указать, в какой базе данных вы хотите создать определенные объекты, относящиеся к определенным пользователем данным.
Ниже приведены предлагаемые настройки. База данных с именем SDEDBU00 – это база данных, в которой будут храниться пользовательские данные в подсистеме баз данных.
AUX_STORAGE "IN DATABASE SDEDBU00" A_STORAGE "IN DATABASE SDEDBU00" BLK_STORAGE "IN DATABASE SDEDBU00" BND_STORAGE "IN DATABASE SDEDBU00" B_STORAGE "IN DATABASE SDEDBU00" D_STORAGE "IN DATABASE SDEDBU00" RAS_STORAGE "IN DATABASE SDEDBU00"
- Раскомментируйте и измените значения конфигурационных строк в разделе LOGFILE_DEFAULTS, чтобы указать, в какой базе данных вы хотите создать таблицы файла отчета.
LD_STORAGE "IN DATABASE SDEDBU00" LF_STORAGE "IN DATABASE SDEDBU00" SESSION_STORAGE "IN DATABASE SDEDBU00"
- Сохраните и закройте файл dbtune.sde.
Теперь вы можете создать базу геоданных в вашей подсистеме DB2.
Создание базы геоданных
Используйте один из следующих методов для создания базы геоданных в вашей базе данных DB2 на z/OS:
Используйте инструмент Включить многопользовательскую базу геоданных (Enable Enterprise Geodatabase)
Если вы установили и настроили ArcGIS for Desktop для подключения к вашей подсистеме DB2, то вы можете запустить инструмент Включить многопользовательскую базу геоданных (Enable Enterprise Geodatabase).
- Запустите ArcMap или ArcCatalog.
- Подключитесь к DB2 из дерева Каталога. Подключитесь с учетной записью sde.
Убедитесь в том, что в диалоговом окне Подключение базы данных сохранен пароль пользователя sde.
- Щелкните правой кнопкой мыши подключение к базе данных и выберите Включить базу геоданных (Enable Geodatabase).
Откроется инструмент Включить многопользовательскую базу геоданных (Enable Enterprise Geodatabase).
- Добавьте файл подключения к базе данных в текстовом окне Входная база данных (Input Database).
- Перейдите к файлу ключей ArcGIS for Server, который был создан при авторизации ArcGIS for Server, и добавьте его в текстовое поле Файл авторизации (Authorization File).
При использовании мастера для авторизации ArcGIS for Server файл ключей записывается на сервер, где установлено программное обеспечение. Если вы авторизовали ArcGIS for Server на компьютере с Linux, то файл был создан в /arcgis/server/framework/runtime/.wine/drive_c/Program Files/ESRI/License<release>/sysgen. Если вы авторизовали на сервере Windows, то файл был создан в Program Files\ESRI\License<release>\sysgen. Если данная процедура еще не выполнена, авторизуйте ArcGIS for Server для создания этого файла.
- Щелкните OK, чтобы запустить инструмент.
Создание базы геоданных (GDBCreateGeodatabase<№>.log) регистрируется в файле журнала, который сохраняется в каталоге, указанном для переменной %TEMP%, на том компьютере, где запущен инструмент. При наличии проблем с запуском инструмента изучите этот файл журнала для их устранения.
В вашей подсистеме DB2 создается база геоданных.
Теперь создайте пользователей, которые могут создать данные.
Использование скрипта Python
Вы можете запустить скрипт Python из ArcGIS for Desktop (Стандартный или Дополнительно), ArcGIS for Server (Standard или Advanced) или с клиентского компьютера ArcGIS Engine (с дополнительным модулем Geodatabase Update) для создания базы геоданных в подсистеме DB2.
Выполните следующие действия, чтобы запустить скрипт Python для создания базы геоданных в подсистеме DB2 z/OS:
- Создайте текстовый файл на клиентском компьютере ArcGIS и скопируйте следующий скрипт в файл.
""" Name: enable_enterprise_gdb.py Description: Provide connection information to an enterprise database and enable enterprise geodatabase. Type enable_enterprise_gdb.py -h or enable_enterprise_gdb.py --help for usage Author: Esri """ # Import system modules import arcpy, os, optparse, sys # Define usage and version parser = optparse.OptionParser(usage = "usage: %prog [Options]", version="%prog 1.0 for " + arcpy.GetInstallInfo()['Version'] ) #Define help and options parser.add_option ("--DBMS", dest="Database_type", type="choice", choices=['SQLSERVER', 'ORACLE', 'POSTGRESQL', 'DB2','INFORMIX','DB2ZOS', ''], default="", help="Type of enterprise DBMS: SQLSERVER, ORACLE, POSTGRESQL, DB2, INFORMIX, or DB2ZOS.") parser.add_option ("-i", dest="Instance", type="string", default="", help="DBMS instance name") parser.add_option ("--auth", dest="account_authentication", type ="choice", choices=['DATABASE_AUTH', 'OPERATING_SYSTEM_AUTH'], default='DATABASE_AUTH', help="Authentication type options (case-sensitive): DATABASE_AUTH, OPERATING_SYSTEM_AUTH. Default=DATABASE_AUTH") parser.add_option ("-u", dest="User", type="string", default="", help="Geodatabase administrator user name") parser.add_option ("-p", dest="Password", type="string", default="", help="Geodatabase administrator password") parser.add_option ("-D", dest="Database", type="string", default="none", help="Database name: Not required for Oracle") parser.add_option ("-l", dest="Authorization_file", type="string", default="", help="Full path and name of authorization file") # Check if value entered for option try: (options, args) = parser.parse_args() #Check if no system arguments (options) entered if len(sys.argv) == 1: print "%s: error: %s\n" % (sys.argv[0], "No command options given") parser.print_help() sys.exit(3) #Usage parameters for spatial database connection database_type = options.Database_type.upper() instance = options.Instance account_authentication = options.account_authentication.upper() username = options.User.lower() password = options.Password database = options.Database.lower() license = options.Authorization_file if( database_type ==""): print " \n%s: error: \n%s\n" % (sys.argv[0], "DBMS type (--DBMS) must be specified.") parser.print_help() sys.exit(3) if (license == ""): print " \n%s: error: \n%s\n" % (sys.argv[0], "Authorization file (-l) must be specified.") parser.print_help() sys.exit(3) if (database_type == "SQLSERVER"): database_type = "SQL_SERVER" # Get the current product license product_license=arcpy.ProductInfo() if (license == ""): print " \n%s: error: %s\n" % (sys.argv[0], "Authorization file (-l) must be specified.") parser.print_help() sys.exit(3) # Checks required license level if product_license.upper() == "ARCVIEW" or product_license.upper() == 'ENGINE': print "\n" + product_license + " license found!" + " Enabling enterprise geodatabase functionality requires an ArcGIS for Desktop Standard or Advanced, ArcGIS Engine with the Geodatabase Update extension, or ArcGIS for Server license." sys.exit("Re-authorize ArcGIS before enabling an enterprise geodatabase.") else: print "\n" + product_license + " license available! Continuing to enable..." arcpy.AddMessage("+++++++++") # Local variables instance_temp = instance.replace("\\","_") instance_temp = instance_temp.replace("/","_") instance_temp = instance_temp.replace(":","_") Conn_File_NameT = instance_temp + "_" + database + "_" + username if os.environ.get("TEMP") == None: temp = "c:\\temp" else: temp = os.environ.get("TEMP") if os.environ.get("TMP") == None: temp = "/usr/tmp" else: temp = os.environ.get("TMP") Connection_File_Name = Conn_File_NameT + ".sde" Connection_File_Name_full_path = temp + os.sep + Conn_File_NameT + ".sde" # Check for the .sde file and delete it if present arcpy.env.overwriteOutput=True if os.path.exists(Connection_File_Name_full_path): os.remove(Connection_File_Name_full_path) print "\nCreating Database Connection File...\n" # Process: Create Database Connection File... # Usage: out_file_location, out_file_name, DBMS_TYPE, instnace, database, account_authentication, username, password, save_username_password(must be true) arcpy.CreateDatabaseConnection_management(out_folder_path=temp, out_name=Connection_File_Name, database_platform=database_type, instance=instance, database=database, account_authentication=account_authentication, username=username, password=password, save_user_pass="TRUE") for i in range(arcpy.GetMessageCount()): if "000565" in arcpy.GetMessage(i): #Check if database connection was successful arcpy.AddReturnMessage(i) arcpy.AddMessage("\n+++++++++") arcpy.AddMessage("Exiting!!") arcpy.AddMessage("+++++++++\n") sys.exit(3) else: arcpy.AddReturnMessage(i) arcpy.AddMessage("+++++++++\n") # Process: Enable geodatabase... try: print "Enabling Enterprise Geodatabase...\n" arcpy.EnableEnterpriseGeodatabase_management(input_database=Connection_File_Name_full_path, authorization_file=license) for i in range(arcpy.GetMessageCount()): arcpy.AddReturnMessage(i) arcpy.AddMessage("+++++++++\n") except: for i in range(arcpy.GetMessageCount()): arcpy.AddReturnMessage(i) if os.path.exists(Connection_File_Name_full_path): os.remove(Connection_File_Name_full_path) #Check if no value entered for option except SystemExit as e: if e.code == 2: parser.usage = "" print "\n" parser.print_help() parser.exit(2)
- Сохраните файл с расширением .py.
- Запустите скрипт, предоставив специфичные для вашего сайта опции и информацию.
В следующем примере запуск выполняется с компьютера с Windows, файл enable_gdb.py запускается для базы данных spdata на экземпляре db2prod. Подключение выполняется для учетной записи SDE с паролем Tgdbst@rtsh3r3. Для авторизации базы геоданных в местоположении для ArcGIS Server по умолчанию задается файл ключей.
enable_gdb.py --DBMS DB2 -i db2prod --auth DATABASE_AUTH -u sde -p Tgdbst@rtsh3r3 -D spdata -l \\Program Files\ESRI\License10.3\sysgen\keycodes
Это пример запуска скрипта на компьютере с Linux:
./enable_gdb.py --DBMS DB2 -i db2prod --auth DATABASE_AUTH -u sde -p Tgdbst@rtsh3r3 -D spdata -l /usr/arcgis/server/framework/runtime/.wine/drive_c/Program Files/ESRI/License10.3/sysgen/keycodes
Файл отчета о создании базы геоданных (GDBCreateGeodatabase<#>.log) будет записан в папку, заданную переменной TEMP или TMP на компьютере, где был запущен скрипт.
В вашей подсистеме DB2 создается база геоданных.
Теперь создайте пользователей, которые могут создать данные.