MapProxy: Difference between revisions

From Wildsong
Jump to navigationJump to search
Brian Wilson (talk | contribs)
mNo edit summary
Brian Wilson (talk | contribs)
mNo edit summary
 
Line 4: Line 4:
There is a cache engine built into [[GeoServer]], I write about it here: [[GeoWebCache]],  
There is a cache engine built into [[GeoServer]], I write about it here: [[GeoWebCache]],  
I have tried to make it work but keep coming back to MapProxy because it's easier to set up.  
I have tried to make it work but keep coming back to MapProxy because it's easier to set up.  
== Local usage notes ==


I'm using MapProxy in Docker.
I'm using MapProxy in Docker.
Line 11: Line 13:
My github repository is https://github.com/wildsong/docker-mapproxy. The project contains more detailed notes.
My github repository is https://github.com/wildsong/docker-mapproxy. The project contains more detailed notes.


== Storage ==
=== Storage ===


I tried CouchDB as the data store for a few months until one day it stopped working. I switched back to files.
I tried CouchDB as the data store for a few months until one day it stopped working. I switched back to files.
MapProxy supports other back ends but it's hard to beat files for simplicity.
MapProxy supports other back ends but it's hard to beat files for simplicity.


== Compose ==
=== Compose ===


I started off using Docker Compose to start both MapProxy and CouchDB and to link the containers together.
I started off using Docker Compose to start both MapProxy and CouchDB and to link the containers together.
Line 22: Line 24:
a reverse proxy. At home I run it without a proxy, just using it for testing.
a reverse proxy. At home I run it without a proxy, just using it for testing.


== Oregon Explorer service glitch ==
=== Oregon Explorer service glitch ===


I figured out trial and error that two of the OE services won't deliver usable data on WMS,  
I figured out trial and error that two of the OE services won't deliver usable data on WMS,  
Line 33: Line 35:


API
API
Keep config in SQLite instead of flat files?
Read only


# usage stats
# usage stats
Line 42: Line 48:
# add a service
# add a service
# delete a service
# delete a service
Admin


# clear cache
# clear cache
Line 48: Line 56:
# get | set description
# get | set description


# Keep config in SQLite


=== Multiple services ===
=== Multiple services ===

Latest revision as of 17:39, 26 September 2021

Some map services are unreliable because they are unreachable, sometimes for days. I can address this problem using MapProxy though.

There is a cache engine built into GeoServer, I write about it here: GeoWebCache, I have tried to make it work but keep coming back to MapProxy because it's easier to set up.

Local usage notes

I'm using MapProxy in Docker. I started to install mapproxy directly on the host then realized yet again I'd be making a bunch of changes to the host just for this one app.

My github repository is https://github.com/wildsong/docker-mapproxy. The project contains more detailed notes.

Storage

I tried CouchDB as the data store for a few months until one day it stopped working. I switched back to files. MapProxy supports other back ends but it's hard to beat files for simplicity.

Compose

I started off using Docker Compose to start both MapProxy and CouchDB and to link the containers together. Putting it behind an ArcGIS Enterprise portal requires that it respond on port 443, so at work I do that with a reverse proxy. At home I run it without a proxy, just using it for testing.

Oregon Explorer service glitch

I figured out trial and error that two of the OE services won't deliver usable data on WMS, only on WMTS. Something to be aware of! I will probably drop them a line some day and ask why it's broken.

Wish list

How much of this can I do with Geoserver right now today?

API

Keep config in SQLite instead of flat files?

Read only

  1. usage stats
  2. storage usage
  3. cache status
  4. seed status
  5. backend info
  6. start / stop / restart a service
  7. add a service
  8. delete a service

Admin

  1. clear cache
  2. start stop seeding
  3. get | set thumbnail
  4. get | set description


Multiple services

I want to be able to group services, for example, a service called "or-ex"

Oregon Explorer
   OSIP2018
   NAIP2016
   etc

and one called "dogami"

 DOGAMI
   hillshade
   BE hillshade

so that I can group things in maps. I think the layout is supposed to be like this:

config/
  mapproxy.yaml -- default example not used in this case
  globals.yaml -- included from each file in services
  services/
    or-ex.yaml -- creates the service http://hostname/or-ex
    dogami.yaml -- creates the service http://hostname/dogami