Mapfeatureserver как замена ArcGIS Server: различия между версиями
Vasnake (обсуждение | вклад) Нет описания правки |
Vasnake (обсуждение | вклад) Нет описания правки |
||
Строка 22: | Строка 22: | ||
На текущий момент программа находится в стадии «Proof of Concept», то есть обладает функциональностью минимально достаточной для демонстрации работоспособности подхода. | На текущий момент программа находится в стадии «Proof of Concept», то есть обладает функциональностью минимально достаточной для демонстрации работоспособности подхода. | ||
Из всего многообразия запросов декларированных в API, наш сервис пока реализует два: | Из всего многообразия запросов декларированных в API, наш сервис пока реализует два: | ||
* layer metadata http://<featureservice-url>/<layerId> | * layer metadata <pre>http://<featureservice-url>/<layerId></pre> | ||
* layer data query by box http://<featurelayer-url>/query | * layer data query by box <pre>http://<featurelayer-url>/query</pre> | ||
причем запрос | причем запрос данных может быть только одного типа - запрос на выборку по ограничивающему боксу (box). | ||
Этого достаточно, чтобы загрузить слой в карту и делать zoom, pan, просмотр атрибутов для features, но и только. | Этого достаточно, чтобы загрузить слой в карту и делать zoom, pan, просмотр атрибутов для features, но и только. | ||
Строка 32: | Строка 32: | ||
Изложенная здесь информация может устареть к тому времени как вы читаете этот текст. Наиболее свежую информацию о проекте вы всегда можете найти на странице проекта в GitHub https://github.com/vasnake/mapfeatureserver | Изложенная здесь информация может устареть к тому времени как вы читаете этот текст. Наиболее свежую информацию о проекте вы всегда можете найти на странице проекта в GitHub https://github.com/vasnake/mapfeatureserver | ||
Чтобы запустить сервис MFS вам понадобится выполнить следующие шаги: | |||
* Скачать MFS с GitHub. | |||
* Установить Python 2.7 и необходимые библиотки, к примеру для MS Windows | |||
<pre>set path=%path%;c:\d\Python27;c:\d\Python27\Scripts | |||
pip install Flask flask-login blinker psycopg2 simplejson</pre> | |||
[http://www.stickpeople.com/projects/python/win-psycopg/ psycopg2 for Windows] | |||
* Запустить приложение Flask | |||
<pre>pushd mapfeatureserver\wsgi | |||
python mapfs_controller.py</pre> | |||
URL веб-службы будет таким http://localhost:5000/ | |||
Если вы откроете эту страницу в браузере вы увидите служебную страницу со ссылками на тестовые слои. Эти ссылки работать не будут, так как у вас нет таких слоев. Удалить лишнее и добавить свое вы можете поправив файл | |||
<pre>mapfeatureserver\wsgi\templates\servlets.html</pre> | |||
Чтобы создать новый слой, вам нужно выполнить следующие шаги: | |||
* Получить доступ к БД PostGIS, к примеру, установив БД на свой хост. | |||
* Загрузить шейп-файл с нужными данными в БД, к примеру так: | |||
<pre>set path=%path%;c:\Program Files\PostgreSQL\9.0\bin | |||
pushd c:\t\shpdir | |||
shp2pgsql.exe -d -I -s 4326 -W cp1251 flyzone.shp mfsdata.flyzone > flyzone.dump.sql | |||
psql -f flyzone.dump.sql postgisdb mfs<pre> | |||
* Записать сведения о слое в конфигурационный файл | |||
<pre>mapfeatureserver\config\layers.config.ini</pre> | |||
находящиеся там примеры и комментарии помогут не ошибиться. | |||
* Создать файл метаданных для слоя. Это самая трудная часть. | |||
<pre>mapfeatureserver\config\layer.<layer id>.config.json</pre> | |||
Чтобы было легче, можно скопировать метаданные из аналогичного существующего слоя ArcGIS и внести в него правки. Метаданные слоя из ArcGIS доступны по URL типа <pre>http://testags/arcgis/rest/services/flyzone/FeatureServer/2?f=pjson</pre> | |||
Также, в MFS есть специальные страницы, типа <pre>http://localhost:5000/admin/dsn/flyzone?oidfield=gid&geomfield=geom</pre> | |||
для помощи в составлении файла метаданных. | |||
После выполнения этих шагов, можно использовать слои MFS как обычные слои ArcGIS Feature Layer в веб-картах построенных на ArcGIS web API. К примеру, есть вьювер Картобонус, построенный на ArcGIS API for Silverlight, именно он использовался для тестирования MFS. | |||
Чтобы добавить слой в карту, используйте URL вида <pre>http://hostname:5000/<layer id></pre> |
Версия от 16:29, 23 мая 2013
Описание веб-сервиса Mapfeatureserver как замены ArcGIS Server
Mapfeatureserver (далее MFS) - это веб-сервис, написанный на Python (WSGI, Flask) реализующий REST API ArcGIS Server для слоев типа Feature Layer. MFS был задуман как средство, позволяющее избавиться от дорогостоящего ArcGIS Server при работе с веб-картами, использующими ArcGIS API.
Mapfeatureserver будет полезен разработчикам ГИС решений для веб и интранет, поскольку позволяет получить веб-карты красивые и функциональные как в ArcGIS, но без затрат на приобретение ArcGIS Server.
Что это, Mapfeatureserver?
Как я уже упомянул, MFS это open source программа на Python, которая после запуска создает веб-сервис отвечающий спецификации ArcGIS REST API для картографических слоев типа Feature Layer. Веб модуль MFS написан с использованием фреймворка Flask и отвечает спецификации WSGI, что позволяет использовать MFS в качестве части более крупных веб-решений.
Геоданные MFS считывает из PostGIS, что означает необходимость а) загрузить данные предполагаемого решения в БД PostGIS; б) обеспечить доступ к этой БД сервису MFS. На текущий момент кроме PostGIS другие БД не поддерживаются, но есть планы добавить поддержку MySQL и MongoDB.
Общая картина использования MFS выглядит примерно так.
- Геоданные (шейп-файлы, к примеру) загружаем в PostGIS.
- Для каждого слоя данных вписываем сведения в конфигурационные файлы MFS.
- Запускаем веб-сервис.
- В клиентской программе, к примеру Картобонус, добавляем к карте слои также, как обычные FeatureLayer из ArcGIS.
Теперь о недостатках и ограничениях MFS.
На текущий момент программа находится в стадии «Proof of Concept», то есть обладает функциональностью минимально достаточной для демонстрации работоспособности подхода. Из всего многообразия запросов декларированных в API, наш сервис пока реализует два:
- layer metadata
http://<featureservice-url>/<layerId>
- layer data query by box
http://<featurelayer-url>/query
причем запрос данных может быть только одного типа - запрос на выборку по ограничивающему боксу (box). Этого достаточно, чтобы загрузить слой в карту и делать zoom, pan, просмотр атрибутов для features, но и только.
Остальная часть API будет реализована несколько позже. Хорошая новость заключается в том, что проект - open source и любой, кто обладает соответствующими навыками, может ускорить реализацию недостающих функций.
Инструкция по использованию Mapfeatureserver
Изложенная здесь информация может устареть к тому времени как вы читаете этот текст. Наиболее свежую информацию о проекте вы всегда можете найти на странице проекта в GitHub https://github.com/vasnake/mapfeatureserver
Чтобы запустить сервис MFS вам понадобится выполнить следующие шаги:
- Скачать MFS с GitHub.
- Установить Python 2.7 и необходимые библиотки, к примеру для MS Windows
set path=%path%;c:\d\Python27;c:\d\Python27\Scripts pip install Flask flask-login blinker psycopg2 simplejson
- Запустить приложение Flask
pushd mapfeatureserver\wsgi python mapfs_controller.py
URL веб-службы будет таким http://localhost:5000/ Если вы откроете эту страницу в браузере вы увидите служебную страницу со ссылками на тестовые слои. Эти ссылки работать не будут, так как у вас нет таких слоев. Удалить лишнее и добавить свое вы можете поправив файл
mapfeatureserver\wsgi\templates\servlets.html
Чтобы создать новый слой, вам нужно выполнить следующие шаги:
- Получить доступ к БД PostGIS, к примеру, установив БД на свой хост.
- Загрузить шейп-файл с нужными данными в БД, к примеру так:
set path=%path%;c:\Program Files\PostgreSQL\9.0\bin pushd c:\t\shpdir shp2pgsql.exe -d -I -s 4326 -W cp1251 flyzone.shp mfsdata.flyzone > flyzone.dump.sql psql -f flyzone.dump.sql postgisdb mfs<pre> * Записать сведения о слое в конфигурационный файл <pre>mapfeatureserver\config\layers.config.ini
находящиеся там примеры и комментарии помогут не ошибиться.
- Создать файл метаданных для слоя. Это самая трудная часть.
mapfeatureserver\config\layer.<layer id>.config.json
Чтобы было легче, можно скопировать метаданные из аналогичного существующего слоя ArcGIS и внести в него правки. Метаданные слоя из ArcGIS доступны по URL типа
http://testags/arcgis/rest/services/flyzone/FeatureServer/2?f=pjson
Также, в MFS есть специальные страницы, типа
http://localhost:5000/admin/dsn/flyzone?oidfield=gid&geomfield=geom
для помощи в составлении файла метаданных.
После выполнения этих шагов, можно использовать слои MFS как обычные слои ArcGIS Feature Layer в веб-картах построенных на ArcGIS web API. К примеру, есть вьювер Картобонус, построенный на ArcGIS API for Silverlight, именно он использовался для тестирования MFS.
Чтобы добавить слой в карту, используйте URL вида
http://hostname:5000/<layer id>