geoserver的demo使用过程

先贴一个效果图,使用的geoserver版本2.18.0,需要对应版本插件netcdf插件【Extensions》Coverage Formats》NetCDF】,使用tomcat8进行发布geoserver,端口启用的是9999;

 这里面的源码以及一些工具等,可以到我的百度盘里面进行查找:

链接:https://pan.baidu.com/s/1qxfIKEoWZGG_gHd5HXPzMA 
提取码:cpnh 

 

在使用的过程中出现各种问题,我这里也贴出来,希望贴友能够少踩这种坑

1、开始的时候我使用2.8.0,2.8.1等的版本,这些都是在官网上下载的war文件,发现部分版本的插件下载不了,这个demo需要使用到一个插件netcdf插件; 文件

2、使用2.8.x的时候,最终将发布的vms服务,直接使用leaflet将tile贴在地图上的时候,发现当地图放大到一定层级后,比如13,14及更大后,Tomcat就直接卡崩了,geoserver都刷不出来,cpu使用特别高,我换了高版本2.18.0后,这个问题解决了;

3、demo使用的数据来源noaa网站(https://psl.noaa.gov/data/gridded/data.ghcncams.html),这里面数据很多,我在上面随便找了一个温度的数据进行处理的,文件【air.mon.mean.nc】

这个数据是经纬度0.5x0.5的大小,文件nc格式,刚开始也是一脸懵,后面找到一个工具类ToolsUI.jar可以查看部分信息,这个在做demo的时候没什么用,我后面想解析nc文件,生成nc文件,就可能用到;【toolsUI.jar】

4、最终这个可以发布出去使用,可能会根据实时的数据,逐小时发布,这时就需要自动化脚本进行发布相关nc文件;

这里面使用到的3个文件:

文件1、自动发布数据和图层的命令,是根据官网上的api中curl命令进行写的;

文件2、我将上面使用到的air.mon.mean.nc文件,直接拆分成了多个nc文件,原始文件由三个维度(time,lat,on),我拆成多个nc文件,改变之后的维度是(lat,lon);

文件3、解析nc文件的格式,解读;

对curl命令行说明:

在使用命令前,需要先新建一个工作空间,本demo中的工作空间是workspace_ranfs

 

 

①发布nc文件数据存储,将nc该文件发布成栅格数据存储,发布到workspace_ranfs工作区,说明,这里面的temp0.nc文件是我自己通过上面的CreateNetCDF_2D.java生成的。

curl -v -u admin:geoserver -XPUT -H "Content-type: text/plain" -d "file://D://tmp/temp0.nc" "http://localhost:9999/geoserver/rest/workspaces/workspace_ranfs/coveragestores/temp0/external.netcdf"

②修改样式,注意使用的是双引号还是单引号,在windows系统下使用单引号会报错

curl -v -u admin:geoserver -XPUT -H "Content-type: text/xml" -d "<layer><defaultStyle><name>RH2Style</name><workspace>cite</workspace></defaultStyle></layer>" http://localhost:9999/geoserver/rest/layers/workspace_ranfs:temp0

③删除数据源和图层

curl -v -u admin:geoserver -XDELETE "http://localhost:9999/geoserver/rest/workspaces/workspace_ranfs/coveragestores/temp0?recurse=true"

查看相关其它信息

curl -v -u admin:geoserver -XGET http://localhost:9999/rest/workspaces/cite/datastores

 url命令参考地址:https://docs.geoserver.org/2.10.0/user/rest/index.html#rest      这个是官方文档的地址

 

在NetCDF文件操作的时候,需要引入依赖:

  <dependencies>
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-api</artifactId>
            <version>1.7.25</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/edu.ucar/netcdf -->
        <dependency>
            <groupId>edu.ucar</groupId>
            <artifactId>netcdf</artifactId>
            <version>4.3.22</version>
        </dependency>
  </dependencies>

 

定义样式RH2Style,我把这个样式放在cite工作空间下,样式配置参考官方文档:https://docs.geoserver.org/2.8.1/user/styling/sld-reference/ 

<?xml version="1.0" encoding="UTF-8"?>
<StyledLayerDescriptor version="1.0.0" xmlns="http://www.opengis.net/sld" xmlns:ogc="http://www.opengis.net/ogc"
  xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://www.opengis.net/sld http://schemas.opengis.net/sld/1.0.0/StyledLayerDescriptor.xsd">
  <NamedLayer>
    <Name>rain</Name>
    <UserStyle>
      <Name>rain</Name>
      <Title>Rain distribution</Title>
      <FeatureTypeStyle>
        <Rule>
          <RasterSymbolizer>
            <Opacity>0.5</Opacity>
            <ColorMap>
              <ColorMapEntry color="#FFFFFF" quantity="243" opacity="0"/>
              <ColorMapEntry color="#9589D3" quantity="253" opacity="1"/>
              <ColorMapEntry color="#8ACECD" quantity="263" opacity="1"/>
              <ColorMapEntry color="#6197C2" quantity="273" opacity="1"/>
              <ColorMapEntry color="#5D8E33" quantity="283" opacity="1"/>
              <ColorMapEntry color="#BFA70B" quantity="293" opacity="1"/>
              <ColorMapEntry color="#F07F0D" quantity="303" opacity="1"/>
              <ColorMapEntry color="#A1350E" quantity="313" opacity="1"/>
            </ColorMap>
          </RasterSymbolizer>
        </Rule>
      </FeatureTypeStyle>
    </UserStyle>
  </NamedLayer>
</StyledLayerDescriptor>

 

demo的html代码:(由于我使用的chineseTmsProviders.js是放在我们云上,是要根据访问流量和次数收费的),百度盘里面有这个文件

<html>
    <head>
        <link rel="stylesheet" href="http://unpkg.com/leaflet@1.4.0/dist/leaflet.css" />
        <script src="http://unpkg.com/leaflet@1.4.0/dist/leaflet.js"></script>
        <script src="https://xxxxxx/lib/leaflet/leaflet.ChineseTmsProviders.js"></script>
        <style type="text/css">
        html,body{margin:0px;padding:0px;}
        </style>
    </head>
    <body>
        <div style="width: 100vw; height: 100vh" id="map"></div>
        <script type="text/javascript">
            // Make basemap
            const map = new L.Map('map', { center: new L.LatLng(32.433668, 105.829757), zoom: 5});
            map.setMaxZoom(18);
            //const osm = new L.TileLayer('http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png');
            var chinaTile = L.tileLayer.chinaProvider('Geoq.Normal.Map', {maxZoom: 17,minZoom: 2});
            var vms = L.tileLayer.wms("http://localhost:9999/geoserver/workspace_ranfs/wms", {
                layers: 'workspace_ranfs:temp0',
                format: 'image/png',
                transparent: true,
                attribution: "Weather data © 2012 IEM Nexrad"
            });
            map.addLayer(chinaTile);
            map.addLayer(vms);
        </script>
    </body>
</html>

 

参考博客:

用NetCDF创建和读取NC文件 https://blog.csdn.net/shener_m/article/details/83313037 

netcdf数据nc格式数据java解析总结(三)使用java生成.nc格式文件 https://blog.csdn.net/ilovecr7/article/details/72901688 

GeoServer实现NetCDF气象文件自动发布 https://blog.csdn.net/freeland1/article/details/78579971

 

posted @ 2020-11-13 15:59  理舞  阅读(1000)  评论(0编辑  收藏  举报