В этом примере скрипт использует текстовых файлов со списком папок и баз данных, которые вы хотите зарегистрировать на сайте ArcGIS Server. Хотя вы можете зарегистрировать базы данных и папки на интегрированных сайтах ArcGIS Server при помощи ArcGIS Pro или портала ArcGIS Enterprise и зарегестрировать автономные сайты ArcGIS Server при помощи ArcGIS Pro или ArcGIS Server Manager, быстрее будет использовать этот скрипт, особенно, если зарегистрировать надо много местоположений.
Подсказка:
Информацию о том, почему вы регистрируете местоположения данных на сайте ArcGIS Server, см. В разделе Источники данных для ArcGIS Server.
Структурируйте входной текстовый файл следующим образом:
#dsName|dsType|serverPath|clientPath|hostname
dsName=<data store name>|dsType={FOLDER | DATABASE}|serverPath=<path to folder or database connection file used by the ArcGIS Server site>|clientPath=<path to folder or database connection file used by the publishing client>
- dsName – имя элемента хранения данных. Любое присвоенное вами имя.
- dsType – тип регистрируемого элемента хранения данных. В этом примере вы можете ввести FOLDER или DATABASE.
- serverPath – путь к данным, отображаемый для серверного компьютера.
- clientPath – путь к данным, отображаемый для компьютеров издателей. Если это не указать, будет использоваться путь к серверным данным. Если ввести ключевое слово managed, то это будет означать, что вы регистрируете этот элемент хранения данных как управляемую базу данных сайта ArcGIS Server.
- hostname – имя компьютера издателя. Это требуется только, когда clientPath является путем к папке. Если это свойство не указать, то будет использоваться имя компьютера, на котором выполняется скрипт.
В этом примере в текстовом файле перечислены два пути к папкам и два файла подключения к базе данных. Второй путь к папке (testData) имеет другое расположение для сайта ArcGIS Server и локального клиента ArcGIS.
#dsName|dsType|serverPath|clientPath|hostname
dsName=sharedData|dsType=FOLDER|serverPath=\\sharedserver\data|clientPath=\\sharedserver\data
dsName=testData|dsType=FOLDER|serverPath=\\test_server\data|clientPath=c:\mydata|hostname=qalab_publisher
dsName=entGeodatabase|dsType=DATABASE|serverPath=C:\data\db_connections\Connection to enterprisegdb1.sde|clientPath=C:\data\db_Connections\Connection to enterprisegdb1.sde
dsName=spatialDatabase|dsType=DATABASE|serverPath=C:\data\db_Connections\Connection to projectdb.sde|clientPath=C:\data\db_Connections\Connection to projectdb.sde
Следующий пример сценария запрашивает информацию о подключении к сайту ArcGIS Server для создания файла подключения ArcGIS Server. Он также предлагает вам указать расположение текстового файла, содержащего список источников данных, и регистрирует источники данных в файле с сайтом ArcGIS Server.
import sys
import os
import getpass
import arcpy
import codecs
def main(argv=None):
# Ask for admin user name and password
username = input("Enter user name: ")
password = getpass.getpass("Enter password: ")
# Ask for server name & port
serverName = input("Enter server name: ")
serverPort = input("Enter server port: ")
# Create a connection file to the server and save it in the same location as that of the script
serverURL="http://"+serverName+":"+str(serverPort)+"/arcgis/admin"
try:
arcpy.mapping.CreateGISServerConnectionFile("PUBLISH_GIS_SERVICES",os.curdir,serverName+".ags",serverURL,"ARCGIS_SERVER",username=username,password=password)
except Exception as e:
print(e)
agsConnection = os.path.join(os.curdir, serverName+".ags")
if not os.path.isfile(agsConnection):
print("Unable to connect to ArcGIS Server. Exiting.")
sys.exit(1)
# Input File that contains the data store information
dataStoresFile = input("Path to pipe-delimited text file containing datastore information: ")
num = 0
datastores = {}
for datastoreRow in readlinesFromInputFile(dataStoresFile):
datastoreEntry = {}
for index in range(len(datastoreRow)):
datastoreProp = datastoreRow[index].split("=")
if datastoreProp[0] == "dsName":
datastoreEntry["connection_name"] = datastoreProp[1]
if datastoreProp[0] == "dsType":
datastoreEntry["datastore_type"] = datastoreProp[1]
if datastoreProp[0] == "serverPath":
datastoreEntry["server_path"] = datastoreProp[1]
if datastoreProp[0] == "clientPath":
datastoreEntry["client_path"] = datastoreProp[1]
if datastoreProp[0] == "hostname":
datastoreEntry["hostname"] = datastoreProp[1]
# Add the datastore information to a dictionary
datastores["datastore" + str(num)] = datastoreEntry
num +=1
# Call helper functions to register datastores
addDataStores(datastores,agsConnection)
# A function that reads lines from the input file
def readlinesFromInputFile(filename, delim='|'):
file = codecs.open(filename,'r','utf-8-sig')
for line in file.readlines():
# Remove the trailing whitespaces and the newline characters
line = line.rstrip()
if line.startswith('#') or len(line) == 0:
pass # Skip the lines that contain # at the beginning or any empty lines
else:
# Split the current line into list
yield line.split(delim)
file.close()
def addDataStores(datastoresDict,agsConnection):
for datastoreToAdd in datastoresDict:
# Build the dictionary with the role name and description
datastoresDict[datastoreToAdd]["connection_file"] = agsConnection
print("Adding the datastore: " + datastoresDict[datastoreToAdd]['connection_name'])
try:
arcpy.AddDataStoreItem(**datastoresDict[datastoreToAdd])
print("Successfully added the datastore: " + datastoresDict[datastoreToAdd]['connection_name'])
except Exception as e:
print("Adding of the datastore: " + datastoresDict[datastoreToAdd]['connection_name'] + " failed.")
print(e)
if __name__ == "__main__":
sys.exit(main(sys.argv[1:]))