IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> Geoserver添加mongoDB数据源 -> 正文阅读

[大数据]Geoserver添加mongoDB数据源

概述

本文讲述如何在geoserver中添加mongoDB作为数据源,并发布图层。

操作

1. 添加mongodb 插件

在浏览器输入地址下载页面,下载mongodb插件。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-3U2tivfz-1655387878217)(https://upload-images.jianshu.io/upload_images/6826673-339f2f41b6a0b42a.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)]
将下载的插件解压到geoserver部署目录geoserver\WEB-INF\lib,启动geoserver即可。

2. 添加数据源

进入geoserver页面,数据存储->新建数据源,如下图所示有MongoDD矢量数据源则说明安装成功。

image.png

mongoDB的数据源参数有两个:data_storescheme_storedata_store为数据库连接地址,格式如下:

# 单数据源
mongodb://root:root@localhost:27017/sfmap?authMechanism=SCRAM-SHA-1&authSource=admin

# 多集群
mongodb://root:root@localhost:27017,localhost:27018/sfmap?authMechanism=SCRAM-SHA-1&authSource=admin

scheme_store为geoserver发布图层的时候生成的,可以是文件:
image.png
生成的数据如下:
image.png

也可以是数据库,是数据库的时候会创建一个名为schemas的集合,如下图:

image.png
数据库中存储的记录如下:
image.png
不论是那种方式,都会生成一个如下文件:

{ 
    "_id" : ObjectId("62aae424ba21bf9ac56d9016"), 
    "typeName" : "mongo_capital", 
    "userData" : {
        "collection" : "mongo_capital"
    }, 
    "geometryDescriptor" : {
        "localName" : "geometry", 
        "crs" : {
            "type" : "name", 
            "properties" : {
                "name" : "urn:ogc:def:crs:EPSG:4326"
            }
        }
    }, 
    "attributeDescriptors" : [
        {
            "localName" : "geometry", 
            "type" : {
                "binding" : "com.vividsolutions.jts.geom.Geometry"
            }, 
            "userData" : {
                "encoding" : "GeoJSON", 
                "mapping" : "geometry"
            }
        }, 
        {
            "localName" : "name", 
            "minOccurs" : NumberInt(0), 
            "maxOccurs" : NumberInt(1), 
            "type" : {
                "binding" : "java.lang.String"
            }, 
            "userData" : {
                "mapping" : "properties.name"
            }
        }
    ]
}

该文件是类似于一个图层的元数据,通过该文件,我们可以控制:1、属性是否展示;2、属性的字段可以以做修改。
image.png

3. 添加数据

数据的添加有两种方式:1. 直接对库操作,插入数据;2.在geoserver创建图层的时候创建好图层,后面再插入数据。geoserver的方式如下:
image.png
说明:

  1. 在geoserver中创建图层的时,必须添加一个geometry类型的字段,字段类型可以是下图中的类型。
    image.png
    插入数据的语句如下:
db.mongo_rect.insert({ "type": "Feature", "properties": { "name": "tect1", "code": "rect1" }, "geometry": { "type": "MultiPolygon", "coordinates": [ [ [ [ 102.2201, 36.0388 ], [ 102.2201, 38.8592 ], [ 106.6959, 38.8592 ], [ 106.6959, 36.0388 ], [ 102.2201, 36.0388 ] ] ] ] } });
db.mongo_rect.insert({ "type": "Feature", "properties": { "name": "rect2", "code": "rect2" }, "geometry": { "type": "MultiPolygon", "coordinates": [ [ [ [ 109.7921, 34.2301 ], [ 109.7921, 37.9395 ], [ 115.5554, 37.9395 ], [ 115.5554, 34.2301 ], [ 109.7921, 34.2301 ] ] ] ] } });
db.mongo_rect.insert({ "type": "Feature", "properties": { "name": "rect3", "code": "rect3" }, "geometry": { "type": "MultiPolygon", "coordinates": [ [ [ [ 101.1165, 30.4594 ], [ 101.1165, 33.8009 ], [ 107.7382, 33.8009 ], [ 107.7382, 30.4594 ], [ 101.1165, 30.4594 ] ] ] ] } });

2、直接对库操作的语句如下:

// 创建集合
db.createCollection("mongo_rect");
// 插入数据
db.mongo_rect.insert({ "type": "Feature", "properties": { "name": "tect1", "code": "rect1" }, "geometry": { "type": "MultiPolygon", "coordinates": [ [ [ [ 102.2201, 36.0388 ], [ 102.2201, 38.8592 ], [ 106.6959, 38.8592 ], [ 106.6959, 36.0388 ], [ 102.2201, 36.0388 ] ] ] ] } });
// 创建索引
db.mongo_rect.createIndex({
    "geometry": "2dsphere"
});

说明

  1. 直接库操作的一定要创建索引,不然geoserver中找不到图层;

3. 发布服务

服务发布就比较简单了,在此就不再赘述。

参考资料

  1. http://docs.geotools.org/latest/userguide/library/data/mongodb.html
  2. MongoDB地理空间数据存储及检索 - 乌合之众 - 博客园 (cnblogs.com)
  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-06-21 21:28:50  更:2022-06-21 21:29:57 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 1:51:14-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码