Terracotta ist ein reiner Python-Kachelserver, der als WSGI-App auf einem dedizierten Webserver oder als serverlose App auf AWS Lambda läuft. Es basiert auf einem modernen Python-Stack und wird von großartiger Open-Source-Software wie Flask, Zappa und Rasterio unterstützt.
Lesen Sie die Dokumente | Testen Sie die Demo | Entdecken Sie die API | Satlas, angetrieben von Terrakotta | Docker-Image
terracotta serve -r {name}.tif
und terracotta connect localhost:5000
bringen Sie dorthin.$ ls -lh
total 1.4G
-rw-r--r-- 1 dimh 1049089 231M Aug 29 16:45 S2A_20160724_135032_27XVB_B02.tif
-rw-r--r-- 1 dimh 1049089 231M Aug 29 16:45 S2A_20160724_135032_27XVB_B03.tif
-rw-r--r-- 1 dimh 1049089 231M Aug 29 16:46 S2A_20160724_135032_27XVB_B04.tif
-rw-r--r-- 1 dimh 1049089 231M Aug 29 16:56 S2A_20170831_171901_25XEL_B02.tif
-rw-r--r-- 1 dimh 1049089 231M Aug 29 16:57 S2A_20170831_171901_25XEL_B03.tif
-rw-r--r-- 1 dimh 1049089 231M Aug 29 16:57 S2A_20170831_171901_25XEL_B04.tif
$ terracotta optimize-rasters * .tif -o optimized/
Optimizing rasters: 100% | ██████████████████████████ | [05: 16< 00:00, file = S2A_20170831_...25XEL_B04.tif]
$ terracotta ingest optimized/S2A_{date}_{}_{tile}_{band}.tif -o greenland.sqlite
Ingesting raster files: 100% | ███████████████████████████████████████████ | 6/6 [00: 49< 00:00, 8.54s/it]
$ terracotta serve -d greenland.sqlite
* Serving Flask app " terracotta.server " (lazy loading)
* Environment: production
WARNING: Do not use the development server in a production environment.
Use a production WSGI server instead.
* Debug mode: off
* Running on http://localhost:5000/ (Press CTRL+C to quit)
Sie können jeden HTTP-fähigen Client verwenden, z. B. curl
.
$ curl localhost:5000/datasets ? tile=25XEL
{ " page " :0, " limit " :100, " datasets " :[{ " date " : " 20170831 " , " tile " : " 25XEL " , " band " : " B02 " },{ " date " : " 20170831 " , " tile " : " 25XEL " , " band " : " B03 " },{ " date " : " 20170831 " , " tile " : " 25XEL " , " band " : " B04 " }]}
Moderne Browser (z. B. Chrome oder Firefox) rendern den JSON als Baum.
Terracotta enthält auch einen Web-Client. Sie können den Client starten (vorausgesetzt, der Server läuft unter http://localhost:5000) mit
$ terracotta connect localhost:5000
* Serving Flask app " terracotta.client " (lazy loading)
* Environment: production
WARNING: Do not use the development server in a production environment.
Use a production WSGI server instead.
* Debug mode: off
* Running on http://127.0.0.1:5100/ (Press CTRL+C to quit)
Öffnen Sie dann die Client-Seite (in diesem Fall http://127.0.0.1:5100/) in Ihrem Browser.
Gerne nehmen wir Fehlerberichte und Pull-Requests über GitHub entgegen. Damit Ihr Code nützlich ist, stellen Sie sicher, dass er durch Tests abgedeckt wird und unsere Linting-Praktiken erfüllt (über mypy
und flake8
).
Um die Tests auszuführen, installieren Sie einfach die erforderlichen Abhängigkeiten über
$ pip install -e .[test]
Dann können Sie laufen
$ pytest
aus dem Stammverzeichnis des Repositorys.