Service bereitstellen (Server)
Zusammenfassung
Stellt eine Service-Definition bereit. Eine bereitgestellte Service-Definitionsdatei (.sd) enthält alle erforderlichen Informationen, um einen GIS-Service zu veröffentlichen, einschließlich Daten, die auf den Server kopiert werden müssen, da sie nicht im Datenspeicher des Servers vorhanden sind.
Verwendung
Dieses Werkzeug konvertiert einen Service-Definitionsentwurf (.sddraft) in eine Service-Definition, die dann in das Werkzeug Service-Definition hochladen eingegeben werden kann, um den GIS-Service auf einen Server hochzuladen und dort zu veröffentlichen. Service-Definitionsentwürfe können nicht verwendet werden, um einen GIS-Service direkt zu veröffentlichen.
Immer, wenn Sie einen Service mithilfe von ArcGIS for Desktop freigeben, wird das Werkzeug Service bereitstellen ausgeführt, und im Fenster Ergebnisse wird ein Ergebnis angezeigt.
Service-Definitionsentwürfe können unter Verwendung von ArcGIS for Desktop oder mithilfe der Arcpy-Funktionen CreateMapSDDraft (in arcpy.mapping), CreateImageSDDraft oder CreateGPSDDraft erstellt werden.
Nach der Bereitstellung wird der eingegebene Service-Definitionsentwurf gelöscht.
Syntax
Parameter | Erläuterung | Datentyp |
in_service_definition_draft | Geben Sie den Service-Definitionsentwurf ein. Service-Definitionsentwürfe können unter Verwendung von ArcGIS for Desktop erstellt werden. Weitere Informationen finden Sie im Hilfethema Service-Entwürfe. Sie können auch die arcpy.mapping -Funktion CreateMapSDDraft verwenden, um Entwürfe von Service-Definitionen zu erstellen. Nach der Bereitstellung wird der eingegebene Service-Definitionsentwurf gelöscht. | File |
out_service_definition |
Ergebnis der Service-Definition. Standardmäßig wird die Service-Definition in dasselbe Verzeichnis wie der Service-Definitionsentwurf geschrieben. | File |
Codebeispiel
Stellt eine Service-Definition bereit.
import arcpy
from arcpy import env
env.workspace = "C:/data"
arcpy.StageService_server("myMapService.sddraft", "myMapService.sd")
Das folgende Skript veranschaulicht den Workflow beim Veröffentlichen mithilfe von Service bereitstellen und Service-Definition hochladen.
# Name: StageService_UploadServiceDefinition_example2.py
# Description: Use a service definition draft to create a service definition
# and then upload and publish that service definition.
# Requirements: Connection to an ArcGIS Server, Spatial Data Server, or My Hosted Services
# Import system modules
import arcpy
from arcpy import env
# Set environment settings
env.workspace = "C:/data"
# Set local variables
inServiceDefinitionDraft = "myMapService.sddraft"
outServiceDefinition = "myMapService.sd"
# Execute StageService
arcpy.StageService_server(inServiceDefinitionDraft, outServiceDefinition)
# Set local variables
inSdFile = outServiceDefinition
inServer = "GIS Servers/myServerConnection"
# Execute UploadServiceDefinition
arcpy.UploadServiceDefinition_server(inSdFile, inServer)
Das folgende Skript erstellt und lädt eine Service-Definition hoch, die verwendet werden kann, um einen vorhandenen Service zu überschreiben.
# Name: StageService_example3_UploadServiceDefinition_example4.py
# Description: Creates a service definition that can be used to overwrite an
# existing service. When this service definition is published it
# will overwrite the existing service.
# Requirements: Connection to an ArcGIS Server, Spatial Data Server,
# or My Hosted Services
# Import system modules
import arcpy
from arcpy import env
import xml.dom.minidom as DOM
# Set environment settings
env.workspace = "C:/data"
# Set local variables
inServiceDefinitionDraft = "myMapService.sddraft"
outServiceDefinition = "myMapService.sd"
newType = 'esriServiceDefinitionType_Replacement'
xml = draftPath + in_sd_draft
doc = DOM.parse(xml)
descriptions = doc.getElementsByTagName('Type')
for desc in descriptions:
if desc.parentNode.tagName == 'SVCManifest':
if desc.hasChildNodes():
desc.firstChild.data = newType
outXml = xml
f = open(outXml, 'w')
doc.writexml( f )
f.close()
# Execute StageService
arcpy.StageService_server(inServiceDefinitionDraft, outServiceDefinition)
# Set local variables
inSdFile = outServiceDefinition
inServer = "GIS Servers/myServerConnection"
# Execute UploadServiceDefinition
arcpy.UploadServiceDefinition_server(inSdFile, inServer)