Hazelcast IMDG 带你瞬间进入内存计算的时代

Stella981
• 阅读 852

Hazelcast IMDG 带你瞬间进入内存计算的时代

Hazelcast是一个平台性的分布式内存网格计算框架引擎,可以实现基于分布式内存计算的诸多场景的应用框架 , 它作为一个开源可内嵌式内存网格计算框架,通过简单的配置, 就可以轻松的让你的应用拥有弹性可扩展的分布式内存计算能力,可以带你瞬间进入内存计算的时代。

Hazelcast IMDG 带你瞬间进入内存计算的时代 伴随着更深入的使用你会发现他是一个创造更多想象空间的的平台框架。是一个百变框架,可以带给你无限可能, 就像航母可以扩展作战半径支持多种作战形式一样,他可以衍生变化出各种框架和解决方案。

如果你正在寻找一个迅速提升服务性能,让应用迅速具备集群和动态弹性可扩展的能力,那Hazelcast正是你要找的框架。

说了那么多,那到底什么是分布式内存网格计算?

首先看分布式计算的解释:

分布式计算研究如何把一个需要非常巨大的计算能力才能解决的问题分成许多小的部分,然后把这些部分分配给许多计算机进行处理,最后把这些计算结果综合起来得到最终结果。

我们常常说的云计算其实是分布式计算的一种.云计算是将巨大的数据处理程序分成无数个待处理小程序, 然后通过多部服务器组成的系统进行处理和分析这些小程序得到结果并返回给用户.

Hazelcast IMDG 带你瞬间进入内存计算的时代

那什么是内存网格(IMDG)?

内存数据网格(IMDG)将基于磁盘的数据从RDBMS、NoSQL数据库复制到RAM中,在RAM中进行处理,一般形式为分布式数据架构, 从而不会因为持续的磁盘读写导致延迟。内存数据网格插入到应用程序和数据层之间,部署在服务器节点的集群上,共享集群的可用内存和CPU。无论是部署在公共云还是私有云环境中、内部部署还是在混合云的环境中,都可以实现内存数据网格. 一些内存数据网格可以支持ANSI-99 SQL和ACID处理.

官方文档:https://hazelcast.com/glossary/in-memory-data-grid/

有了上述分布式计算和内存网格的解释那自然就明白了什么是分布式内存网格计算, 基于云计算可以给互联网很多想象空间和更多的可能,那基于分布式内存网格计算会带来什么?

基于内存计算的特性, 目前Hazelcast也是公认的提升应用程序性能的最灵活的方案. 分布式计算,服务集群, 弹性伸缩,高速分布式缓存,消息订阅,流式计算,甚至是作为下一代的微服务技术的Service Mesh,Hazelcast也可以让你轻松拥有.

拥有这么多功能的框架性能到底怎么样,这是架构师和开发者最关注的问题,作为Hazelcast基础功能的分布式缓存在性能上与 Redis 集群的性能做了一次对比,在高并发多线程的模式下,Hazelcast性能要比Redis性能略高. Hazelcast是基于Java构建的,而 Redis 是基于C++构建的, 两个都是内存级缓存,Hazelcast性能跑过 Redis 依靠的是分布式内存管理与数据分片算法方面的能力, 这也很值得做深入研究. Redis终究也没想到在开源界也可以有跨界杀手.

Hazelcast VS Redis 的性能测结果:

Hazelcast IMDG 带你瞬间进入内存计算的时代

原文地址:https://hazelcast.com/resources/benchmark-redis-vs-hazelcast/

而且Hazelcast因为其采用自制集群无中心化的特性,作为分布式缓存的解决方案没有单点故障的烦恼,集群部署简易,也没有节点数量要求, 而且灵活可弹性扩展.支持热插拔, 高效的内存分片管理能力支持,可以将当前小内存机器集群构建出大内存计算平台,规避其他缓存框架单机内存限制的问题, 省钱又省心, 大内存在人工智能,机器学习,金融,数据分析等诸多领域都有清晰的应用市场,这些都可以让Hazelcast作为选型目标.

在分布式缓存上有这么好的表现,但这并不是Hazelcast真正值得称赞的地方. 分布式缓存能力是Hazelcast的一个基础原子能力, 在诸多真实的项目中选择引入Hazelcast有各种各样的使用场景和选型需求,大概率是基于Hazelcast丰富的原子能力和业务场景适用性.

在大数据时代、海量数据处理、机器学习、流处理的需求与场景我们随处可见。Hazelcast Jet 是一个基于Hazelcast的分布式高性能流处理引擎,专为高性能低延迟的大数据集计算而设计,该引擎适合数据密集型应用程序,满足低延迟,高吞吐,批量,分布式处理需求。

Hazelcast Jet 整体架构:

Hazelcast IMDG 带你瞬间进入内存计算的时代

Hazelcast IMDG 带你瞬间进入内存计算的时代

从上图可以看出Hazelcast Jet适用于多源大数据采集存储,实时数据处理,数据清洗,ML深度学习,预警,分析,消息订阅,等业务,这个框架非常适合我们现在所做的智慧城市(IOC)中城市体征数据底盘的需求,Hazelcast Jet可以作为数据底层处理基座, 收集各类城市数据,包含IOT物联网传感器数据,然后进行清洗,分析,预警,深度学习,AI 人工智能的应用等,通常企业级的开发要达到这些能力都需要集成诸多组件,而Hazelcast Jet要实现这些能力对其他组件的依赖非常低,降低了多组件集成的成本与复杂度,彻底的简化了流处理的方式,让行业内的流处理业务产生了一次重大的飞跃。

这些目前 Spark,Stream,Flink都是该领域的成熟的流处理框架,那Hazelcast Jet 除了在功能与底座方面的优点外,那性能如何也是一个不能回避的问题。

先来看一个Hazelcast Jet 与 Spark,Flink 的经典的Words Count大数据性能测试结果:

Hazelcast IMDG 带你瞬间进入内存计算的时代

Hazelcast Jet 的处理速度比大多数的实时处理框架要好一点。在加上Hazelcast 的分布式 IMAP ,海量数据分布式大数据处理速度要更快。

原文地址:https://hazelcast.com/resources/jet-0-4-vs-spark-flink-batch-benchmark/

Hazelcast Jet的流处理速度之所以快是基于分布式内存计算,在加上流处理核心使用了directed acyclic graph (DAG) 有向无环图技术,可以加速分布式数据处理速度,DAG 技术也在区块链技术上有应用,不同于区块链当前的生链算法,可以加速区块链的生链处理速度,被称为第二代区块链技术,感兴趣可以研究一下。

基于上面的描述和性能测试结果,相信大家都有更深的兴趣了,那就要先了解下Hazelcast还提供了那些能力,Hazelcast以分布式内存计算能力为平台, 无缝集成了很多开源框架的特性与原子能力, 这些原子能力和平台的整体性也保持的很好, 会让你有种水到渠成的感觉, 这些能力也为Hazelcast带来了更多的想象空间和可能性,同时原子能力的组合,可以带来很多变化, 就像拼积木一样,拥有更多的能力,更多的使用场景.

Hazelcast在官网的介绍也凸显出Hazelcast的能力和使用场景的多样性.先了解下Hazelcast的整体架构.

Hazelcast IMDG 带你瞬间进入内存计算的时代

可以从官方公布的体系架构中看到Hazelcast的整体结构和基础模块和原子能力.

综合官网的介绍Hazelcast的功能点和原子能力包含:

  • 基于Topic 实现的消息队列或订阅\发布模式;

  • 分布式java.util.{Queue, Set, List, Map}

  • 分布式java.util.concurrent.ExecutorService

  • 分布式java.util.concurrency.locks.Lock

  • 分布式节点 listeners and events

  • 分布式 Task

  • 分布式id生成器(IdGenerator).

  • 分布式事件驱动(Distributed Events).

  • 分布式计算(Distributed Computing).

  • 分布式查询(Distributed Query).

  • 提供用于一对多关系的分布式MultiMap。

  • 通过JCA与J2EE容器集成和事务支持。

  • 提供用于安全集群的Socket层加密。

  • 支持同步和异步持久化。

  • 通过JMX监控和管理集群。

  • 支持动态HTTP Session集群。

  • 利用备份实现动态分割。

  • 动态故障恢复.

  • 节点负载均衡.

  • 分布式流计算

  • 安全组件

  • 滚动升级特性

  • Map/Reduce

  • 多模式组网, 节点自动发现.

  • 自带集群节点管理后台.

那基于这些已经有的原子能力,可以衍生出很多场景的解决方案,大部分是官网提到的解决方案:

  • 分布式缓存

  • 发布订阅系统

  • 分布式锁

  • 任务调度

  • 分布式 ID 生成

  • 分布式Task执行服务器

  • 配置中心

  • 数据库集成/数据迁移 (官网的一个Case)

  • 数据抽取 ETL

  • 实时流处理

  • 内存数据库

  • NoSQL数据存储

  • Session 会话存储

  • IM即时通信框架

  • 大型游戏框架(这个在适合不过了)

  • 微服务框架

  • Service Mash(作为下一代微服务框架的底座)

更多的想法和解决方案可以参考hazelcast Blog ,官方开发人员和社区开发者都会分享一些Hazelcast最新动态和基于Hazelcast最新的Idea和Solution!

博客地址:https://hazelcast.com/blog

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Easter79 Easter79
3年前
swap空间的增减方法
(1)增大swap空间去激活swap交换区:swapoff v /dev/vg00/lvswap扩展交换lv:lvextend L 10G /dev/vg00/lvswap重新生成swap交换区:mkswap /dev/vg00/lvswap激活新生成的交换区:swapon v /dev/vg00/lvswap
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
4个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
Python之time模块的时间戳、时间字符串格式化与转换
Python处理时间和时间戳的内置模块就有time,和datetime两个,本文先说time模块。关于时间戳的几个概念时间戳,根据1970年1月1日00:00:00开始按秒计算的偏移量。时间元组(struct_time),包含9个元素。 time.struct_time(tm_y
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
10个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这