Управление статусом кэша картографического сервиса (Сервер)

Сводка

Управляет хранящимися на сервере внутренними данными о созданных листах в кэше картографического сервиса или сервиса изображений.

Использование

  • Инструмент используется для перестроения статуса кэша после того, как вы вручную скопировали листы в директорию кэша либо построили листы по запросу.

  • Инструмент является единственным способом построения статуса кэша, созданного в предыдущей версии ArcGIS Server или Portal for ArcGIS.

  • Вместо создания статуса всего кэша вы можете воспользоваться этим инструментом, чтобы получить отчеты о статусе интересующих вас территорий и масштабных уровней. Вы можете добиться этого, установив для параметра Режим управления (manage_mode в Python) значение REPORT_BUNDLE_STATUS. Отчет сохраняется в новой файловой базе геоданных, названной Status.gdb, в классе объектов TaskStatus.

    Помните, что ваша директория кэша также содержит базу Status.gdb, относящуюся ко всему кэшу и обновляемую при использовании других опций Режима управления для этого инструмента. В этом местоположении вы не можете заменить базу Status.gdb на другую.

Синтаксис

arcpy.server.ManageMapServerCacheStatus(input_service, manage_mode, {scales}, {num_of_caching_service_instances}, {report_folder}, {area_of_interest}, {report_extent})
ParameterОбъяснениеТип данных
input_service

Слой изображения карты, у которого будет изменен статус кэша. Его можно выбрать, указав нужный сервис на портале или перетащив веб-слой листов с панели Каталог, с вкладки Портал, чтобы задать этот параметр.

Image Service; MapServer
manage_mode
  • DELETE_CACHE_STATUSУдаляет информацию о статусе, используемую сервером.
  • REBUILD_CACHE_STATUSУдаляет и создает заново информацию о статусе, используемую сервером.
  • REPORT_BUNDLE_STATUSСоздает информацию о статусе в новой базе геоданных Status.gdb в указанной вами в параметре Выходная папка директории. Данная опция используется, когда вы собираетесь создать пользовательский отчет о статусе для конкретной интересующей вас области либо определенного набора масштабов.
String
scales
[scales,...]
(Дополнительный)

Масштабные уровни, для которых будет изменен статус. Этот параметр применим только при создании пользовательского статуса с использованием опции REPORT_BUNDLE_STATUS для параметра manage_mode.

Double
num_of_caching_service_instances
(Дополнительный)

Задает число экземпляров, использующихся для обновления/создания листов. Значение этого параметра установлено как – без ограничений (-1) и не может быть изменено.

Long
report_folder
(Дополнительный)

Выходная директория для базы Status.gdb. Этот параметр применяется только при создании пользовательского статуса с использованием опции REPORT_BUNDLE_STATUS.

Folder
area_of_interest
(Дополнительный)

Область интереса (полигон), определяющая территорию, покрываемую отчетом о статусе. Этот параметр применяется только при создании пользовательского статуса с использованием опции REPORT_BUNDLE_STATUS.

Feature Set
report_extent
(Дополнительный)

Прямоугольный экстент определяет территорию, для которой будет построен статус. Этот параметр применяется только при создании пользовательского статуса с использованием опции REPORT_BUNDLE_STATUS.

Помните, что параметр area_of_interest позволяет вам указать непрямоугольную интересующую вас область.

  • MAXOF - будет использоваться максимальный экстент всех входных данных.
  • MINOF - будет использоваться минимальная область, общая для всех входных данных.
  • DISPLAY– экстент будет равен видимому отображению.
  • Имя слоя - будет использоваться тот же экстент, что и в указанном слое.
  • Объект Extent - будет использоваться тот же экстент, что и в указанном объекте.
  • Строка координат, разделенных пробелами – будет использоваться экстент из заданной строки. Координаты должны быть выражены в таком порядке: x-min, y-min, x-max, y-max.
Extent

Производные выходные данные

NameОбъяснениеТип данных
output_folder

Выходной URL-адрес сервиса.

Строковое

Пример кода

Пример ManageMapServerCacheStatus, (автономный скрипт)

Удаление информации о статусе кэша.

# 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,
                                                     manageMode, scales,
                                                     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 as 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(str(e))

report.close()

Environments

Этот инструмент не использует параметры среды геообработки

Информация о лицензиях

  • Basic: Да
  • Standard: Да
  • Advanced: Да

Связанные разделы