[云原生专题-58]:Kubesphere云治理-操作-分步部署Web业务平台RuoYi Cloud项目 - 上云部署过程总体概述与总体流程

作者主页(文火冰糖的硅基工坊):文火冰糖(王文兵)的博客_文火冰糖的硅基工坊_CSDN博客

 本文网址:https://blog.csdn.net/HiWangWenBing/article/details/122940876


目录

第1章 RuoYi Cloud概述

1.1 RuoYi Cloud项目概述

1.2 单机部署的应用程序上云过程中的主要变化

1.3 RuoYi Cloud项目上云,涉及4个方面的主要工作:

(1)有状态的中间件,主要是数据库

(2)无状态的业务相关的微服务(手工制作docker镜像)

(3)微服务应用程序相关的配置文件

(4)网络

第2章 RuoYi Cloud项目业务软件架构

(1)数据库微服务层

(2)应用微服务层

(3)微服务注册层

第3章 从代码层面看RuoYi 支持的微服务

(1)前端服务

(2)后端服务

(3)后端网络

第4章 手工本地化部署的主要步骤

步骤0:前置条件

步骤1: Clone项目代码到本地机器

步骤2:启动nacos服务

步骤3:启动MySQL服务

步骤4:启动Redis

步骤5:启动ruoye程序

第5章 手工上云分步部署的主要步骤 

步骤0:前置条件

步骤1: Clone项目代码到本地机器

步骤2:部署中间件数据库

步骤3:微服务管理层

步骤4:部署微服务

步骤5:部署网关

步骤6:部署前端UI

第6章 DevOps自动化部署

6.1 DevOps的整体流程

6.2 DevOps自动化部署的阶段


第1章 RuoYi Cloud概述

1.1 RuoYi Cloud项目概述

https://gitee.com/y_project/RuoYi-Cloud

https://blog.csdn.net/HiWangWenBing/article/details/122937375

1.2 单机部署的应用程序上云过程中的主要变化

RuoYi Cloud一款基于Web的后台管理系统,由多个功能模块组成,大都数功能模块是可以划分为一个个独立的微服务,本文并不打算介绍或学习功能模块的使用或代码实现,而是根据该开源项目的源代码,采用微服务部署的方式,把该项目部署到云端。

单机部署的应用程序上云过程中的主要变化如下:

(1)总体

  • 采用微服务的方式部署:而不是一体化的方式部署该应用;
  • 部署到云端:而不是部署到单机,实际上,该项目是可以部署到单机上的。

(2)中间件的变化

  • 中间件程序被部署成有状态的服务,有自己独立的IP地址,而不是local IP。
  • 需要分层部署:docker -》 deployment -》 service这三层,最底层的doker,最接近单机上的一个功能。

(3)单个应用程序的变化

  • 相对于第三方中间件的部署方式:该项目的部署,是从源代码开始:需要自己编译、制作镜像、发布镜像,然后再根据镜像进行部署,而不是直接使用镜像仓库中的镜像部署。
  • 相对于单机版应用程序:上云后的每个应用程序以微服务的形式存在,以docker镜像的方式存在,因此相对于单机版,程序总体的镜像的大小发生了变化,需要消耗更多的内存和硬盘。
  • 每个pod被部署成无状态的服务,pod所需的参数和中间要访问的数据,都通过数据库中间件保存和持久化。

(4)网络的变化(最大的变化单机内部进程通信变成了集群内分层的网络通信)

  • 单机版的网络通信,所有的IP地址都是127.0.0.1,通过端口号区分各个应用程序 。上云后,每个微服务都有自己独立的集群内的IP地址。
  • 上云后,一个微服务又进一步抽象为service,每个service可以部署多个depolyment实例,支持多个pod实例的负载均衡。每个service和微服务pod都有自己独立的IP地址。
  • 同一个微服务的多个实例之间,不是通过端口号区分,而是通过IP地址区分。
  • 通过端口暴露的方式,提供集群外访问服务Service,暴露端口的时候,保持内网的端口号不变。也就是说,集群内、外访问微服务用到IP地址和端口号都不一样。特别是外部访问的端口号进行了映射。
  • 微服务与微服务之间,通过集群内部的集群内的域名访问,而不是IP地址进行通信,这样的好处是微服务动态伸缩的时候,IP地址会发生变化,如果通过IP地址通信,服务的动态伸缩就面临这严重的问题。
  • 支持单一的、统一的网关,访问集群内部的所有服务。

(5)项目和微服务配置的变化

  • 生存环境、开发环境、运营环境的配置是不一样的,通过名字空间进行隔离。

1.3 RuoYi Cloud项目上云,涉及4个方面的主要工作:

(1)有状态中间件,主要是数据库

RuoYi Cloud的后台管理系统,需要生成大量的管理数据。

这些数据将存储在数据库微服务中间件中,数据库微服务的代码开发,并不是该项目的一部分,它们将作为第三方代码被集成进RuoYi Cloud系统,所谓集成,并非而动态或静态库文件的方式进行集成,而是以动态微服务的方式集成。这些第三方的微服务,在安装部署的时候,直接取于各自docker hub仓库,而不是RuoYi Cloud项目自身。

  • 中间件镜像的部署
  • 数据库数据的导入

(2)无状态的业务相关的微服务(手工制作docker镜像)

  • 源码的编译

RuoYi Cloud后端代码是java语言编写的代码,前端是js代码,因此需要相应的编译环境。

  • 镜像的制作

RuoYi Cloud的微服务的目标文件是jar文件,以java基础环境为基础docker镜像,在此基础之上生成新的docker镜像。

  • 镜像的发布

生成的多个微服务镜像,可以发布到阿里云的免费的个人仓库中。用于后续的部署。

  • 镜像的部署

一旦把镜像发布到镜像仓库中,后续就可以普通的docker镜像的部署方式来部署RuoYi Cloud的微服务了。

备注:

业务相关的微服务之所以是无状态,是因为其数据全部存储在数据库中,并根据数据库的内容,决定应用程序的当前状态。

(3)微服务应用程序相关的配置文件

大多微服务都有自己配置文件,用于对微服务的启动和运行时的行为进行配置和控制。

  • 配置文件的挂载
  • 配置文件的修改

(4)网络

  • 部署NodePort服务,用于通过公网访问部署的微服务
  • 部署服务,实现负载均衡
  • 部署服务,实现统一网关访问

第2章 RuoYi Cloud项目业务软件架构

分为三层:

(1)数据库微服务层

  • mysql数据库:用于存放nacos对RuoYi 所有前后台微服务注册配置信息。
  • redis数据库: 用于存放RuoYi 所有前后台微服务管理数据。
  • 对象存储:存储文件,如log。

(2)应用微服务层

  • 前台
  • 后台
  • 负载均衡与限流网关

(3)微服务注册层

  • 服务注册与发现:nacos

部署的过程自下而上。

第3章 从代码层面看RuoYi 支持的微服务

(1)前端服务

  • ruoye-ui

(2)后端服务

  • ruoye-system
  • ruoye-gen
  • ruoye-job
  • ruoye-file

(3)后端网络

  • ruoye-gateway
  • ruoye-auth

第4章 手工本地化部署的主要步骤

这个过程虽然不是必须的,但通过这个过程起到两个作用:

(1)通过单机版的方式快速熟悉ruoye项目的各个功能组件(各个微服务)

(2)通过比较,感受云上部署与本地单机版部署的区别

(3)便于把本地数据库方便的迁移到部署在云上的数据库

步骤0:前置条件

(1)为MySQL数据库安装客户端程序:MySQL Workbench

(2)为Redis数据库安装客户端程序: Visual Studio Code - Code Editing. Redefined

(3)为后台编译安装java编译环境: Visual Studio Code - Code Editing. Redefined

(4)为前台提编译安装node.js编译环境:Download | Node.js

步骤1: Clone项目代码到本地机器

Clone到本地的目的是编译目标文件和获得配置文件。

步骤2:启动nacos服务

步骤3:启动MySQL服务

步骤4:启动Redis

步骤5:启动ruoye程序

第5章 手工上云分步部署的主要步骤 

步骤0:前置条件

(1)为MySQL数据库安装客户端程序:MySQL Workbench

(2)为Redis数据库安装客户端程序: Visual Studio Code - Code Editing. Redefined

(3)为后台编译安装java编译环境: Visual Studio Code - Code Editing. Redefined

(4)为前台提编译安装node.js编译环境:Download | Node.js

步骤1: Clone项目代码到本地机器

Clone到本地的目的是编译目标文件和获得配置文件。

步骤2:部署中间件数据库

  • MySQL数据库+数据库数据的导入 =》用于nacos微服务
  • Redis数据库+数据库数据的导入   =》用于ruoye-xxx微服务

步骤3:微服务管理层

  • nacos服务的部署与配置
  • sentinel服务的部署与配置

步骤4:部署微服务

  • ruoye-system
  • ruoye-gen
  • ruoye-job
  • ruoye-file

步骤5:部署网关

  • ruoye-gateway

步骤6:部署前端UI

  • ruoye-auth

第6章 DevOps自动化部署

6.1 DevOps的整体流程

6.2 DevOps自动化部署的阶段

(1)clone code:克隆代码

(2) unit test:代码编写与单元测试

(3)build and push:构建镜像

(4)push latest:发布镜像

(5)deploy to dev :部署到开发环境

(6)deploy to production:部署的生产环境


作者主页(文火冰糖的硅基工坊):文火冰糖(王文兵)的博客_文火冰糖的硅基工坊_CSDN博客

 本文网址:https://blog.csdn.net/HiWangWenBing/article/details/122940876

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

文火冰糖的硅基工坊

你的鼓励是我前进的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值