Un servicio de imágenes en caché puede comportarse como un servicio de imágenes dinámico o estático. Generalmente, debido a la estructura en teselas y a la naturaleza estática de un servicio de imágenes en caché, será más rápido que uno que no esté almacenado en caché (o al que no se acceda como un servicio dinámico). Al acceder a un servicio de imágenes en caché, su comportamiento predeterminado es estático y tendrá acceso limitado a las propiedades del servicio, es decir, no puede modificar el método de mosaico ni la compresión de transmisión.
Cualquier aplicación Web que pueda mostrar un servicio de imágenes utiliza la caché, aunque la manera en la que se recuperan y utilizan las teselas varía entre las aplicaciones.
ArcMap y ArcGIS Pro
Cuando visualiza un servicio de imágenes que se ha almacenado en la caché, tendrá capacidades del servicio de imágenes limitadas. Por ejemplo, no podrá cambiar el método de mosaico o método de compresión de la transmisión. Pero todavía podrá hacer cosas como cambiar la simbología y la mejora, realizar una identificación de los píxeles, consultar los datos y descargar los datos de origen.
Si necesita trabajar con el servicio de imágenes de forma dinámica y usar una funcionalidad como, por ejemplo, el método de mosaico, puede cambiar el modo de la capa. Para cambiar el modo, haga clic con el botón derecho en la capa del servicio de imágenes y desactive Habilitar el modo de vista en caché. Para utilizar el servicio de imágenes como un servicio en caché, vuelva a activar esta opción.
Aplicaciones de ArcGIS API for JavaScript
Al programar con ArcGIS API for JavaScript, utilice la clase ArcGISTiledMapServiceLayer para conectarse a un servicio de imágenes en caché. Cuando utiliza el servicio en caché, las teselas se recuperan del directorio de caché mediante las llamadas REST al servicio de mapas. La solicitud de tesela toma la forma http://<image service URL>/tile/<level>/<row>/<column>.
Si ve URL como esta, su aplicación está obteniendo las teselas correctamente de las solicitudes REST:
http://gisserver.domain.com:6080/arcgis/rest/services/myService/ImageServer/tile/10/1723/3495
Si ve algún otro formato de dirección URL para su servicio de imágenes, su aplicación está recuperando la tesela de una manera menos eficiente o la caché no se está usando.
Si está viendo un servicio en caché simple en cualquier aplicación Web y realiza un desplazamiento panorámico en un área donde no existen teselas, la aplicación no muestra una imagen dinámica; por lo contrario, no ve nada.
Sugerencia:
Si el servicio de imágenes parece más lento de lo esperado, examine las direcciones URL del servicio de imágenes para verificar que la aplicación esté recuperando las teselas. Una forma de hacer esto es abrir la aplicación en Mozilla Firefox 4 y hacer clic en Firefox > Desarrollador web > Consola web. Cuando aparezca la consola, haga clic en el botón Red y, a continuación, haga zoom o desplace su servicio de imágenes.
Sugerencia:
Asegúrese de que los datos de la fuente de datos almacenados en la caché está en la misma proyección como el resto de los datos utilizados en la aplicación Web. Si no es así, es posible que no vea los datos, dado que la mayor parte de las aplicaciones web no pueden volver a proyectar los datos. Además, asegúrese de que el esquema de ordenamiento en teselas sea el mismo para el servicio de imágenes en caché como las otras capas en la aplicación Web en caché; de lo contrario, no todas las capas serán visibles.
Mejorar el rendimiento en la visualización de servicios de imágenes en caché
Cuando los clientes envían peticiones a ArcGIS Server para visualizar un servicio de imágenes, por lo general, el navegador almacena en caché la respuesta del servidor y se reutiliza durante cierto tiempo. Este comportamiento ayuda a ArcGIS Server a lograr el mejor rendimiento de visualización posible del servicio de imágenes. No obstante, según cómo se utilicen el servicio de imágenes y sus datos asociados en aplicaciones, es posible que deba ajustarse el tiempo durante el cual el navegador debe utilizar una respuesta del caché. Esto se puede lograr agregando una propiedad llamada cacheControlMaxAge en la Notación de objetos JavaScript (JSON) del servicio.
Cómo se utiliza la propiedad cacheControlMaxAge
Las respuestas del servicio de imágenes de ArcGIS Server incluyen un encabezado de etiqueta de entidad (ETag) y Cache-Control. El valor del encabezado ETag es un identificador único de la respuesta. El encabezado Cache-Control tiene un valor max-age que proporciona información al navegador en relación con el tiempo máximo durante el cual se puede reutilizar la respuesta del caché del navegador. Este valor se controla mediante la propiedad cacheControlMaxAge.
Si una solicitud se repite y no se ha superado la duración máxima del caché, el navegador utiliza la respuesta del caché sin enviar la solicitud al servidor. Si se ha superado la duración máxima del caché, el navegador debe enviar la solicitud al servidor y establecer un encabezado IF-NONE-MATCH con un valor de ETag asociado correspondiente a la respuesta en su caché. ArcGIS Server evalúa la solicitud y utiliza el valor de ETag para determinar si la respuesta ha cambiado. Si la respuesta del servidor es distinta de la copia que hay en el navegador, el servidor envía una respuesta nueva al navegador. Si la respuesta es idéntica a la copia que hay en el navegador, el servidor alerta al navegador para que continúe utilizando la respuesta que tiene en el caché.
Definición del valor de la propiedad cacheControlMaxAge
Como administrador de ArcGIS Server, puede definir la propiedad cacheControlMaxAge para especificar durante cuánto tiempo se permite al navegador utilizar una respuesta en caché. Puesto que se reduce la necesidad de que ArcGIS Server envíe respuestas completas, esto permite que el caché del navegador sea más eficiente, ayuda a optimizar las aplicaciones y ahorra ancho de banda.
En el caso de los servicios de imágenes en caché que no permiten a los clientes almacenar teselas en caché local, el valor predeterminado es 0. Esto significa que el navegador siempre vuelve a enviar las solicitudes y que ArcGIS Server procesará las solicitudes y enviará respuestas completas al navegador si el contenido ha cambiado.
En el caso de los servicios de imágenes en caché que permiten a los clientes almacenar teselas en caché local, el valor predeterminado es 12 horas (43.200 segundos). Esto significa que, si una solicitud se repite en un plazo de 12 horas, el navegador volverá a utilizar la respuesta de su caché. Este valor funciona correctamente para la mayoría de aplicaciones.
Más información sobre el almacenamiento en caché local
En el caso de los servicios de imágenes en caché en los que el mapa o los datos no cambian con frecuencia, se recomienda aumentar el valor predeterminado hasta 30 días (2.592.000 segundos) o más para minimizar el tráfico de la red.
Para agregar la propiedad cacheControlMaxAge a un servicio y especificar su valor predeterminado, se hace así:
- En un navegador web, abra el Directorio de administrador de ArcGIS Server e inicie sesión con un usuario que tenga privilegios de administración. La dirección URL tiene el formato https://gisserver.domain.com:6443/arcgis/admin.
- Haga clic en servicios y seleccione el servicio de imágenes que desea modificar en la lista Servicios. Si no ve el servicio en la lista, es posible que se encuentre en un directorio debajo de la carpeta Raíz.
- En la página Service - <service name> (<service type>), desplácese a la parte inferior y haga clic en editar.
- En el cuadro de diálogo Propiedades del servicio, busque la sección de propiedades del JSON del servicio.
- Agregue la propiedad cacheControlMaxAge a la sección y especifique el valor (en segundos) de la propiedad. Por ejemplo:
"properties": { "cacheControlMaxAge": "2592000",
- Haga clic en Guardar cambios.
- En la página Servicio - <nombre del servicio> (<tipo del servicio>), compruebe que la propiedad cacheControlMaxAge y el valor especificado aparezcan en la sección Propiedades.
Superponer cachés en aplicaciones Web
Como se ha indicado anteriormente, al diseñar las cachés del servicio de imágenes que se superpondrá con otros servicios en caché, hay factores de diseño de caché importantes que considerar. Las aplicaciones web creadas con ArcGIS API for JavaScript requieren que haga coincidir el sistema de coordenadas y el tamaño de teselas al superponer cachés. También es una buena práctica hacer coincidir la mayor cantidad de escalas posible. La forma más sencilla de hacer esto es hacer coincidir los esquemas de ordenamiento en teselas para las dos cachés y, a continuación, crear solamente las teselas en las escalas que tienen sentido para cada caché. De esta manera, puede asegurarse de que hizo coincidir el sistema de coordenadas y el tamaño de teselas y de que el software reconoce que las dos cachés tienen escalas en común.
El esquema de ordenamiento en teselas recomendado es el esquema de ordenamiento en teselas ArcGIS Online/Bing Maps/Google Maps.
OGC WMTS
La especificación Web Map Tile Service (WMTS) del Consorcio Geoespacial abierto (OGC) es una especificación internacional para proporcionar mapas digitales a través de la web con teselas de imágenes en caché. Cuando cree un mapa en caché o un servicio de imágenes utilizando ArcGIS Server, el servicio y sus teselas son accesibles mediante la especificación WMTS automáticamente.
La dirección URL para conectarse a un servicio de imágenes en caché utilizando el protocolo WMTS utiliza la siguiente patrón:
https://gisserver.domain.com:6443/arcgis/rest/services/folder/service/ImageServer/WMTS