CN111782233A - 微服务多场景部署适配设计模型 - Google Patents

微服务多场景部署适配设计模型 Download PDF

Info

Publication number
CN111782233A
CN111782233A CN202010779815.XA CN202010779815A CN111782233A CN 111782233 A CN111782233 A CN 111782233A CN 202010779815 A CN202010779815 A CN 202010779815A CN 111782233 A CN111782233 A CN 111782233A
Authority
CN
China
Prior art keywords
service
micro
deployment
installation
design model
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN202010779815.XA
Other languages
English (en)
Inventor
黄平珍
王艳清
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Mianyang Smart City Industrial Development Co ltd
Original Assignee
Mianyang Smart City Industrial Development Co ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Mianyang Smart City Industrial Development Co ltd filed Critical Mianyang Smart City Industrial Development Co ltd
Priority to CN202010779815.XA priority Critical patent/CN111782233A/zh
Publication of CN111782233A publication Critical patent/CN111782233A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • G06F8/61Installation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/70Software maintenance or management
    • G06F8/71Version control; Configuration management
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/445Program loading or initiating
    • G06F9/44505Configuring for program initiating, e.g. using registry, configuration files

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Security & Cryptography (AREA)
  • Stored Programmes (AREA)

Abstract

本发明提供微服务多场景部署适配设计模型,涉及微服务部署领域。该微服务多场景部署适配设计模型,包括微服务共部署,微服务单元不能独立运行,必须加入启动模式中,启动模式分为独立节点和分布式节点、微服务安装包构建和微服务安装包部署。在微服务的基础上,提出一种新的设计模型,把微服务和单点融为一体,贯穿前端和后端,贯穿开发,测试,持续集成,运维。形成标准的软件生产流程,制定软件生产规则,以统一的生产模式,适配不同的场景,从而实现加快开发,测试进度;加快了现场实施的进度;为公司节约了人力成本;提高模块的重用度;提升了生产环境的性能。

Description

微服务多场景部署适配设计模型
技术领域
本发明涉及微服务部署领域,具体为微服务多场景部署适配设计模型。
背景技术
微服务的出现解决了复杂问题:它把可能会变得庞大的单体应用程序分解成一套服务;每个服务都可以由一个团队独立专注开发;可以实现每一个微服务独立部署;可以实现每个服务能够独立扩展。微服务同时又带来了新的问题:分布式系统之间复杂的交互;分区数据库架构以及事务的处理;测试应用程序的复杂度;跨越多服务的变更;部署模式的复杂性等。目前有很多开源的微服务框架:SpringCloud,Motan,gRPC,Thrift,Dubbo,但是都只解决了部分问题。
软件产品的设计,技术选择,并不仅仅只是和软件本身的功能相关。更大程度上取决于客户的场景,受制于硬件环境。同一个产品,在大的场景下,采用微服务的方式设计,分解成20个服务,那么在小的场景中,硬件资源不足的前提下,我们如何适配运维。目前开源的微服务框架,几乎都是往大场景扩展,没有考虑到小场景,相当于否定了传统的单点模式。软件设计没有极端,只有权衡。场景大小都是相对的,随着时间的推移,大场景也可能变成小场景,小场景也有可能变成大场景。对于不确定性环境,我们唯有提出一种兼容的设计模式,以不变应万变。
发明内容
(一)解决的技术问题
针对现有技术的不足,本发明提供了微服务多场景部署适配设计模型,解决了现有微服务部署受制于部署场景的问题。
(二)技术方案
为实现以上目的,本发明通过以下技术方案予以实现:微服务多场景部署适配设计模型,包括以下内容:
1、微服务共部署
微服务架构中,一个微服务单元就是一个进程,一个微服务进程在注册中心中对应着一个节点,开发环境和生产环境几乎是一致的,微服务单元只能在本地开发环境独立启动,在生产环境中,微服务单元不能独立运行,必须加入启动模式中,启动模式分为独立节点和分布式节点;
1.1独立节点:单个节点中可以进行多个服务,且单个进程不需要注册中心;
1.2分布式节点:多个节点在注册中心下进行服务,且单个进程可以进行多个服务;
2、微服务安装包构建
节点下,将多个服务进行编译,合并依赖,合并配置文件,合并资源文件,合并第三方服务依赖的过程;
3、微服务安装包部署
3.1一键式安装包结构:包括基础环境清洗、安装界面、内嵌chrome、业务进程、第三方服务进程和内嵌数据库;
3.2安装工具设计:整体可以理解为,远程连接服务器,上传安装包,执行相关的命令来对服务的操作;
3.3安装工具的安装流程:启动安装工具,判断是否安装,是,检查安装环境,并上传安装envClean安装包,接着上传安装jdk,然后上传且解压服务安装包,最后执行对应的脚本文件、执行脚本返回打印信息和修改服务器状态。
优选的,所述微服务可以独立运行,并且可以共部署运行,所述微服务共部署运行必须满足无重复的bean、支持日志共部署、无重复的第三方应用配置、支持配置文件共部署、服务互调部署场景无感知、服务器自动初始化、支持国际化共部署、服务启动自动注册、支持服务升级共部署和共部署服务依赖不冲突。
优选的,所述envClean安装包功能为创建系统用户,以及设置soft、data和log的路径。
优选的,所述对应的脚本文件包括install、start、stop和uninstall,即安装脚本文件、开始脚本文件、停止脚本文件和卸载脚本文件。
(三)有益效果
本发明提供了微服务多场景部署适配设计模型。具备以下有益效果:
本发明,在微服务的基础上,提出一种新的设计模型,把微服务和单点融为一体,贯穿前端和后端,贯穿开发,测试,持续集成,运维。形成标准的软件生产流程,制定软件生产规则,以统一的生产模式,适配不同的场景,从而实现加快开发,测试进度;加快了现场实施的进度;为公司节约了人力成本;提高模块的重用度;提升了生产环境的性能。
附图说明
图1为传统部署模式和本发明的部署模式对比示意图;
图2为本发明的安装目录合并示意图;
图3为本发明的一键式安装包部署结构示意图;
图4为本发明的远程部署示意图;
图5为本发明的部署流程示意图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
实施例:
本发明实施例提供微服务多场景部署适配设计模型,包括以下内容:
1、微服务共部署
如图1所示,微服务架构中,一个微服务单元就是一个进程,一个微服务进程在注册中心中对应着一个节点,开发环境和生产环境几乎是一致的,微服务单元只能在本地开发环境独立启动,在生产环境中,微服务单元不能独立运行,必须加入启动模式中,启动模式分为独立节点和分布式节点,而传统的方式为单节点进行单服务;
1.1独立节点:单个节点中可以进行多个服务,且单个进程不需要注册中心;
1.2分布式节点:多个节点在注册中心下进行服务,且单个进程可以进行多个服务;
2、微服务安装包构建
如图2所示,节点下,将多个服务进行编译,合并依赖,合并配置文件,合并资源文件,合并第三方服务依赖的过程;
3、微服务安装包部署
3.1一键式安装包结构:如图3所示,包括基础环境清洗、安装界面、内嵌chrome、业务进程、第三方服务进程和内嵌数据库;
3.2安装工具设计:如图4所示,整体可以理解为,远程连接服务器,上传安装包,执行相关的命令来对服务的操作;
3.3安装工具的安装流程:如图5所示,启动安装工具,判断是否安装,是,检查安装环境,并上传安装envClean安装包,接着上传安装jdk,然后上传且解压服务安装包,最后执行对应的脚本文件、执行脚本返回打印信息和修改服务器状态,envClean安装包功能为创建系统用户,以及设置soft、data和log的路径,对应的脚本文件包括install、start、stop和uninstall,即安装脚本文件、开始脚本文件、停止脚本文件和卸载脚本文件。
微服务可以独立运行,并且可以共部署运行,所述微服务共部署运行必须满足无重复的bean、支持日志共部署、无重复的第三方应用配置、支持配置文件共部署、服务互调部署场景无感知、服务器自动初始化、支持国际化共部署、服务启动自动注册、支持服务升级共部署和共部署服务依赖不冲突。
尽管已经示出和描述了本发明的实施例,对于本领域的普通技术人员而言,可以理解在不脱离本发明的原理和精神的情况下可以对这些实施例进行多种变化、修改、替换和变型,本发明的范围由所附权利要求及其等同物限定。

Claims (4)

1.微服务多场景部署适配设计模型,其特征在于,包括以下内容:
1、微服务共部署
微服务架构中,一个微服务单元就是一个进程,一个微服务进程在注册中心中对应着一个节点,开发环境和生产环境几乎是一致的,微服务单元只能在本地开发环境独立启动,在生产环境中,微服务单元不能独立运行,必须加入启动模式中,启动模式分为独立节点和分布式节点;
1.1独立节点:单个节点中可以进行多个服务,且单个进程不需要注册中心;
1.2分布式节点:多个节点在注册中心下进行服务,且单个进程可以进行多个服务;
2、微服务安装包构建
节点下,将多个服务进行编译,合并依赖,合并配置文件,合并资源文件,合并第三方服务依赖的过程;
3、微服务安装包部署
3.1一键式安装包结构:包括基础环境清洗、安装界面、内嵌chrome、业务进程、第三方服务进程和内嵌数据库;
3.2安装工具设计:整体可以理解为,远程连接服务器,上传安装包,执行相关的命令来对服务的操作;
3.3安装工具的安装流程:启动安装工具,判断是否安装,是,检查安装环境,并上传安装envClean安装包,接着上传安装jdk,然后上传且解压服务安装包,最后执行对应的脚本文件、执行脚本返回打印信息和修改服务器状态。
2.根据权利要求1所述的微服务多场景部署适配设计模型,其特征在于:所述微服务可以独立运行,并且可以共部署运行,所述微服务共部署运行必须满足无重复的bean、支持日志共部署、无重复的第三方应用配置、支持配置文件共部署、服务互调部署场景无感知、服务器自动初始化、支持国际化共部署、服务启动自动注册、支持服务升级共部署和共部署服务依赖不冲突。
3.根据权利要求1所述的微服务多场景部署适配设计模型,其特征在于:所述envClean安装包功能为创建系统用户,以及设置soft、data和log的路径。
4.根据权利要求1所述的微服务多场景部署适配设计模型,其特征在于:所述对应的脚本文件包括install、start、stop和uninstall,即安装脚本文件、开始脚本文件、停止脚本文件和卸载脚本文件。
CN202010779815.XA 2020-08-05 2020-08-05 微服务多场景部署适配设计模型 Pending CN111782233A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202010779815.XA CN111782233A (zh) 2020-08-05 2020-08-05 微服务多场景部署适配设计模型

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202010779815.XA CN111782233A (zh) 2020-08-05 2020-08-05 微服务多场景部署适配设计模型

Publications (1)

Publication Number Publication Date
CN111782233A true CN111782233A (zh) 2020-10-16

Family

ID=72766822

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202010779815.XA Pending CN111782233A (zh) 2020-08-05 2020-08-05 微服务多场景部署适配设计模型

Country Status (1)

Country Link
CN (1) CN111782233A (zh)

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112685052A (zh) * 2020-12-30 2021-04-20 浪潮通用软件有限公司 一种基于.NET Core的支持不同部署方式的微服务实现方法
CN114416224A (zh) * 2022-03-25 2022-04-29 共道网络科技有限公司 一种在多微服务环境下调用微服务的方法及装置
CN115562688A (zh) * 2022-10-13 2023-01-03 深圳市中兴新云服务有限公司 一种基于微服务与组件融合一键部署方法
CN115729526A (zh) * 2022-11-29 2023-03-03 北京京航计算通讯研究所 一种单体和微服务一体化软件开发方法

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20090249279A1 (en) * 2008-03-31 2009-10-01 Jatho Investments Software appliance framework
CN106610836A (zh) * 2016-12-23 2017-05-03 国网信息通信产业集团有限公司 一种微服务运行管理工具
US20180088935A1 (en) * 2016-09-27 2018-03-29 Ca, Inc. Microservices application configuration based on runtime environment
CN111488201A (zh) * 2020-06-28 2020-08-04 浙江网新恒天软件有限公司 一种微服务的部署和运行方法

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20090249279A1 (en) * 2008-03-31 2009-10-01 Jatho Investments Software appliance framework
US20180088935A1 (en) * 2016-09-27 2018-03-29 Ca, Inc. Microservices application configuration based on runtime environment
CN106610836A (zh) * 2016-12-23 2017-05-03 国网信息通信产业集团有限公司 一种微服务运行管理工具
CN111488201A (zh) * 2020-06-28 2020-08-04 浙江网新恒天软件有限公司 一种微服务的部署和运行方法

Cited By (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112685052A (zh) * 2020-12-30 2021-04-20 浪潮通用软件有限公司 一种基于.NET Core的支持不同部署方式的微服务实现方法
CN112685052B (zh) * 2020-12-30 2024-01-23 浪潮通用软件有限公司 一种基于.NET Core的支持不同部署方式的微服务实现方法
CN114416224A (zh) * 2022-03-25 2022-04-29 共道网络科技有限公司 一种在多微服务环境下调用微服务的方法及装置
CN115562688A (zh) * 2022-10-13 2023-01-03 深圳市中兴新云服务有限公司 一种基于微服务与组件融合一键部署方法
CN115562688B (zh) * 2022-10-13 2023-10-03 深圳市中兴新云服务有限公司 一种基于微服务与组件融合一键部署方法
CN115729526A (zh) * 2022-11-29 2023-03-03 北京京航计算通讯研究所 一种单体和微服务一体化软件开发方法

Similar Documents

Publication Publication Date Title
CN111782233A (zh) 微服务多场景部署适配设计模型
US10430204B2 (en) System and method for cloud provisioning and application deployment
US8627311B2 (en) Systems, methods, and apparatus to deploy software
CN107769949B (zh) 一种应用组件部署方法及部署节点
US10846073B2 (en) Methods, apparatuses, terminals, servers, and systems for container generation
US20140075438A1 (en) Method, server, and system for starting an application
JP5542796B2 (ja) モバイル・デバイス・ソフトウェアの管理方法及び装置
US8464246B2 (en) Automation of mainframe software deployment
US20150100684A1 (en) Test and management for cloud applications
US20150199197A1 (en) Version management for applications
WO2017202211A1 (zh) 虚拟机上安装业务版本的方法及装置
CN109298868B (zh) 测绘影像数据处理软件智能动态部署及卸载方法
US20140208308A1 (en) Computer system and method for resolving dependencies in a computer system
CN112506477B (zh) 一种在Kubernetes集群中使用RESTful API添加计算节点的方法
CN110888652B (zh) 基于jenkins插件的多版本构建方法及终端
CN106502713A (zh) 一种软件升级方法和系统
CN111679888A (zh) 一种代理容器的部署方法及装置
CN111506322A (zh) 一种自动化集成构建开发部署平台及方法
CN111966366A (zh) 一种多cpu架构的集群部署的方法和设备
CN103026337B (zh) 配给组件的提取和重构
CN106897223A (zh) 一种基于持续集成的软件包交付方法及装置
CN109558147A (zh) 一种基于Jenkins和Gitlab的持续集成平台构建方法
CN110795356A (zh) 基于Ansible实现软件一键式部署与自动化测试的系统及其方法
CN113127009A (zh) 大数据管理平台的自动化部署方法和装置
US20140173634A1 (en) Method and integration component for integrating osgi environments into a service-oriented architecture

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination