Organiser le service (Serveur)

Niveau de licence :De baseStandardAvancé

Récapitulatif

Permet d'organiser une définition de service. Un fichier de définition de service organisée (.sd) contient toutes les informations nécessaires pour publier un service SIG, y compris les données qui doivent être copiées sur le serveur, car elles n'apparaissent pas dans le magasin de données du serveur.

Utilisation

Syntaxe

StageService_server (in_service_definition_draft, out_service_definition)
ParamètreExplicationType de données
in_service_definition_draft

Définition de service de brouillon en entrée Vous pouvez créer des brouillons de définitions de services à l'aide d'ArcGIS for Desktop. Pour plus d'informations, consultez la rubrique d'aide A propos des services de brouillon. Vous pouvez également utiliser la fonction arcpy.mapping CreateMapSDDraft pour créer des définitions de services de brouillon.

Une fois organisée, la définition de service de brouillon en entrée est supprimée.

File
out_service_definition

Définition de service résultante. Par défaut, il convient d'écrire la définition de service dans le même répertoire que la définition de service de brouillon.

File

Exemple de code

Exemple de StageService (fenêtre Python)

Permet d'organiser une définition de service.

import arcpy
from arcpy import env
env.workspace = "C:/data"
arcpy.StageService_server("myMapService.sddraft", "myMapService.sd")
Exemple de worflow de publication (script autonome)

Le script suivant illustre un workflow de publication créé à l'aide de Stage_Service et Upload_Service_Definition.

# 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)
Exemple de remplacement de services (script autonome)

Le script suivant crée et télécharge une définition de service qui permet de remplacer un service.

# 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)

Environnements

Thèmes connexes

Informations de licence

ArcGIS for Desktop Basic : Oui
ArcGIS for Desktop Standard : Oui
ArcGIS for Desktop Advanced : Oui
9/12/2013