搭建开源地图服务 - 利用OSMGIS和iD
研究开源地图组建,服务搭建,初步方案为:
第一步:安装PostgreSQL数据库CentOS7下初始化PostgreSQL 第二步:
我们选PostgreSQL作为我们的GIS数据库,关于PostgreSQL的安装,之前已经有文章介绍过(centOS7下同样适用)。PostGIS需要额外的安装和配置。PostGIS的安装我们同样使用Yum的方式。 1.1 安装PostGIS PostGIS 安装过程需要依赖一些相关库文件,为了方便安装,首先我们需要添加EPEL源,然后再安装PostGIS rpm -Uvh http://dl.fedoraproject.org/pub/epel/7/x86_64/e/epel-release-7-2.noarch.rpm
yum list postgis* #查看能够安装的最新版本
-------------------------------------------------
postgis.x86_64 2.0.7-1.el7 @epel
postgis2_94.x86_64 2.1.8-1.rhel7 @pgdg94
可安装的软件包
postgis-docs.x86_64 2.0.7-1.el7 epel
postgis-utils.x86_64 2.0.7-1.el7 epel
postgis2_94-client.x86_64 2.1.8-1.rhel7 pgdg94
postgis2_94-debuginfo.x86_64 2.1.8-1.rhel7 pgdg94
postgis2_94-devel.x86_64 2.1.8-1.rhel7 pgdg94
postgis2_94-docs.x86_64 2.1.8-1.rhel7 pgdg94
postgis2_94-utils.x86_64 2.1.8-1.rhel7 pgdg94
------------------------------------------------------
yum install postgis2_94
1.2 创建地理空间数据库 目前如果导入OSM的全球数据的话,导入后至少需要480G的存储空间。所以根据需求请选择合适的存储路径来创建数据库。 mkdir /home/DATA/pgtbs_osmgis #目录请自行决定
chown postgres /home/DATA/pgtbs_osmgis
然后在psql下创建表空间,为了方便管理,我们再创建一个PG用户osmgis psql -Upostgres CREATE USER osmgis WITH PASSWORD 'password'; CREATE TABLESPACE pgtbs_osmgis OWNER "osmgis" LOCATION '/home/DATA/pgtbs_osmgis';
请把‘password’替换成您设置的密码。 创建数据库和一个对应的管理用户,管理用户建议使用password认证(pg_hba.conf),具体配置可参见之前的文章。 CentOS7下初始化PostgreSQL CREATE DATABASE osmgis WITH OWNER = "osmgis" ENCODING = 'UTF8' TABLESPACE=pgtbs_osmgis; GRANT ALL PRIVILEGES ON DATABASE osmgis TO osmgis;
服务启动 pg_ctl restart #初始化启动了一次,所以是restart 这里是个坑,如果不启动会报错 could not load library "/usr/lib64/pgsql/postgis-2.0.so": ×××××××××乱遭: cannot open shared object file: No such file or directory
注意,注意 1.3 添加postgis功能以及hstore 以下方法,因权限问题,需要使用postgres用户来操作 su - postgres
psql -Upostgres -dosmgis </usr/pgsql-9.3/share/contrib/postgis-2.1/postgis.sql
psql -Upostgres -dosmgis </usr/pgsql-9.3/share/contrib/postgis-2.1/spatial_ref_sys.sql
psql -Upostgres -dosmgis </usr/pgsql-9.3/share/contrib/postgis-2.1/postgis_comments.sql
用postgres用户登录psql,然后创建hstore psql -Upostgres -dosmgis
create extension hstore; #如报错,请检查是否安装了postgresql94-contrib
1.4 PostgreSQL配置的优化 为了使地图数据导入更加顺滑,我们需要调整一下PG的配置文件 配置文件:/var/lib/pgsql/9.4/data/postgresql.conf shared_buffers = 128MB
maintenanceworkmem = 256MB
checkpoint_segments = 20
autovacuum = off
以上的配置一般适用于你有8G的内存,具体配置可根据自己的情况自行调整,可以参考 修改完配置后别忘了 sudo service postgresql-9.4 reload
根据需要,可以去 http://planet.openstreetmap.org/ 下载地图数据,建议下载 .pbf 二进制格式的数据,这样下载和数据导入速度都会快一些。目前全球数据大小在25G左右(导入后大概占用空间500G左右)。也可以根据需要下载州、国家、地区的数据 http://download.geofabrik.de/ ,或者下载某个城市甚至可以指定一个区域下载 http://download.bbbike.org/osm/。更多的OSMGIS数据下载可以参见: http://wiki.openstreetmap.org/wiki/Planet.osm#Downloading 我们可以先下载一个比较小的地图用于先期的测试工作,我们先拿宝岛台湾作个试验吧! wget http://download.bbbike.org/osm/bbbike/Beijing/Beijing.osm.pbf
如果打算导入全球数据的话,根据服务器的配置不同,耗时也是不同的。快则一天,多则可能需要一周。具体可参考官方的评测报告:http://wiki.openstreetmap.org/wiki/Osm2pgsql/benchmarks, 里面例举了不同硬件/软件配置的数据导入耗时。
因为本次地图底图要支持CartoCSS,我们选用了osm-bright的方案,当然还有其他一些开源的方案支持CartoCSS+Mapnik的底图瓦片渲染,这个可以根据个人喜好来决定。但无论选择哪种方案,最终是希望能通过一个友好的编辑器(例如TileMill),来方便的设计/修改地图的底图样式。 3.1 下载osm-bright 用皮肤,地图皮肤哦 git clone https://github.com/mapbox/osm-bright.git
3.2 imposm 安装 地图数据文件的导入工具,本次选择了imposm,也可以用osm2pgsql,一个是Python的实现一个是C的实现,据说imposm比osm2pgsql要快一些。 yum install python-psycopg2 python-devel protobuf-compiler gcc gcc-c++ protobuf-devel tokyocabinet-devel geos-devel
yum install python-pip pip install imposm
3.3 数据导入 导入需要指定一个mapping.py的配置文件,此文件在osm-bright的项目目录下 sudo -s cd /home/postgres/
su - postgres
imposm --connection=postgis://osmgis:password@localhost/osmgis -m ./osm-bright/imposm-mapping.py --read --write --optimize --deploy-production-tables taiwan-latest.osm.pbf
这里需要注意一下路径:1、./osm-bright/imposm-mapping.py 另外一个需要注意的是,imposm默认链接PG用的是IPv6 ??? 所以可能需要修改pghba.conf,否则以上导入过程可能会报错(FATAL: Ident authentication failed for user “xxxxxx”),我们需要在pghba.conf中加入以下一条规则: IPv6 local connections:host all osmgis ::1/128 md5
因为TileMile是NodeJS的项目,所以我们要先安装NodeJS以及NPM包管理工具 yum install nodejs npm
第三步:CentOS7下Mapnik编译安装笔记(修改版) 在CentOS 7上安装Node.js的4种方法(包含npm) iD - OpenStreetMap的友好的JavaScript编辑器 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |