Concurrent Web Map Cache Server: A “Web 2.0 Meets SOA” Case Study

Slides:



Advertisements
Similar presentations
Concurrent Web Map Cache Server Zao Liu, Marlon Pierce, Geoffrey Fox Community Grids Laboratory Indiana University.
Advertisements

1 - 1 Concurrent Web Map Cache Server A Vision for IndianaMap Zao Liu, Marlon Pierce, Geoffrey Fox Community Grids Laboratory Indiana University Neil Devadasan.
Visualizing maps on the web. What is a Map? A map is a drawing that is the representation, on a certain scale, of a terrain.
Web GIS Oregon Explorer Marc G Rempel Oregon State University The Valley Library Oregon Explorer
Copyright 2004 Monash University IMS5401 Web-based Systems Development Topic 2: Elements of the Web (g) Interactivity.
Europe’s Information Society eContentplus OrléansWP6 1st Coordination and progress meeting Technical information OGC WMS – WFS – CSW.
Browsers and Servers CGI Processing Model ( Common Gateway Interface ) © Norman White, 2013.
Server-Side vs. Client-Side Scripting Languages
Welcome to EDINA Digimap Digimap is an EDINA service offering online access to a range of spatial data. It is authenticated using Athens and is available.
Geospatial Content-Based Image Retrieval Viewing Interface MENTORS: Dr. Chi-Ren Shyu Matt Klaric BY: Abdulmajed Al-Meshaal Neil Timmerman.
Week 2 IBS 685. Static Page Architecture The user requests the page by typing a URL in a browser The Browser requests the page from the Web Server The.
1 Dynamic Map Service Integration Tool Mashing.
Using AJAX Galip Aydin, Ahmet Sayar, and Marlon Pierce Community Grids Lab Indiana University.
Part or all of this lesson was adapted from the University of Washington’s “Web Design & Development I” Course materials.
WebGIS. Web & GIS ….WebGIS Access without purchasing proprietary software Data directly from producer Emerging new market.
Internet GIS. A vast network connecting computers throughout the world Computers on the Internet are physically connected Computers on the Internet use.
Client/Server Architectures
Managing Data Interoperability with FME Tony Kent Applications Engineer IMGS.
Developing Health Geographic Information Systems (HGIS) for Khorasan Province in Iran (Technical Report) S.H. Sanaei-Nejad, (MSc, PhD) Ferdowsi University.
Sharing Geographic Content
VAP What is a Virtual Application ? A virtual application is an application that has been optimized to run on virtual infrastructure. The application software.
INTRODUCTION TO WEB DATABASE PROGRAMMING
M. Taimoor Khan * Java Server Pages (JSP) is a server-side programming technology that enables the creation of dynamic,
FALL 2005CSI 4118 – UNIVERSITY OF OTTAWA1 Part 4 Web technologies: HTTP, CGI, PHP,Java applets)
By Mihir Joshi Nikhil Dixit Limaye Pallavi Bhide Payal Godse.
City of Santa Cruz Embraces AGS/Flex
US Army Corps of Engineers DGI Europe 2008 Interoperability & Collaboration Focus Day Joel Schlagel & Michael Smith US Army Corps of Engineers Hanover,
GIS technologies and Web Mapping Services
About Dynamic Sites (Front End / Back End Implementations) by Janssen & Associates Affordable Website Solutions for Individuals and Small Businesses.
Distributed Voyager (DVoy) Web Services
M i SMob i S Mob i Store - Mobile i nternet File Storage Platform Chetna Kaur.
Jeremy D. Bartley Kansas Geological Survey An Introduction to an Index of Geospatial Web Services.
U.S. Environmental Protection Agency WATERS Status Update
9 Chapter Nine Compiled Web Server Programs. 9 Chapter Objectives Learn about Common Gateway Interface (CGI) Create CGI programs that generate dynamic.
An Introduction To Building An Open Standard Web Map Application Joe Daigneau Pennsylvania State University.
material assembled from the web pages at
Data Scrounging 101 Steve Signell, Instructor Robert Poirier, TA School of Science Rensselaer Polytechnic Institute Monday,
The 2000 Decennial Census School District Project: Using Census Data for the School District Mapping System **** Development and Implementation Tai A.
QuakeSim Work: Web Services, Portlets, Real Time Data Services Marlon Pierce Contributions: Ahmet Sayar,
GIS On The Web: An Overview of ArcIMS. *The easy flow of geographic data can offer real-life solutions in many societal sectors, including municipal government,
Best Practices for Designing Effective Map Services Tanu Hoque.
Enabling High-Quality Printing in Web Applications
Chapter 6 Server-side Programming: Java Servlets
Advanced Computer Networks Topic 2: Characterization of Distributed Systems.
Concurrent Web Map Cache Server A “Web 2.0 Meets SOA” Case Study Zao Liu, Marlon Pierce, Sunghoon Ko, Geoffrey Fox Community Grids Laboratory Indiana University.
1 Geospatial and Business Intelligence Jean-Sébastien Turcotte Executive VP San Francisco - April 2007 Streamlining web mapping applications.
ICDL 2004 Improving Federated Service for Non-cooperating Digital Libraries R. Shi, K. Maly, M. Zubair Department of Computer Science Old Dominion University.
RSISIPL1 SERVICE ORIENTED ARCHITECTURE (SOA) By Pavan By Pavan.
Integrating Geographical Information Systems and Grid Applications Marlon Pierce Contributions: Ahmet Sayar,
March 2005 IGIC Statewide GIS Conference The IndianaMap Roll-out Project Presented By: Neil M. Devadasan, The POLIS Center Philip S. Worrall, Innovative.
Web Design and Development. World Wide Web  World Wide Web (WWW or W3), collection of globally distributed text and multimedia documents and files 
Internet Applications (Cont’d) Basic Internet Applications – World Wide Web (WWW) Browser Architecture Static Documents Dynamic Documents Active Documents.
Team Members Charles Dunbar Ben Kallal Ankit Patel Peter Purcell Kody Reynolds 1 IRP Presentation Client Lisa Hein-Iowa Natural Heritage Foundation Faculty.
REST By: Vishwanath Vineet.
1 - 1 Concurrent Web Map Cache Server A Vision for IndianaMap Zao Liu, Marlon Pierce, Geoffrey Fox Community Grids Laboratory Indiana University Neil Devadasan.
©2010 AIR WORLDWIDE 1 Using ArcGIS Server Web Map Services in Web Map Mash-Ups Benjamin Spaulding, Ph.D. AIR Worldwide Esri Boston Dev Meet-Up 12/8/2010.
Publishing GIS Services to ArcGIS Server
Copyright © 2004, Keith D Swenson, All Rights Reserved. OASIS Asynchronous Service Access Protocol (ASAP) Tutorial Overview, OASIS ASAP TC May 4, 2004.
Copyright 2007, Information Builders. Slide 1 iWay Web Services and WebFOCUS Consumption Michael Florkowski Information Builders.
® ® copyright © 2013 Open Geospatial Consortium What HTML5 and REST mean to the Geo community Raj Singh, PhD Open Geospatial Consortium
Building Preservation Environments with Data Grid Technology Reagan W. Moore Presenter: Praveen Namburi.
GeoServer Prof. Wenwen Li School of Geographical Sciences and Urban Planning 5644 Coor Hall
Copyright, Open Geospatial Consortium Making Location Count Peer-to-Peer File Sharing An Answer to the SDI blues North Carolina GIS Conference February,
AMSA TO 4 Advanced Technology for Sensor Clouds 09 May 2012 Anabas Inc. Indiana University.
X3D Technology Approach for Developing 3D Web-GIS System
Working with Feature Layers
The Improvement of PaaS Platform ZENG Shu-Qing, Xu Jie-Bin 2010 First International Conference on Networking and Distributed Computing SQUARE.
WebEx and Comparison of WebEx, Centra, PlaceWare, Latitude
Voter Information Portal
Mixed Reality Server under Robot Operating System
Presentation transcript:

Concurrent Web Map Cache Server: A “Web 2.0 Meets SOA” Case Study Zao Liu, Marlon Pierce, Sunghoon Ko, Geoffrey Fox Community Grids Laboratory Indiana University & Neil Devadasan Polis Center Indiana University Purdue University Indianapolis It’s a program which could be considered as a web map service based on several existing GIS server.

GIS Map Servers as a Web 2.0 Case Study There are several different products for creating on-line maps and allowing interaction with Geographical Information System (GIS) data bases. ESRI, Autodesk, Open Geospatial Consortium These follow a classic user driven request/response style model. Google Maps (released in 2005). Highly interactive AJAX style clients replaced stodgy user-driven request/response. See http://www.collab-ogce.org/GGF15 Workshop for more information. More importantly, any one could use the JavaScript API to make really sophisticated applications.

Building a Hybrid System Google Maps provide a highly interactive user interface and capabilities (geolocations, directions) But GIS services have much more detailed local information. Indiana has orthophotography with much higher zoom levels than Google maps. http://www.indiana.edu/~gisdata/05orthos.html Local county servers have many interesting map layers not in Google Parcels/property lines, school district lines And these tie into feature services with interesting data like pinpoint addresses, tax assessments, etc. So obviously it makes sense to adopt the Google approach but enhance it with local data. Ultimately we hope to ties this into representations of scientific data generated on the Grid.

Marion County Map Server (ESRI ArcIMS) Hamilton County Map Server Google Maps Server Marion County Map Server (ESRI ArcIMS) Hamilton County Map Server (AutoDesk) Cass County Map Server (OGC Web Map Server) Must provide adapters for each Map Server type . Cache Server Tile Server Adapter The tile server fulfills Google map calls with cached tiles at the requested bounding box that fill the bounding box. Cache Server requests map tiles at all zoom levels with all layers. These are converted to uniform projection, indexed, and stored. Overlapping images are combined. Browser client fetches image tiles for the bounding box using Google Map API. Browser + Google Map API 4

Building a Cache Server Reverse engineering Map Server requests.

Federating GIS Servers Around Indiana Indiana has 92 counties Approximately 15 have public GIS map servers. Examples ESRI ArcIMS and ArcMap Server Marion, Vanderburgh, Hancock, Kosciusco, Huntington, Tippecanoe Autodesk MapGuide Hamilton, Hendricks, Monroe, Wayne WTH Mapserver™ Web Mapping Application (OGC Minnesota Map Server) Fulton, Cass, Daviess, City of Huntingburg Also there are state-wide GIS servers Orthophotography from Indiana University Indiana Geological Survey These are not normally interoperable.

Map Requests for ArcIMS and ArcMap Map image requests for ESRI ArcIMS and ArcMap are based on ArcXML ESRI sends SOAP-like XML over HTTP. Note the generated image is left on the server. Client has to retrieve it in a separate step. Server cleans up images every 10 minutes or so (a configurable parameter).

Map Requests for other type of Servers Map requests for other type of servers are using HTTP GET method. Trick is to figure out the correct format for the name/value pairs. Requesting format of MapGuide and WMS is almost the same Map image is directly returned in the HTTP response (GIF, JPG, etc) Request for AutoDesk MapGuide Server http://litemap.co.hamilton.in.us:8080/liteview/servlet/MapGuideLiteView?VERSION=1.1.1&REQUEST=Gemap&LAYERS=COUNTY_PLAN.MWF\parcels&SRS=EPSG:4326&BBOX=86.0009765625,40.06125658140474,85.99960327148438,40.062307630891&WIDTH=256&HEIGHT=256&FORMAT=image/png&BGCOLOR=0xFFFFFF&TRANSPARENT=TRUE&WMTVER=1.1.1&STYLES= Request for WTH Web Map Server http://thinkopengis.wthengineering.com/cgibin/mapserv.exe?map=cass0805.map&VERSION=1.1.1&REQUEST=GetMap&LAYERS=parcels,roads,highways&SRS=EPSG:4326&BBOX=86.4596523336861,40.6980435683496,86.3180175693406,40.7924667445799&WIDTH=600&HEIGHT=400&FORMAT=image/png&BGCOLOR=0xFFFFFF&TRANSPARENT=FALSE&WMTVER=1.1.1

County Boundaries To take advantage of highly accurate local data for use statewide, a variety of technical issues must be overcome such as: Projecting the information to a single coordinate system Standardizing symbols Retrieving individual Layers .

Caching for Performance County Server Performance is constrained by the performance of the individual servers. Cache Server We have implemented two methods to achieve this. One is an agent server which will wait for a user’s connection, then check the user’s operation to see how many counties’ service it requires, then send requests to all those county servers, wait for their responses and then combine the maps to return to the user. The response time in this schema is quite long, since the users have to wait enough time for remote county servers to generate maps, plus the time for our agent server to combine the map, then transfer it back. Besides, in this method, if one county server doesn’t work, our agent server will not response to client neither. Obviously this is not suitable for AJAX style applications. We need to pre-fetch and store as tiles. 10

Building a Tiling Server Reverse engineering Google’s map server.

Tiling Strategy Google Maps works by delivering map tiles that fill a bounding box. Google Map API 2.0 lets you point at your own tile server. We use this to serve up our own map data together with Google maps. To do this, all tiles should be saved as the same bounding box as Google map tiles. Tiles must have same size, projection, and coordinate values as underlying Google base maps. Each tile uses tile ID and zoom level as its name (ie, tile36.48.10), so no database is needed to find the tile. Our tile naming convention based on Google’s lat/lon to transverse Mercator projection. tileX.Y.Zoom, but must first convert lat and lon to rectangular coordinates. Naming convention discussed on next slide. See http://mapki.com/wiki/Lat/Lon_To_Tile Using zoom level as the first-level directory and layer as the second-level directory to store tiles.

Converting bounding box to Google tile values Google uses an x,y coordinate system combined with a zoom value to specify the tiles to retrieve from the server. These coordinates are calculated using an algorithm which can be found in GoogleMapki. See: http://www.codeproject.com/useritems/googlemap.asp Find the bounding box of Indiana which covers all the state. Convert the latitude value and longitude value of the bounding box into the Google map tile coordinate values. Identify the tile coordinate values in the bounding box. Convert the tile ID into the latitude and longitude values. Use Indiana Geology Survey’s service to match county to tile. Store in database. We can pre-fetch tiles by sending request to the county server that these tiles belong to and fetch the tile back. Steps for fetching image tiles from county map servers that match Google map tiles. Example Tile: http://mt0.google.com/mt?n=404&v=w2.37&x=0&y=0&zoom=16.

Naming Tiles Example Tile 1 (36,47) Tile 4 (37,47) Tile 2 (36,48) Convert A, B lat/lon values to Google map tile values at a given zoom level. Value for A is (36,47), B is (37,49) Calculating how many tiles there are in this bounding box and identify each tile’s value. In this figure, there are (37-46+1)*(49-37+1) = 6 tiles (our choice). For each tile in the bounding box, we can convert it’s tile coordinate values into lat/lon values. Using each tile lat/lon values to construct requests for IGS boundary services. IGS Services will tell which counties are at least partially in this tile. The site for IGS services is: http://igs.indiana.edu/ Save the tile-county mapping in our database. For a given tile name, we can look up the county. Tile 1 (36,47) Tile 4 (37,47) Tile 2 (36,48) Tile 5 (37,48) Tile 3 (36,49) Tile 6 (37,49) Bounding box of Indiana at zoom level 10 B(-84.6, 37.1)

Combine Google map with county parcel data Map servers typically contain base maps and optional layers. Parcel boundaries, roads, and township boundaries are layers. We cache each layer separately. Layers and base maps are combined dynamically using Java Advanced Image libraries. 15

Matching Projections: EPSG4326 to Mercator County map over-layer from IGS is in EPSG4326 projection. Must convert to Mercator to match Google. 16

Combine tiles at County Boundaries Marion County Hancock County The communication between two MapFacher threads occurs on the boundary cases. As the graph in this slide, while a MapFecher is working on its county’s image retrieving, it might get a map like this. While XmlFetcher request for maps, it might send request for the same coordinates to several county servers if the map covers more than one county. And the image generated by each remote server would seemed like this. So that while the mapfecher is working, it will still fetch this map and then try to break it into tiles, but as we can see, there will be many useless tiles contains nothing in it. In addition, in order to be able to combine to a map across boundary, all the mapfetcher need to store all those tiles even they have the same coordinates. While our program is running, we found that in many map fetcher’s local directory, it is frequently that many small tiles are empty only few of them contains useful info. County boundary tiles need to be combined to one tile by use Java Advanced Image Library

Next Steps Caching more regions in Indiana and elsewhere. If county uses ESRI or OGC map server, current agent plugins can be used. We would like to do California next. Use to represent outputs of scientific applications. Contour plots, vector maps, and other types of layers for displaying results of geophysical applications. Dynamic (“real time” layers) to display streaming data from instruments and applications. Find a way to keep current with county servers, especially when the county server change layer id. Recent Monroe county example The tiling services should support multiple server styles URLs for REST/AJAX style clients WSDL and SOAP for formal Web Services Support OGC and ESRI clients. Improve collaborative clients

Observations and Conclusions Web 2.0 approaches are very compatible with SOA in general... Although the details are important. But we have to do a better job making services. We are very good at making complicated interfaces to simple services. Programmable Web lists 350+ simple public APIs to complicated services. Science Gateways will change dramatically. We have been burdened down by security issues that Google et al ignore. Portals tend to be dominated by server-side, Enterprise standards, while mash-ups favor thicker browser clients and looser standards Judge a service by popularity rather than number of pages in the specification. And it’s the data...we need to find better ways to use Grids like the TeraGrid to populate data services. Computations will always require expertise. Grid software is useful for computing experts. But not everyone needs this. We need to think of better ways for archiving and delivering computational results.

More Information mpierce@cs.indiana.edu See demo: http://156.56.104.164/demo/indianaViewer.html Collaborative version: http://156.56.104.164/samples/CollabmapUpdate/indianaViewer.html Need a) Flash, and b) a friend to also try. Buggy still, so you have to login at the same time.

Comparison of state and county data 10 foot contours (1990) 1 foot contours (2006) Missing local roads Local roads (2006) No parcels Parcels (2006) No point addresses Point addresses (2006) Jurisdictional boundaries (2001) Jurisdictional boundaries (2006)

Basic Problem: Data Federation Integrated GIS systems have obvious benefits but inevitably systems are developed by various state and local government agencies. Bottom up rather than top down This tends to give excellent local information but it breaks down at the county boundary.

Considerations We assume heterogeneity in GIS map and feature servers. Must find a way to federate existing services We must reconcile ESRI, OGC, Google Map, and other technical approaches. Make a clean distinction between clients and services Must try to take advantage of Google, ESRI, etc rather than compete. We must have good performance and interactivity. Servers must respond quickly--launching queries to 20 different map servers is very inefficient. Clients should have simplicity and interactivity of Google Maps and similar AJAX style applications.

Backup Slides

Developing issues Integrating GIS map servers is not trivial Different county map servers may use different technologies and web services. Interoperability of Geospatial Referencing: Different coordinate systems and projections are used by the different county web services. Semantic Interoperability: Different attribute names for layers are used by the different county web services. Our solution: create a virtual map server to act as an agent server Translates map requests from generic format to the format expected by the specific map server. Provides a common language and programming interface for constructing clients Projecting the information to a single coordinate system Standardizing symbol The agent server by itself will work but performance is not good Must wait for slowest server to respond Failure prone: a county server may not respond at all Adds additional overhead for combining images

Caching Server The agent server runs offline to harvest map images from county map servers. Images are stored as tiles. Tiles at county boundaries may be combined for greater storage and performance efficiency. Clients connect to the cache server instead of the agent server. The cache server constructs the requested image from pre-fetched tiles. Inspired by Google Maps approach Enable more interactive clients Image construction may be parallelized/multi-threaded for greater performance. Potentially takes advantage of new multi-core server architectures from Sun, Intel, and AMD.

Two Phase Approach: Caching and Tiling Federation through caching: WMS and WFS resources are queried and results are stored on the cache servers. WMS images are stored as tiles. These can be assembled into new images on demand (c. f. Google Maps). Projections and styling can be reconciled. We can store multiple layers this way. We build adapters that can work with ESRI and OGC products; tailor to specific counties. Tiling: Client programs obtain images directly from our tile server. That is, don’t go back to the original WMS for every request. Similar approaches can be used to mediate WFS requests. The tile server can re-cache and tile on demand if tile sections are missing. Google Map Clients can work with tiling server. 27

Cache Server architecture IGS boundary- checking service Tile-County Mapping Process County Web Map Services County Map Fetcher thread County Web Map Services County Map Fetcher thread Database County Web Map Services County Map Fetcher thread County Boundary Fetcher thread which need to use JAI library to combine tiles from different counties. County Web Map Services County Web Map Services 1 - 28 28

Building Indiana Map client Using Google Map API Google Map API V2 enables us to add custom map directly on Google Map . See http://mapki.com/wiki/Add_Your_Own_Custom_Map To utilize Google map API to build Indiana map client, there are several steps: Register for using Google map API Create a collection of copyrights. Give those copyright collections to all tile layers that we want to add on Google Map. Pass those tile layer(s) off to create a map type. Once a map type has been created, it can be added to our map instance in our JavaScript code. 29

Example code for building custom map on Google Map Create a GCopyright var copyright = new GCopyright(1, new GLatLngBounds(new GLatLng(-90, -180), new GLatLng(90, 180)), 0, “@Indiana Geology Survey"); Add the GCopyright to a GCopyrightCollection var copyrightCollection = new GCopyrightCollection('Chart'); copyrightCollection.addCopyright(copyright); Create a GTileLayer array var tilelayers = [new GTileLayer(copyrightCollection , 3, 11)]; tilelayers[0].getTileUrl = CustomGetTileUrl; function CustomGetTileUrl(a,b) { var z = 17 - b; var f = "/maps/?x="+a.x+"&y="+a.y+"&zoom="+z; return f; } Create a GMapType var custommap = new GMapType(tilelayers, new GMercatorProjection(12), "Chart", {errorMessage:"No data available"}); Add the custom map type to the map map.addMapType(custommap); Once the maptype added to the map container, this type layer could be controlled as Google map. 30

Collaborative Indiana Map Flex data service from Adobe which is the basic technology used to support collaboration of Indiana map clients. Enables innovative applications to be delivered in the browser in a reliable and scalable manner. Enables data to automatically be pushed to the client application without polling. Enables a client application to concurrently share data with other clients or other servers. This model enables new application concepts like “co-browsing” and synchronous collaboration. The Flex module adds the following collaboration features to Google Maps: Map sharing: Maps are kept in sync (in real time) between users involved in a collaboration session. Videoconferencing (Webcam sharing and VOIP): You can share your Webcam and microphone to add video and audio to your collaboration session. White-board: Collaborating users can draw on the map. For example you could draw potential directions, etc. The users’ whiteboards are kept in sync in real time. Chat-board: Collaborating users can chat on the chat-board in real time. Cursor sharing: When you move your mouse, other users see the movements of your mouse and what you are pointing at. Using flex API to communicate with Ajax and Javascript to implement rich web applications. 31

Flex runtime architecture To enable collaboration, clients need flash player first installed. To the clients who subscribe to the same channel which configured in the flex data services, the events invoked in one client could broadcast to other clients to enable collaboration. Clients can make direct calls to Java objects as well as subscribe to real-time data feeds, send messages to other clients, and integrate with existing Java Message Service (JMS) messaging systems. 32

Storage of caching entire state Currently storing 15 counties at 13 zoom levels for 13 layers. It is takes ~250 GB. Takes about 2.5-3 TB to store the entire state to zoom level 13 this way. There are 48410476 tiles for zoom levels 0-13, 162561384 tiles for 0-14 levels (nearly 12 TB). There are ~10 layers for each scale Aerial photo layer tiles take 25~30 KB Other layers (parcels, roads) are much smaller: 30~36 KB for all remaining 9 layers per tile So we need almost 60KB * 48410476 tiles to store all map data Layers from Google (Hybrids, Street, Google Satellite) don’t need to be cached. This is large but possible. We can easily spread our caching server over multiple hosts to store even higher magnification scales. Efficient tiling storage can save disk space. 33

Current Progress Supports ESRI and OGC servers Now 17 counties is being cached. (Marion, Monroe are fully cached for 13 zoom levels) 7 layers has been proved that they can be easily cached. Aerial photo layer, street , interstate layer, parcel, parcel ID, county boundary, school). 3 more layers can be easily shown in client without caching. (Google Map, Google Satellite, Hybrids). Querying parcel information across boundary. ( MARION-HANCOCK boundary) Support Geocode querying. Higher resolution than Google Satellite. Google Map-like interaction. Performance and Reliability. Cache Server still work even the county server doesn’t work. Much faster response to the client. 34

Tradeoffs of Caching Cached images must be store somewhere. More zoom levels, much more disk space is needed. For 12 levels, 500-600 GB. For 13 levels, 2.5-3 TB. For 14 levels, about 12 TB. (It may be not necessary to cache this zoom level for all counties. We can cache this level for the requirement of some place. Difficulty of map re-projection. Latency of keeping update with county servers. Inconsistencies in available layers. 35