Skip To Content

Пример: Регистрация папок и баз данных, перечисленных в текстовом файле

В этом примере скрипт использует текстовых файлов со списком папок и баз данных, которые вы хотите зарегистрировать на сайте 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:]))