一种残膜回收机防缠绕挑膜装置的制 一种秧草收获机用电力驱动行走机构

一种基于Hazelcast的系统部署方法及相关设备与流程

2021-11-25 01:20:00 来源:中国专利 TAG:

一种基于hazelcast的系统部署方法及相关设备
技术领域
1.本技术涉及系统部署技术领域,尤其涉及一种基于hazelcast的系统部署及相关设备。


背景技术:

2.在一家为行业提供系统服务的企业,经常需要将系统服务部署到需求方的服务器上做本地化部署。
3.系统依赖于数据库、缓存、消息队列等外部组件,每次部署均需要对这些外部组件单独进行安装调试,存在着增加了实施运维的工作量,提高了系统部署的难度,降低了系统部署的效率的技术问题。


技术实现要素:

4.本技术提供了一种基于hazelcast的系统部署方法及相关设备,解决了由于系统依赖于数据库、缓存、消息队列等外部组件,每次部署均需要对这些外部组件单独进行安装调试,存在的增加了实施运维的工作量,提高了系统部署的难度,降低了系统部署的效率的技术问题。
5.有鉴于此,本技术第一方面提供了一种基于hazelcast的系统部署方法,所述方法包括:
6.在hazelcast中申明hazelcast消息队列的名称以及hazelcast缓存的名称;
7.将所述hazelcast嵌入至应用系统的依赖包中;
8.启动所述应用系统的安装程序,使得所述hazelcast在内存中完成所述hazelcast消息队列以及所述hazelcast缓存的加载。
9.可选地,所述将所述hazelcast嵌入至应用系统的依赖包中具体包括:
10.通过工程管理软件maven,将所述hazelcast嵌入至应用系统的pom文件中;
11.在所述pom文件中申明所述hazelcast为依赖。
12.可选地,所述启动所述应用系统的安装程序之后还包括:
13.为所述hazelcast消息队列启动线程进行所述hazelcast消息队列的监听。
14.可选地,若在所述hazelcast中申明两个或两个以上hazelcast消息队列的名称,则分别为两个或两个以上所述hazelcast消息队列启动一个线程进行所述hazelcast消息队列的监听。
15.本技术第二方面提供一种基于hazelcast的系统部署装置,所述装置包括:
16.申明单元,用于在hazelcast中申明hazelcast消息队列的名称以及hazelcast缓存的名称;
17.嵌入单元,用于将所述hazelcast嵌入至应用系统的依赖包中;
18.启动单元,用于启动所述应用系统的安装程序,使得所述hazelcast在内存中完成所述hazelcast消息队列以及所述hazelcast缓存的加载。
19.可选地,所述嵌入单元具体用于:
20.通过工程管理软件maven,将所述hazelcast嵌入至应用系统的pom文件中;
21.在所述pom文件中申明所述hazelcast为依赖。
22.可选地,还包括:
23.监听单元,用于为所述hazelcast消息队列启动线程进行所述hazelcast消息队列的监听。
24.可选地,若在所述hazelcast中申明两个或两个以上hazelcast消息队列的名称,则所述监听单元分别为两个或两个以上所述hazelcast消息队列启动一个线程进行所述hazelcast消息队列的监听。
25.本技术第三方面提供一种基于hazelcast的系统部署设备,所述设备包括处理器以及存储器:
26.所述存储器用于存储程序代码,并将所述程序代码传输给所述处理器;
27.所述处理器用于根据所述程序代码中的指令,执行如上述第一方面所述的基于hazelcast的系统部署方法的步骤。
28.本技术第四方面提供一种计算机可读存储介质,所述计算机可读存储介质用于存储程序代码,所述程序代码用于执行上述第一方面所述的基于hazelcast的系统部署方法。
29.从以上技术方案可以看出,本技术实施例具有以下优点:
30.本技术中,提供了一种基于hazelcast的系统部署方法及相关设备,利用hazelcast具备消息队列以及缓存的功能,将hazelcast嵌入集成至应用系统中,使得在部署该应用系统时,即可实现应用系统功能、分布式缓存功能以及消息队列功能的同时部署,提升了部署效率,解决了由于系统依赖于数据库、缓存、消息队列等外部组件,每次部署均需要对这些外部组件单独进行安装调试,存在的增加了实施运维的工作量,提高了系统部署的难度,降低了系统部署的效率的技术问题。
附图说明
31.图1为本技术实施例中一种基于hazelcast的系统部署方法的方法流程图;
32.图2为本技术实施例中一种基于hazelcast的系统部署装置的结构示意图;
33.图3为本技术实施例中一种基于hazelcast的系统部署模块的结构示意图。
具体实施方式
34.为了使本技术领域的人员更好地理解本技术方案,下面将结合本技术实施例中的附图,对本技术实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅是本技术一部分实施例,而不是全部的实施例。基于本技术中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本技术保护的范围。
35.本技术设计了一种基于hazelcast的系统部署方法及相关设备,解决了由于系统依赖于数据库、缓存、消息队列等外部组件,每次部署均需要对这些外部组件单独进行安装调试,存在的增加了实施运维的工作量,提高了系统部署的难度,降低了系统部署的效率的技术问题。
36.为了便于理解,请参阅图1,图1为本技术实施例中一种基于hazelcast的系统部署
方法的方法流程图,如图1所示,具体为:
37.101、在hazelcast中申明hazelcast消息队列的名称以及hazelcast缓存的名称;
38.需要说明的是,hazelcast自带hazelcast消息队列以及hazelcast缓存,且其hazelcast缓存为分布式缓存,在hazelcast中申明hazelcast消息队列的名称以及hazelcast缓存的名称即可使用hazelcast的这两种功能。
39.102、将hazelcast嵌入至应用系统的依赖包中;
40.需要说明的是,hazelcast可以被嵌入至应用系统的依赖包中,即与应用系统集成为一个整体,不需要分开进行安装和调试。
41.103、启动应用系统的安装程序,使得hazelcast在内存中完成hazelcast消息队列以及hazelcast缓存的加载。
42.需要说明的是,在安装阶段,启动应用系统的安装程序,除了应用系统的本体功能被安装完毕以外,hazelcast会自行在内存中完成hazelcast消息队列以及hazelcast缓存的加载,
43.进一步地,将hazelcast嵌入至应用系统的依赖包中具体包括:
44.通过工程管理软件maven,将hazelcast嵌入至应用系统的pom文件中;
45.在pom文件中申明hazelcast为依赖。
46.需要说明的是,pom文件为工程管理软件maven中的申明文件,将hazelcast的源代码嵌入至应用系统的pom文件中,在pom文件中申明hazelcast的依赖,则在应用程序的运行时,可以直接使用hazelcast的依赖。
47.进一步地,启动应用系统的安装程序之后还包括:
48.为hazelcast消息队列启动线程进行hazelcast消息队列的监听。
49.需要说明的是,应用系统在启动时,为hazelcast消息队列启动线程进行监听,监听hazelcast消息队列中的消息并消费。
50.进一步地,若在hazelcast中申明两个或两个以上hazelcast消息队列的名称,则分别为两个或两个以上hazelcast消息队列启动一个线程进行hazelcast消息队列的监听。
51.需要说明的是,在hazelcast中,可以申明两个或两个以上hazelcast消息队列的名称,即启用两个或两个以上的hazelcast消息队列,在应用系统启动的阶段中,则会为每个定义在hazelcast消息队列中的队列启动线程进行监听,并分别消费。
52.图2为本技术实施例中一种基于hazelcast的系统部署装置的结构示意图,如图2所示,具体包括:
53.申明单元201,用于在hazelcast中申明hazelcast消息队列的名称以及hazelcast缓存的名称;
54.嵌入单元202,用于将hazelcast嵌入至应用系统的依赖包中;
55.启动单元203,用于启动应用系统的安装程序,使得hazelcast在内存中完成hazelcast消息队列以及hazelcast缓存的加载。
56.进一步地,嵌入单元202具体用于:
57.通过工程管理软件maven,将hazelcast嵌入至应用系统的pom文件中;
58.在pom文件中申明hazelcast为依赖。
59.进一步地,还包括:
60.监听单元204,用于为hazelcast消息队列启动线程进行hazelcast消息队列的监听。
61.进一步地,若在hazelcast中申明两个或两个以上hazelcast消息队列的名称,则监听单元分别为两个或两个以上hazelcast消息队列启动一个线程进行hazelcast消息队列的监听。
62.本技术中,提供了一种基于hazelcast的系统部署方法及相关设备,利用hazelcast具备消息队列以及缓存的功能,将hazelcast嵌入集成至应用系统中,使得在部署该应用系统时,即可实现应用系统功能、分布式缓存功能以及消息队列功能的同时部署,提升了部署效率,解决了由于系统依赖于数据库、缓存、消息队列等外部组件,每次部署均需要对这些外部组件单独进行安装调试,存在的增加了实施运维的工作量,提高了系统部署的难度,降低了系统部署的效率的技术问题。
63.图3是本技术实施例提供的一种基于hazelcast的系统部署模块的结构示意图,该基于hazelcast的系统部署模块900可因配置或性能不同而产生比较大的差异,可以包括一个或一个以上中央处理器(central processing units,cpu)922(例如,一个或一个以上处理器)和存储器932,一个或一个以上存储应用程序942或数据944的存储介质930(例如一个或一个以上海量存储设备)。其中,存储器932和存储介质930可以是短暂存储或持久存储。存储在存储介质930的程序可以包括一个或一个以上模块(图示没标出),每个模块可以包括对服务器中的一系列指令操作。更进一步地,中央处理器922可以设置为与存储介质930通信,在基于hazelcast的系统部署模块900上执行存储介质930中的一系列指令操作。
64.基于hazelcast的系统部署模块器900还可以包括一个或一个以上电源926,一个或一个以上有线或无线网络接口950,一个或一个以上输入输出接口958,和/或,一个或一个以上操作系统941,例如windows servertm,mac os xtm,unixtm,linuxtm,freebsdtm等等。
65.上述实施例中由服务器所执行的步骤可以基于该图3所示的服务器结构。
66.其中,cpu 922用于执行如下步骤:
67.在hazelcast中申明hazelcast消息队列的名称以及hazelcast缓存的名称;
68.将hazelcast嵌入至应用系统的依赖包中;
69.启动应用系统的安装程序,使得hazelcast在内存中完成hazelcast消息队列以及hazelcast缓存的加载。
70.本技术实施例还提供了另一种基于hazelcast的系统部署设备,设备包括处理器以及存储器:
71.存储器用于存储程序代码,并将程序代码传输给处理器;
72.处理器用于根据程序代码中的指令执行前述各个实施例的一种基于hazelcast的系统部署方法中的任意一种实施方式。
73.本技术实施例还提供一种计算机可读存储介质,用于存储程序代码,该程序代码用于执行前述各个实施例所述的一种基于hazelcast的系统部署方法中的任意一种实施方式。
74.所属领域的技术人员可以清楚地了解到,为描述的方便和简洁,上述描述的系统,装置和单元的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
75.本技术的说明书及上述附图中的术语“第一”、“第二”、“第三”、“第四”等(如果存在)是用于区别类似的对象,而不必用于描述特定的顺序或先后次序。应该理解这样使用的数据在适当情况下可以互换,以便这里描述的本技术的实施例例如能够以除了在这里图示或描述的那些以外的顺序实施。此外,术语“包括”和“具有”以及他们的任何变形,意图在于覆盖不排他的包含,例如,包含了一系列步骤或单元的过程、方法、系统、产品或设备不必限于清楚地列出的那些步骤或单元,而是可包括没有清楚地列出的或对于这些过程、方法、产品或设备固有的其它步骤或单元。
76.应当理解,在本技术中,“至少一个(项)”是指一个或者多个,“多个”是指两个或两个以上。“和/或”,用于描述关联对象的关联关系,表示可以存在三种关系,例如,“a和/或b”可以表示:只存在a,只存在b以及同时存在a和b三种情况,其中a,b可以是单数或者复数。字符“/”一般表示前后关联对象是一种“或”的关系。“以下至少一项(个)”或其类似表达,是指这些项中的任意组合,包括单项(个)或复数项(个)的任意组合。例如,a,b或c中的至少一项(个),可以表示:a,b,c,“a和b”,“a和c”,“b和c”,或“a和b和c”,其中a,b,c可以是单个,也可以是多个。
77.在本技术所提供的几个实施例中,应该理解到,所揭露的系统,装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,所述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,装置或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。
78.所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
79.另外,在本技术各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。
80.所述集成的单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本技术的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的全部或部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本技术各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:u盘、移动硬盘、只读存储器(英文全称:read

only memory,英文缩写:rom)、随机存取存储器(英文全称:random access memory,英文缩写:ram)、磁碟或者光盘等各种可以存储程序代码的介质。
81.以上所述,以上实施例仅用以说明本技术的技术方案,而非对其限制;尽管参照前述实施例对本技术进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本技术各实施例技术方案的精神和范围。
再多了解一些

本文用于企业家、创业者技术爱好者查询,结果仅供参考。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

相关文献