マップ サービス キャッシュのエクスポート(Export Map Server Cache) (サーバ)

ライセンス レベル:BasicStandardAdvanced

サマリ

マップまたはイメージ サービスのキャッシュから、タイルをキャッシュ データセットまたはタイル パッケージとしてディスク上のフォルダにエクスポートします。タイルは、他のキャッシュにインポートするか、またはサービスから独立したラスタ データセットとして ArcGIS for Desktop またはモバイル デバイスからアクセスすることができます。

使用法

構文

ExportMapServerCache_server (input_service, target_cache_path, export_cache_type, copy_data_from_server, storage_format_type, scales, {num_of_caching_service_instances}, {area_of_interest}, {export_extent}, {overwrite_tiles})
パラメータ説明データ タイプ
input_service

エクスポートするキャッシュ タイルを含むマップまたはイメージ サービス。

これは、サーバとサービスの両方の情報を含む文字列です。この文字列の構築方法を確認するには、ArcCatalog を開き、カタログ ツリーでサービスを選択して、[場所] ツールバーに表示されているテキストを記録します。バックスラッシュをスラッシュに変更します(たとえば、GIS Servers/arcgis on MYSERVER (admin)/USA.MapServer)。

String
target_cache_path

キャッシュのエクスポート先のフォルダ。このフォルダは、登録済みサーバ キャッシュ ディレクトリである必要はありません。ArcGIS Server アカウントには、エクスポート先のキャッシュ フォルダに対する書き込みアクセス権が必要です。サーバ アカウントにエクスポート先のフォルダに対する書き込みアクセス権を付与できないときに、ArcGIS for Desktop クライアントにこのフォルダへの書き込みアクセス権がある場合は、[データをサーバからコピー] パラメータを選択します。

Folder
export_cache_type

キャッシュをキャッシュ データセットとしてエクスポートするか、タイル パッケージとしてエクスポートするかを選択します。ArcGIS Runtime および ArcGIS Mobile の配置では、タイル パッケージが適しています。

  • CACHE_DATASETArcGIS Server を使用して生成されるマップまたはイメージ サービス キャッシュ。ArcMap と、ArcGIS Server のマップまたはイメージ サービスで使用されます。これがデフォルト設定です。
  • TILE_PACKAGEキャッシュ データセットがレイヤとして追加され、簡単に共有できるように統合された単一の圧縮ファイル。ArcGIS for Desktop や、ArcGIS Runtime およびモバイル アプリケーションで使用できます。
String
copy_data_from_server

ArcGIS Server アカウントにエクスポート先フォルダに対する書き込みアクセス権を付与できないときに、ArcGIS for Desktop クライアントにこのフォルダへの書き込みアクセス権がある場合のみ、COPY_DATA に対するこのオプションをオンにします。ソフトウェアは、タイルをエクスポート先のフォルダに移動する前に、サーバの出力ディレクトリにエクスポートします。

  • COPY_DATAタイルはサーバの出力ディレクトリに配置された後、エクスポート先のフォルダに移動されます。ArcGIS for Desktop クライアントには、エクスポート先のフォルダに対する書き込みアクセス権が必要です。
  • DO_NOT_COPYタイルは直接エクスポート先のフォルダにエクスポートされます。ArcGIS Server アカウントには、エクスポート先のフォルダに対する書き込みアクセス権が必要です。これがデフォルト設定です。
Boolean
storage_format_type

エクスポートしたキャッシュの格納形式。

  • COMPACTタイルは、ディスク領域の節約とキャッシュのコピーの高速化を可能にするために、バンドル ファイルにグループ化されます。[エクスポートするキャッシュのタイプ](Python では export_cache_type)がタイル パッケージの場合は、これがデフォルトです。
  • EXPLODED各タイルは、個別のファイルとして格納されます(ArcGIS Server 10 よりも前のバージョンでのキャッシュの格納方法のように)。
String
scales
[scales,...]

タイルのエクスポート先の縮尺レベルのリスト。

Double
num_of_caching_service_instances
(オプション)

このツールの実行に専用で使用する、システム/CachingTools サービスのインスタンス数の合計。ArcGIS Server への管理者接続を通して使用できる [サービス エディタ] ウィンドウで、システム/CachingTools サービスの [コンピュータごとのインスタンスの最大数] の値を大きく変更することができます。選択したインスタンス数を、サーバ コンピュータでサポートできることを確認してください。

Long
area_of_interest
(オプション)

キャッシュからタイルをエクスポートする範囲を空間的に制限する対象エリア(ポリゴン)。フィーチャクラスを指定するか、ArcMap で対話的に定義するフィーチャを指定できます。このパラメータは不規則な形状のエリアをエクスポートする場合に有効です。ツールはキャッシュ データセットをピクセル解像度でクリップします。

対象エリアを指定しない場合、マップ全体がエクスポートされます。

Feature Set
export_extent
(オプション)

エクスポートするタイルを定義する矩形の表示範囲。デフォルトでは、表示範囲は、インポートするマップ サービスの全体表示に設定されます。このツールのオプション パラメータの [対象地域] を使用すると、矩形の代わりにポリゴンを使用してインポートを行えます。1 つのジョブに対して両方のパラメータを同時に指定しないようにすることをお勧めします。両方のパラメータを指定した場合は、[対象地域] パラメータが [インポート範囲] よりも優先されます。

Extent
overwrite_tiles
(オプション)
  • OVERWRITEエクスポートにより、対象エリアのすべてのピクセルが置き換えられます。エクスポート先のキャッシュ内にあるタイルを、作成されたキャッシュのタイルで完全に上書きします。
  • MERGE(マージする)タイルがインポートされたとき、元のキャッシュ内の透明なピクセルはデフォルトで無視されます。この結果、エクスポート先のキャッシュはマージまたはブレンドされます。これがデフォルト設定です。
Boolean

コードのサンプル

ExportMapServerCache(マップ サービス キャッシュのエクスポート)の例 1

格納形式をエクスプロードからコンパクトに変更して、フィーチャクラスのキャッシュ タイルをエクスポートします。

# Name: ExportMapServerCache.py for ArcGIS Server 
# Description: The following stand-alone script demonstrates how to export 
# 		cache as CACHE_DATASET in COMPACT storage format and MERGE tiles
#               using an AREA_OF_INTEREST to TARGET_CACHE_PATH
#		which is accessible to server instances 
# 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
targetCachePath 	= "C:/data/temp"
exportCacheType 	= "CACHE_DATASET"
copyDataFromServer 	= "DO_NOT_COPY"
storageFormat 		= "COMPACT"
scales 			= [500000,250000,125000,64000]
numOfCachingServiceInstances = "2"
areaOfInterest 		= "C:/data/101/Portland/Metro.shp"
exportExtents 		= ""
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 "scaleValues[0]","scaleValues[-1]","scaleValues[0:3]"

# Enter rectangular custom extent values for the "exportExtents" variable to
# constrain the exporting cache along the rectangular extents

try:
    starttime = time.clock()
    result = arcpy.ExportMapServerCache_server(inputService, targetCachePath,
                                               exportCacheType,
                                               copyDataFromServer,
                                               storageFormat, scales, 
                                               numOfCachingServiceInstances, 
                                               areaOfInterest, exportExtents, 
					       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 "Exported cache successfully for mapservice " + serviceName 
    " to " + targetCachePath + "\n using " + areaOfInterest + "\n in "
    str(elapsedtime) + " sec \n on " + arg2
    
except Exception, e:
    # If an error occurred, print line number and error message
    tb = sys.exc_info()[2]
    report.write("Failed at \n" "Line %i" % tb.tb_lineno)
    report.write(e.message)

print "Exported Map server Cache  using area of Interest"

report.close()

ExportMapServerCache(マップ サービス キャッシュのエクスポート)の例 2

ArcGIS Server インスタンスからエクスポート先のフォルダにアクセスできない場合に、キャッシュを TILE_PACKAGE としてエクスポートします。

# Name: ExportMapServerCache.py
# Description: The following stand-alone script demonstrates how to export cache
#               as TILE_PACKAGE for default number of scales of a service, to a 
#               TARGET_CACHE_PATH which is inaccessible to server instances using
#               COPY_DATA_FROM_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
targetCachePath = "C:/temp/usa"
exportCacheType = "TILE_PACKAGE"
copyDataFromServer = "COPY_DATA"
storageFormat = "COMPACT"
scaleValues = [500000,250000,125000,64000]
numOfCachingServiceInstances = "2"
exportExtents = ""
areaOfInterest = ""
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 "scaleValues[0]","scaleValues[-1]","scaleValues[0:3]"

try:
    starttime = time.clock()
    result = arcpy.ExportMapServerCache_server(inputService, targetCachePath,
                                               exportCacheType,
                                               copyDataFromServer,
                                               storageFormat, scales,
                                               numOfCachingServiceInstances,
                                               areaOfInterest,
                                               exportExtents, 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 "Exported cache successfully for mapservice " + serviceName + " to "
    targetCachePath + " in " + str(elapsedtime) + " sec \n on" + arg2

except Exception, 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(e.message)
    
print "Exported Map server Cache "

report.close()

環境

このツールはジオプロセシング環境を使用していません

関連トピック

ライセンス情報

ArcGIS for Desktop Basic: ○
ArcGIS for Desktop Standard: ○
ArcGIS for Desktop Advanced: ○
9/14/2013