Résumé
Cet outil importe des tuiles depuis un dossier du disque vers un cache de couche d'images de carte.
Le dossier source peut être un enfant d'un répertoire de cache du serveur enregistré, un dossier dans lequel un cache a été exporté précédemment ou un paquetage de tuiles (.tpk). Le service cible doit avoir la même structure de tuile et le même format de stockage que le cache source.
Utilisation
Utilisez cet outil pour importer l'intégralité ou une partie d'un cache d'un dossier vers un autre.
Le paramètre Overwrite Tiles (Remplacer les tuiles) permet aux tuiles importées de remplacer entièrement les tuiles existantes, au lieu de fusionner les images. Les tuiles importées peuvent toujours être contraintes dans une zone d'intérêt.
Syntaxe
arcpy.server.ImportMapServerCache(input_service, source_cache_type, {source_cache_dataset}, {source_tile_package}, {upload_data_to_server}, {scales}, {num_of_caching_service_instances}, {area_of_interest}, {import_extent}, {overwrite})
Paramètre | Explication | Type de données |
input_service | Couche d’images de carte dont les tuiles de cache doivent être importées. | Image Service; MapServer |
source_cache_type | Permet d’importer le cache d’un jeu de données de cache ou d’un paquetage de tuiles vers un service de carte ou d’imagerie en cache exécuté sur le serveur.
| String |
source_cache_dataset (Facultatif) | Chemin d'accès au dossier de cache correspondant au nom du bloc de données. Vous n’êtes pas obligé d’entrer un répertoire de cache du serveur inscrit. La plupart du temps, vous spécifiez un emplacement du disque où figurent déjà des tuiles exportées. Le compte ArcGIS Server doit pouvoir accéder à cet emplacement. Si le compte ArcGIS Server ne peut pas obtenir de droits d’accès sur cet emplacement, définissez le paramètre upload_data_to_server sur UPLOAD_DATA. | Raster Dataset |
source_tile_package (Facultatif) | Chemin d'accès au paquetage de tuiles (.tpk) qui sera importé. Le compte ArcGIS Server doit pouvoir accéder à cet emplacement. Lors de l’importation d’un fichier de paquetage de tuiles dans un service de carte ou d’imagerie en cache, le paramètre upload_data_to_server est ignoré, car il est automatiquement défini sur UPLOAD_DATA. | File |
upload_data_to_server (Facultatif) | Définissez ce paramètre sur UPLOAD_DATA si le compte ArcGIS Server ne dispose pas d'un accès en lecture au cache source. L'outil téléchargera le cache source dans le répertoire de téléchargements ArcGIS Server avant de le placer dans le répertoire de cache ArcGIS Server.
| Boolean |
scales [scales,...] (Facultatif) | Liste des niveaux d'échelle auxquels les tuiles sont importées. | Double |
num_of_caching_service_instances (Facultatif) | Indique le nombre d’instances qui seront utilisées pour mettre à jour ou générer les tuiles. La valeur de ce paramètre est définie sur illimitée (-1) et ne peut pas être modifiée. | Long |
area_of_interest (Facultatif) | Polygone de zone d'intérêt qui contraint spatialement la zone où les tuiles sont importées dans le cache. Ce paramètre est utile si vous voulez importer des tuiles pour des zones de forme irrégulière, car l’outil découpe le jeu de données du cache qui intersecte le polygone à une résolution de pixel, puis l’importe dans le répertoire de cache du service. Si vous ne fournissez aucune valeur pour ce paramètre, la valeur du paramètre Emprise d'importation est utilisée. Par défaut, il convient d'utiliser l'étendue globale de la carte. | Feature Set |
import_extent (Facultatif) | Etendue rectangulaire définissant les tuiles à importer dans le cache. Par défaut, l’étendue est définie sur l’étendue complète du service de carte dans lequel vous effectuez l’importation. Notez que le paramètre facultatif Area Of Interest (Zone d’intérêt) de cet outil vous permet de contraindre spatialement les tuiles importées avec une forme irrégulière. Si vous entrez des valeurs pour les deux paramètres, le paramètre Area Of Interest (Zone d’intérêt) est prioritaire sur le paramètre Import Extent (Emprise d’importation).
| Extent |
overwrite (Facultatif) | Indique si les images du cache de destination sont fusionnées avec les tuiles du cache d’origine ou remplacées par ces dernières.
| Boolean |
Sortie dérivée
Nom | Explication | Type de données |
out_job_url | L’URL en sortie. | Chaîne |
Exemple de code
Importez un jeu de données de cache dans un service en cache pour le nombre d'échelles par défaut. Les tuiles du cache de destination sont remplacées par les tuiles importées.
# Name: ImportMapServerCache.py
# Description: The following stand-alone script demonstrates how to import map
# server cache from a source directory with CACHE_DATASET and
# OVERWRITE existing cache on the service for the number
# of scales specified without Uploading data to server
# Requirements: os, sys, time and traceback modules
# Any line that begins with a pound sign is a comment and will not be executed
# Empty quotes take the default value.
# To accept arguments from the command line replace values of variables to
# "sys.argv[]"
# Import system modules
import arcpy
from arcpy import env
import os, sys, time, datetime, traceback, string
# Set environment settings
env.workspace = "C:/data"
# List of input variables for map service properties
connectionFile = r"C:\Users\<username>\AppData\Roaming\ESRI\Desktop10.1\ArcCatalog"
server = "arcgis on MyServer_6080 (publisher)"
serviceName = "Rainfall.MapServer"
inputService = connectionFile + "\\" + server + "\\" + serviceName
sourceCacheType = "CACHE_DATASET"
sourceCacheDataset = "C:/data/destination_folder/Layers"
sourceTilePackage = ""
uploadDataToServer = "DO_NOT_UPLOAD"
scales = [500000,250000,125000,64000]
numOfCachingServiceInstances = "2"
areaOfInterest = ""
importExtents = ""
overwriteTiles = "OVERWRITE"
currentTime = datetime.datetime.now()
arg1 = currentTime.strftime("%H-%M")
arg2 = currentTime.strftime("%Y-%m-%d %H:%M")
file = 'C:/data/report_%s.txt' % arg1
# print results of the script to a report
report = open(file,'w')
# use "scales[0]","scales[-1]","scales[0:3]"
try:
starttime = time.clock()
result = arcpy.ImportMapServerCache_server(inputService, sourceCacheType,
sourceCacheDataset,
sourceTilePackage,
uploadDataToServer, scales,
numOfCachingServiceInstances,
areaOfInterest, importExtents,
overwriteTiles)
finishtime = time.clock()
elapsedtime = finishtime - starttime
#print messages to a file
while result.status < 4:
time.sleep(0.2)
resultValue = result.getMessages()
report.write ("completed " + str(resultValue))
print("Imported Map server Cache Tiles successfully for" + serviceName + \
" from" + sourceCacheDataset + "\n in " + str(elapsedtime)+ "sec on " + arg2)
except Exception as e:
# If an error occurred, print line number and error message
tb = sys.exc_info()[2]
report.write("Failed at step 1 \n" "Line %i" % tb.tb_lineno)
report.write(str(e))
print("Imported Map server Cache Tiles ")
report.close()
Importez des tuiles de cache pour une zone d’intérêt depuis un paquetage de tuiles vers un service de cache.
# Name: ImportMapServerCache.py
# Description: The following stand-alone script demonstrates how to import map
# server cache from a source directory with Tile Package to an existing service for
# the default number of scales specified using an AOI by uploading data to remote server
# To Import cache tiles for the scales specified for given feature class
# Requirements: os, sys, time and traceback modules
# Author: ESRI
# Any line that begins with a pound sign is a comment and will not be executed
# Empty quotes take the default value.
# To accept arguments from the command line replace values of variables to
# "sys.argv[]"
# Import system modules
import arcpy
from arcpy import env
import os, sys, time, datetime, traceback, string
# Set environment settings
env.workspace = "C:/data"
# List of input variables for map service properties
connectionFile = r"C:\Users\<username>\AppData\Roaming\ESRI\Desktop10.1\ArcCatalog"
server = "arcgis on MyServer_6080 (publisher)"
serviceName = "Rainfall.MapServer"
inputService = connectionFile + "\\" + server + "\\" + serviceName
sourceCacheType = "TILE_PACKAGE"
sourceCacheDataset = ""
sourceTilePackage = "C:\\data\\destination_folder\\TPK\\Rainfall.tpk"
uploadDataToServer = "UPLOAD_DATA"
scales = [500000,250000,125000,64000]
numOfCachingServiceInstances = "2"
cacheDir = "c:\\arcgisserver\\arcgiscache"
areaOfInterest = "C:/data/101/Portland/Portland_Metro.shp"
importExtents = ""
overwriteTiles = "MERGE"
currentTime = datetime.datetime.now()
arg1 = currentTime.strftime("%H-%M")
arg2 = currentTime.strftime("%Y-%m-%d %H:%M")
file = 'C:/data/report_%s.txt' % arg1
# print results of the script to a report
report = open(file,'w')
# use "scales[0]","scales[-1]","scales[0:3]"
try:
starttime = time.clock()
result = arcpy.ImportMapServerCache_server(inputService, sourceCacheType,
sourceCacheDataset,
sourceTilePackage,
uploadDataToServer, scales,
numOfCachingServiceInstances,
areaOfInterest, importExtents,
overwriteTiles)
finishtime = time.clock()
elapsedtime = finishtime - starttime
#print messages to a file
while result.status < 4:
time.sleep(0.2)
resultValue = result.getMessages()
report.write ("completed " + str(resultValue))
print("Imported Map server Cache Tiles successfully for " + serviceName + \
" from " + sourceTilePackage + " to " + cacheDir + "\n using "+ areaOfInterest + \
" in " + str(elapsedtime) + " sec \n on " + arg2)
except Exception as e:
# If an error occurred, print line number and error message
tb = sys.exc_info()[2]
report.write("Failed at step 2 \n" "Line %i" % tb.tb_lineno)
report.write(str(e))
report.close()
print("Imported Map server Cache Tiles for the given feature class")
Environnements
Informations de licence
- Basic: Oui
- Standard: Oui
- Advanced: Oui
Rubriques connexes
Vous avez un commentaire à formuler concernant cette rubrique ?