返回介绍

24.单体升级为微服务方案

发布于 2020-09-14 22:20:42 字数 9052 浏览 1338 评论 0 收藏 0

[2020-09-14 | v2.3.0 版本]

当前系统分为system、demo 等模块,现有需求把每个模块单独启动作为微服务应用,故而推出新版boot【2020-09-14 | v2.3.0 版本】,支持快速切换成cloud,本项目cloud技术栈为:

  • 服务注册:nacos
  • 配置中心:nacos-config
  • 理由网关: gateway
  • 服务间调用:openfeign
  • 熔断和降级:sentinel
  • 服务监控:Spring Boot Admin

    视频教程 :点击我去B站

目录:

一、启动jeecg-system服务

升级system模块为独立服务

1.将system项目的pom文件中的其他模块的依赖删除,只保留local-api

2.system项目作为微服务启动,需要添加微服务依赖

<!-- nacos -->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
<!-- 如果走配置中心需要添加此依赖
<dependency>
   <groupId>com.alibaba.cloud</groupId>
   <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency> -->

<!-- 服务降级 -->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
</dependency>

3.在resource文件夹下新建bootstrap.yml,内容如下:

server:
  port: 7001
spring:
  profiles:
    active: dev
  application:
    name: jeecg-system
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848
feign:
  sentinel:
    enabled: true

4.修改dev配置文件,删除截图中两处配置

5.启动类添加注解:@EnableDiscoveryClient

二、启动jeecg-demo服务

升级其他模块为独立服务(例如demo模块) 以demo为例:

1.修改pom,将local-api修改成cloud-api

<dependency>
   <groupId>org.jeecgframework.boot</groupId>
   <artifactId>jeecg-system-cloud-api</artifactId>
</dependency>

2.添加配置文件bootstrap.yml(如果没有),内容如下:

server:
  port: 7002
spring:
  profiles:
    active: dev
  application:
    name: jeecg-demo
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848
feign:
  sentinel:
    enabled: true

3.新增配置文件application-dev.yml(如果没有),内容可以直接复制system下的同名文件,并删除此处端口号

4.在org.jeecg包下新建启动类(如果没有)

package org.jeecg;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.openfeign.EnableFeignClients;

import java.net.UnknownHostException;

@SpringBootApplication
@EnableDiscoveryClient
@EnableFeignClients
public class JeecgDemoApplication {

    public static void main(String[] args) throws UnknownHostException {
        SpringApplication.run(JeecgDemoApplication.class, args);
    }
}

上述步骤完成 即可启动nacos 运行每个模块的启动类 测试微服务。

三、启动Nacos

微服务通过Nacos 实现服务注册发现

docke安装nacos文档: https://nacos.io/zh-cn/docs/quick-start-docker.html

1.启动nacos,访问localhost:8848/nacos 账号密码 都是nacos,查看服务列表

2.启动system、demo,再查看服务列表

四、启动gateway

启动类: org.jeecg.JeecgGatewayApplication

查看在线接口文档: http://127.0.0.1:9999/doc.html

五、启动前端

前端项目找到文件public/index.html,修改后台服务为 gateway地址 修改地址:window._CONFIG['domianURL'] = 'http://127.0.0.1:9999,其中端口号 9999和gateway的端口保持一致


#常见问题

可以忽略不影响

#下面可以忽略

1.每个服务yml配置中有个属性 context-path: /jeecg-boot,服务化后需要修改成/,或者直接删除该配置

  1. 跨域设置,此设置可以忽略,文档留作记录 ```

org/jeecg/config/shiro/filters/JwtFilter.java:65 org/jeecg/config/WebMvcConfiguration.java:49 ```

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文