terracotta
v0.8.5
Terracotta は、専用ウェブサーバー上の WSGI アプリとして、または AWS Lambda 上のサーバーレス アプリとして実行される純粋な Python タイル サーバーです。これは、Flask、Zappa、Rasterio などの優れたオープンソース ソフトウェアを利用した最新の Python スタック上に構築されています。
ドキュメントを読む |デモを試してみる | API を探索する |サトラス、テラコッタ搭載 |ドッカーイメージ
terracotta serve -r {name}.tif
とterracotta connect localhost:5000
実行すると、そこにアクセスできます。$ 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)
curl
などの HTTP 対応クライアントを使用できます。
$ 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 " }]}
最新のブラウザ (Chrome や Firefox など) は、JSON をツリーとしてレンダリングします。
Terracotta には Web クライアントも含まれています。次を使用してクライアントを起動できます (サーバーが http://localhost:5000 で実行されていると仮定します)。
$ 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)
次に、ブラウザでクライアント ページ (この場合は http://127.0.0.1:5100/) を開きます。
GitHub 経由でバグ レポートやプル リクエストを喜んで受け付けます。コードを有効にするには、コードがテストでカバーされていること、および lint の実践 ( mypy
およびflake8
経由) を満たしていることを確認してください。
テストを実行するには、必要な依存関係を次のようにインストールするだけです。
$ pip install -e .[test]
その後、実行できます
$ pytest
リポジトリのルートから。