Управление статусом кэша картографического сервиса (Сервер)
Краткая информация
Управляет хранящимися на сервере внутренними данными о созданных листах в кэше картографического сервиса или сервиса изображений.
Использование
- Данный инструмент может удалить или перестроить информацию о статусе кэша в ArcMap или ArcGIS Server Manager.
Инструмент используется для перестроения статуса кэша после того, как вы вручную скопировали листы в директорию кэша либо построили листы по запросу.
Инструмент является единственным способом построения статуса кэша, созданного в предыдущей версии ArcGIS Server.
Вместо создания статуса всего кэша вы можете воспользоваться этим инструментом, чтобы получить отчеты о статусе интересующих вас территорий и масштабных уровней. Вы можете добиться этого, установив для параметра Режим управления (Manage Mode) (manage_mode) значение REPORT_BUNDLE_STATUS. Отчет сохраняется в новой файловой базе геоданных, названной Status.gdb, в классе объектов TaskStatus, которые вы можете просматривать в ArcMap.
Помните, что ваша директория кэша также содержит базу Status.gdb, относящуюся ко всему кэшу и обновляемую при использовании других опций Режима управления (Manage Mode) для этого инструмента. В этом местоположении вы не можете заменить базу Status.gdb на другую.
Синтаксис
Параметр | Объяснение | Тип данных |
input_service | Картографический сервис или сервис изображений, статус которого будет изменен. Это строка, содержащая информацию как о сервере, так и о сервисе. Чтобы узнать, как сформировать эту строку, откройте ArcCatalog, выберите свой сервис в дереве каталога и обратите внимание на текст на панели инструментов Местоположение (Location). Затем поменяйте обратные косые черты на прямые, например GIS Servers/arcgis on MYSERVER (admin)/USA.MapServer. | String |
scales (дополнительно) |
Масштабные уровни, для которых будет изменен статус. Этот параметр применим только при создании пользовательского статуса с использованием опции REPORT_BUNDLE_STATUS параметра manage_mode. | Double |
manage_mode |
| String |
num_of_caching_service_instances (дополнительно) |
Общее количество экземпляров сервиса System/CachingTools, которые вы хотите выделить для работы этого инструмента. Вы можете увеличить Максимальное число экземпляров на компьютер (maximum number of instances per machine) сервиса System/CachingTools с помощью окна Редактор сервисов (Service Editor), доступного через административное подключение к ArcGIS for Server. Убедитесь, что ваши серверы смогут поддерживать выбранное количество экземпляров. Данный инструмент использует по умолчанию три экземпляра, если они доступны. Использование большего числа экземпляров инструментом может привести к слишком медленному выполнению операции. | Long |
report_folder (дополнительно) |
Выходная директория для базы Status.gdb. Этот параметр применяется только при создании пользовательского статуса с использованием опции REPORT_BUNDLE_STATUS. Для учетной записи, под которой был запущен ArcGIS for Desktop, необходимы права на запись данных в эту папку. В папке должна обязательно находиться база Status.gdb. | Folder |
report_extent (дополнительно) |
Прямоугольный экстент определяет территорию, для которой будет построен статус. Этот параметр применяется только при создании пользовательского статуса с использованием опции REPORT_BUNDLE_STATUS. Помните, что параметр Область интереса (Area Of Interest) позволяет вам указать непрямоугольную интересующую вас область. | Extent |
area_of_interest (дополнительно) |
Область интереса (полигон), определяющая территорию, покрываемую отчетом о статусе. Это может быть класс объектов или функция, интерактивно определенная в ArcMap. Этот параметр применяется только при создании пользовательского статуса с использованием опции REPORT_BUNDLE_STATUS. | Feature Set |
Пример кода
ManageMapServerCacheStatus example
Удаляет информацию о статусе кэша.
# Name: ManageMapServerCacheStatus.py
# Description: The following stand-alone script demonstrates how to delete
# Status of cache using ManageMapServerCachStatus tool
# 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.MapService"
inputService = connectionFile + "\\" + server + "\\" + serviceName
scales = ""
manageMode = "DELETE_CACHE_STATUS"
numOfCachingServiceInstances = "2"
outputFolder = ""
areaOfInterest = ""
reportExtents = ""
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.ManageMapServerCacheStatus_server(inputService, scales[-1],
manageMode,
numOfCachingServiceInstances,
outputFolder,
areaOfInterest,
reportExtents)
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 "Reported the Bundle status for scale =" + str(scales[-1]) + "of "
serviceName + "at " + outputFolder + "\n using specified feature class "
areaOfInterest + " 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 3 \n" "Line %i" % tb.tb_lineno)
report.write(e.message)
report.close()