2. 中国科学院 沈阳计算技术研究所, 沈阳 110168;
3. 辽宁省生态环境监测中心, 沈阳 110161
2. Shenyang Insititue of Computing Technology, Chinese Academy of Sciences, Shenyang 110168, China;
3. Ecological Environment Monitoring Center of Liaoning Province, Shenyang 110161, China
随着全球气候变暖, 经济和人民物质的提高, 工业、农业、生产生活的用水量增加, 导致对水资源的使用加剧, 水体遭到污染的事件频发[1], 与此同时科学发展的不断进步, 航天遥感在环境监测上的应用及雷达技术支持, 水质环境监测数据的种类和数量正在急剧增长, 监测产生的数据量大多为GB或TB, 有时数据量能够达到PB. 大数据技术、互联网技术的迅猛发展使大数据存储及分析利用的问题得到了解决[2]. 在过去几年中, 新一代系统被引入大规模数据处理中, 基于MapReduce范式的程序[3], 尤其是Apache Hadoop[4]越来越成为流行, 利用大数据技术对水生态的历史数据进行处理、存储和分析等, 在有效管理水生态数据的同时利用数据的分析结果对水生态环境保护提供有效方案. 近年来, 国内外出现了很多基于大数据技术平台对水资源数据进行分析处理的应用. 例如: Moturi等[5]研究在处理较小的数据集上大数据系统表现出不理想的速度, 但是在足够大的数据集上实现了合理的加速, 数据集在补充计算节点的数量下, 与正常的数据挖掘和处理相比, 能够减少30%的执行时间; Parmar等[6]将神经网络模型、模糊模型和小波模型相结合对监测站监测的水质参数化学需氧量(COD)进行预测. 李辉等[7]提出了在Hadoop平台上利用MapReduce并发处理水文信息的模型, 利用大数据技术提高了存储执行的效率.
在水生态监测环境中, 水文监测站在网络互通的条件下, 形成网络结构或按河流流向分布, 由于监测站点分布广泛, 传感器可监测水生态、水质、气象等多类数据, 因此随着传感器的监测频率上升, 水生态环境数据大幅度增长, 传统关系型数据库在存储与管理数据中不足以承载如此海量的数据; 文献[8]提出一种基于生态系统服务的生态足迹(Ecosystem Service-based Ecological Footprint, ESEF)方法, 在考虑或不考虑水质标准和环境分类的条件下, 采用求平均值法和并集法分析太湖流域上游湖州市的水生态承载力, 但该方法扩展性不强. 基于上述问题, 为解决海量水生态监测数据存储和处理问题以及水生态承载力分析方法的可扩展性, 本文利用Hadoop分布式存储以及基于MapReduce并行计算提出一种基于大数据的水生态承载力模型, 将影响水生态承载力的数据因素划分为3个指标层, 同时结合HDFS分布式文件系统来管理存储海量数据, 利用生态足迹法计算水生态足迹和水生态承载力[9]以及利用MapReduce的并行计算处理来训练水生态承载力模型, 将生态足迹与生态承载力相比较, 得到生态承载力是否赤字或盈余. 在可持续发展的基础上控制水生态环境在可承载范围内, 完成海量水文数据存储并能完成有效计算.
1 水生态承载力大数据处理架构 1.1 水信息大数据处理总体架构整体的基于大数据的水文信息处理架构如图1所示, 数据源分别由物联网、水生态监控站以及互联网资源构成, 通过远程上传、网络爬虫等完成对数据源的数据采集.
数据资源库是整个系统平台的核心, 为了处理海量数据存储问题, 将其划分为结构化数据库、基础数据库以及非结构化HDFS分布式存储数据库等部分. 是经过数据采集及处理后的数据存储部分[10], 实现对水环境空间数据、业务数据与管理数据的管理. 提供不同物理结构数据资源库, 具有良好扩展性.
水生态环境管理平台应用依据Java开发框架为基础, 将数据应用开发、运行时环境与支撑业务开发的软件封装为资源管理、基础服务以及大数据支撑应用平台, 为水环境监管部门提供业务应用, 全面提升信息化应用水平, 增强信息资源共享服务力度.
1.2 大数据采集与处理目前, 大量的水资源、水环境以及水生态数据不断的由监测站点生成并通过物联网技术上传至远程服务中心处. 在数据仓库的归档过程中, 其中最大的数据集就是关于水质、水位和水流量的实时数据信息. 水质信息在不同站点处实时监测水质的水温、溶解氧、pH、电导率、氨氮离子、余氯等参数, 这些数据集形成海量的水生态信息. 由于水质信息数据中的pH值、污水处理厂的排放浓度等具有时空连续性, 因此在进行监测水质数据是否超标实现污染超标预警预报等服务时, 对水生态监测数据的存储和计算的要求提升. 为实现终端用户以交互式的丰富方式分析大量后端数据, 使用Hadoop技术实现对大量水生态数据的存储与计算功能, 通过Hadoop分布式文件系统将接口应用程序连接到后端HBase, 通过MapReduce框架用户可以轻松的分析和可视化水生态大数据. 如图2所示.
使用高性能的Linux集群构建配置, 安装Yarn、HBase等Hadoop生态大数据技术. 基于Hadoop作为水生态数据存储和计算的基础, 主要包括数据采集、数据预处理、数据存储和数据加载4个模块. 数据采集单元负责水生态数据监测站点的数据采集任务, 监测站点自动对水质、水量等信息进行监控, 并通过互联网技术将数据信息传送至数据预处理模块; 数据预处理接收到的数据大部分的时候时“肮脏”的数据, 极易遭到噪声的影响导致数据丢失、数据出现冲突等, 采用ETL (Extra、Transform、Load)技术将数据采集单元收集到的数据进行清洗转换, 完成数据加载入库操作.
数据存储模块主要是将经过ETL技术处理后的数据存放在HDFS分布式文件系统、HBase结构化分布式存储系统中, 这种分布式文件系统提高了数据的容错能力以及提高了可用性, 提供了对文件的操作和存储的支持, 在必要时能够实时读写并随机访问, 数据被分成块, 以分布式的方式存储在HDFS集群中存在的节点上, 解决了数据库的单点性能极限. 既能提供较高的可扩展性, 又能达到并发访问的能力.
分布式计算框架MapReduce帮助我们在Hadoop平台上完成分布式的计算编程, 完成对水生态数据的分类处理, Sqoop工具能够完成Hadoop与关系型数据库之间数据的互相转移, 例如通过Shell命令将存在于关系型数据库中具有结构规范无需处理的结构化数据备份到Hadoop (HDFS、HBase)中, 完成数据的转移, 从而提高获取数据的速度.
1.3 Hadoop分布式存储管理Hadoop通过分布式存储管理的方式, 将数据存储及计算均衡分布在各个集群上, 从而可保证数据的可靠性和高容错性. Hadoop的核心包括HDFS (Hadoop Distributed File System), Hadoop的分布式存储工具, 实现水生态数据的存储; MapReduce分布式计算框架处理海量水生态数据的运算. HDFS的存储结构如图3所示.
与关系型数据库不同, HDFS将集群中的工作节点均匀分布, 在存储上文件分块存储, 通过设置参数(dfs. blocksize)来确定块的大小, 每个数据块的大小默认设置为64 MB, 当经过处理的水生态数据上传至HDFS时, 可以被切割成不同的块分别存放在不同的DataNode上, 完成对水生态数据的备份存储, 使得存储更高效并具有高容错性[7]. Mastar/slave结构是HDFS的架构模式, 其一个Master (NameNode)节点包含若干个slave (Data-Node). NameNode会记录文件分块存储在DataNode上的位置信息, 由dfs. name. dir指定元数据(文件的名称、副本系数, Block存储的NameNode)的存储位置, 负责客户端的请求响应. DataNode负责存储Block, 在NameNode的调度下完成数据库的创建、删除和复制; 根据设置的时间间隔定期向NameNode报告本身以及所有Block的信息.
HDFS架构中还包含一个辅助NameNode: Secondary NameNode, 它相当于NameNode的助手节点, 负责fsimage (镜像文件)备份以及将edits(日志文件)与镜像定期合并, 帮助减小edit logs的大小, 减轻NameNode重新启动时的压力, 使NameNode保持文件系统最新的元数据. 当系统发生突发事件的时候, 可以保存最新的改动.
2 水生态承载力分析模型 2.1 水生态承载力影响因素水生态环境具备弹性力的特点, 能够在一定程度上进行自我恢复. 对水生态承载力的计算主要从环境、生活、资源多个方面进行综合分析, 能够体现数据的多元性、动态性以及分析结果的客观性, 为人们对水生态破坏控制在可以恢复的范围内, 即水污染、水资源利用控制在水生态环境自我恢复能力中, 能够最大化的利用水资源, 净化对水体造成的污染. 本文通过研究分析水环境、水资源与水生态方面的数据, 分别进行分类统计、比对、分析, 总结归纳得出影响水生态承载力评估的主要因素主要包括: 水生态压力数据、水资源支撑力层数据以及弹性力数据. 水生态压力数据主要包括人口增长P1、经济增长P2、环境污染P3, 支撑力指层标数据主要包括水资源自身支持S1、人类支持S2, 弹性力指标数据主要包括生态因素数据E1. 如表1所示.
2.2 水生态承载力模型在研究承载力评估方法的过程中, 从多个领域了解到目前计算承载力的方法主要有系统仿真、灰色关联度计算、系统统计学等方法[11–13]. 生态足迹是从可持续发展的理念出发, 黄林楠等[9]提出了一种水资源生态足迹计算方法, 本文基于生态足迹法, 参考王文国等[14]对生态足迹计算相关参数的修正, 分别计算水生态足迹以及水生态承载力.
${W_{EC}} = N{w_{ec}} = 0.88N{\lambda _w}{Q_w}{\gamma _w}/{P_w}$ | (1) |
式(1)中所述的
${W_{EF}} = N{\gamma _w}({W_{\rm{i}}}/{P_{\rm{w}}})$ | (2) |
${W_{EF}} = {W_{EFl}} + {W_{EFp}} + {W_{EFc}}$ | (3) |
其中,
根据表1所示的压力层数据、承载力层数据和弹性力层数据的需求, 设计包含3层的水生态承载力分析模型, 通过输出值不断调整模型的权重以及误差, 如图4所示.
输入层有3个节点, 分别为水资源压力层数据P、水生态承载力层数据S和水生态弹性力层数据E. 隐藏层节点的个数通过式(4)进行计算, 得出节点的个数范围为[3, 12], 在本模型中选取6个节点, 输出层有一个节点, 为EF评估值.
$L = \sqrt {n + m} + a$ | (4) |
$\Delta E = {W_{EC}} - {W_{EF}}$ | (5) |
将流域流经区域地区的水生态足迹与生态承载力相比较, 就会得到水生态资源环境是否为生态赤字或者生态盈余, 如式(5)所示, 若
2.3 水生态承载力模型MapReduce并行计算
本文模型实现采用传统的反向传播算法, 并且参考文献[16]中的一些思想.
MapReduce是一种编程模型适用于大规模数据处理的相关实现. 开发者只需实现mapper函数和reducer函数就定义好了MapReduce作业, mapper函数初始键/值对(key-value), 根据初始键/值对计算产生中间键/值对. MapReduce框架会将产生的中间键值对中键相同的值传递给一个reduce函数. Reducer函数接受一个键以及一组值, 将这组值进行合并产生一组规模更小的值[17], 具体的操作如下:
将训练集分配到多个节点, 执行多个mapper任务, 每一个mapper接收一个训练项, 然后使用训练项计算出模型中权重的更新值, 并将产生的中间键/值对, 形如(key=权重; value=更新值)暂存于本地系统文件; 然后执行多个reducer任务, 每个reducer收集一个权重的更新值, 并计算更新值的平均值, 然后将计算所得的平均值作为权重的更新值; 更新模型中所有的权重的值. 重复执行mapper-reducer任务直到达到预期的精度.
3 实验应用 3.1 实验环境实验环境基于Hadoop大数据平台, 实验应用采用Java做为编程语言, JDK版本为1.8.0_181, 采用分布式搭建大数据环境, 选择5台PC搭建, 其中一台作为Master(NameNode), 其余4台作为slave(DataNode). 环境信息及配置如表2和表3所示.
3.2 实验数据
本文选取辽河流域2012~2018年的水生态监测数据以及人口数据、GDP增长基础数据作为研究对象. 数据分别来源于辽宁省环境监测站监测数据、辽宁省沈阳市、盘锦市、鞍山市、营口市、铁岭市的年水资源公报以及辽宁省统计年鉴. 选取2012~2017年的数据作为训练集, 2018年的数据作为测试集.
3.3 生态承载力结果分析分析2012~2017年辽河流域流经区域的水生态承载力是否符合生态发展的规律, 是否呈现可持续发展状态. 选取人口数量、生活用水、农业灌溉、工业用水、GDP增长率、万元GDP平均耗水量作为生态压力层数据; 选取人均水资源量、城市污水处理量、工业用水重复率作为承载力层数据; 选取年降水量、森林覆盖面积作为弹性力层数据. 对2012–2017年间的辽河流域流经区域的数据通过EF计算方法对生态足迹进行计算, 通过30组输入数据以及EF所得数据对水生态承载力模型进行训练.
将2018年辽河流域流经地区的压力层数据P、支撑力层数据S、弹性力层数据E作为输入层节点数据输入到水生态承载力模型中, 计算出2018年的辽河流域流经区域的水生态足迹的评估值, 如表4所示.
将ECC所得值与生态足迹评估值进行比较, 通过分析, 沈阳、铁岭、盘锦、营口的生态承载力值均小于生态足迹评估值, 处于水生态环境赤字状况, 尤其是盘锦地区生态承载力达到最低值, 说明对水资源环境过度使用; 鞍山生态承载力值大于生态足迹评估值, 处于生态盈余情况, 如图5所示. 通过分析以往数据显示, 鞍山水资源总量较往年相比减少了30%, 但相较于其他地区多, 水生态环境处于可持续发展状态.
3.4 Hadoop集群吞吐能力分析
为了能够验证利用Hadoop集群存储处理海量数据方面比单机数据处理技术上能够有更优越的表现[18], 本实验在选取不同的数据量在Local单机模式以及Full-Distributed Mode集群模式下进行运行时间测试, 在这两种情况下都使用“清洗”后的数据进行规则计算. 数据表包括3列: 唯一标识符、监测时间、监测值. 用“清洗”后的数据统计时间段内, 监测物的超标次数.
从表5可以看出, 在数据量较小的情况下单机运行的时间更短, 处理数据的效率更高, 而数据在超过3 GB之后, Hadoop集群的运行时间更短, 且稳定运行, 时间跨度不是很大.
4 结论与展望
本文对水生态环境承载力的分析从现实生态环境出发, 提出基于大数据的水生态承载力分析模型, 利用大数据技术对水资源、水生态数据处理分析, 以及增加生态足迹计算的数据多样性, 通过生态承载力分析模型输出值与生态承载力相比较, 得出水生态环境当前发展情况是否赤字或盈余. 应用案例表明, 在增加数据多样性的同时能够通过水生态承载力模型对生态足迹做出准确的分析, 减少了数据进行各类公式计算的过程, 提高了工作的效率并丰富了数据来源的多样性. 基于大数据的水生态承载力模型加深了对历史数据的分析与挖掘, 在未来科学和技术的发展下, 以及数据资源库资源的不断完善, 能够对水生态环境承载力做出更准确的分析结果.
[1] |
李安增, 王宁, 王常权, 等. 大数据技术在环境信息中的应用. 计算机系统应用, 2015, 24(1): 60-64. DOI:10.3969/j.issn.1003-3254.2015.01.010 |
[2] |
刘卫萍, 王宁, 周晓磊, 等. 数据融合技术在环境监测领域的应用. 计算机系统应用, 2016, 25(6): 88-93. DOI:10.15888/j.cnki.csa.005202 |
[3] |
Yang HC, Dasdan A, Hsiao RL, et al. Map-reduce-merge: Simplified relational data processing on large clusters. Proceedings of the 2007 ACM SIGMOD International Conference on Management of Data. Beijing, China. 2007. 1029–1040.
|
[4] |
Apache Hadoop. http://hadoop.apache.org/, 2014.
|
[5] |
Moturi CA, Maiyo SK. Use of mapreduce for data mining and data optimization on a web Portal. International Journal of Computer Applications, 2012, 56(7): 39-43. DOI:10.5120/8906-2945 |
[6] |
Parmar KS, Bhardwaj R. River water prediction modeling using neural networks, fuzzy and wavelet coupled model. Water Resour Manage, 2015, 29(1): 17-33. DOI:10.1007/s11269-014-0824-7 |
[7] |
李辉, 王建文, 叶明雯. 基于Hadoop的海量气象水文数据并发处理模型. 计算机应用, 2018, 38(S2): 187-191, 205. |
[8] |
焦雯珺, 闵庆文, 李文华, 等. 基于ESEF的水生态承载力评估-以太湖流域湖州市为例. 长江流域资源与环境, 2016, 25(1): 147-151. DOI:10.11870/cjlyzyyhj201601018 |
[9] |
黄林楠, 张伟新, 姜翠玲, 等. 水资源生态足迹计算方法. 生态学报, 2008, 28(3): 1279-1286. DOI:10.3321/j.issn:1000-0933.2008.03.044 |
[10] |
叶茂, 夏润亮, 刘颖, 等. 基于大数据的省级水利数据中心体系设计. 计算机与网络, 2018, 44(17): 60-62. DOI:10.3969/j.issn.1008-1739.2018.17.053 |
[11] |
翁异静, 邓群钊, 杜磊, 等. 基于系统仿真的提升赣江流域水生态承载力的方案设计. 环境科学学报, 2015, 35(10): 3353-3366. |
[12] |
靳超, 周劲风, 李耀初, 等. 基于系统动力学的海洋生态承载力研究——以惠州市为例. 海洋环境科学, 2017, 36(4): 537-543. |
[13] |
沈思祎, 钮尔轩, 孟斌. 基于灰色关联度的辽宁近海海域生态环境承载力评价. 大连海事大学学报, 2017, 43(3): 112-118. |
[14] |
王文国, 龚久平, 青鹏, 等. 重庆市水资源生态足迹与生态承载力分析. 生态经济, 2011(7): 159-162. |
[15] |
罗娜. 辽宁省水资源生态足迹动态变化与时间序列预测分析研究[硕士学位论文]. 大连: 辽宁师范大学, 2012.
|
[16] |
周志华. 机器学习. 北京: 清华大学出版社, 2016.
|
[17] |
Liu ZQ, Li HY, Miao GS. Mapreduce-based backpropagation neural network over large scale mobile data. Proceedings of the 2010 Sixth International Conference on Natural Computation. Yantai, China. 2010. 1726–1730.
|
[18] |
曾理, 王以群. Hadoop集群和单机数据处理的耗时对比实验. 硅谷, 2009(19): 55-56. |