• spring-brick插件开发记录


    1、基础配置

    1.1、工程结构

    使用maven的聚合模式创建多个module

    1.2、集成插件POM改造

    主程序pom中引入依赖:

        
        com.gitee.starblues
        spring-brick
        ${spring-brick.version}
    

    主程序打包方式:

       
         com.gitee.starblues
            spring-brick-maven-packager
            ${spring-brick.version}
            
                    main
                    
                        com.demo.main.Application
                    
                
            
                    
                        
                            repackage
                        
                    
                
    

    其中configuration配置中的mode固定写成 main

    mainClass则是主程序的启动类的全路径

    插件pom中引入依赖

       
        com.gitee.starblues
        spring-brick-bootstrap
        ${spring-brick.version}
    

    插件打包方式

       
            com.gitee.starblues
            spring-brick-maven-packager
            ${spring-brick.version}
            
                    prod
                    
                        preprocess-plugin
                         com.demo.preprocess.plugin.PreprocessPluginApplication
                        1.0.0
                        auto
                        demo插件
                    application.properties
                    
                    
                        jar
                    
                
            
                    
                        
                            repackage
                        
                    
                
    

    重点参数说明:

    mode :提供了两种模式dev/prod固定写成prod,每次安装都会生成可以在线上部署的jar,同时也不影响本地程序的正常启动

    id :写插件的工程名称

    bootstrapClass:插件启动类的全路径

    configFileName:插件内配置文件的名称如果是application-dev.properties则文件名称也要写成这个名称,不支持spring.profiles.active 配置做切换

    1.3、集成插件启动类改造

    主程序启动类实现插件框架的SpringBootstrap:

    public class Application implements SpringBootstrap {
        public static void main(String[] args) {
            SpringMainBootstrap.launch(Application.class, args);
        }
    
        @Override
        public void run(String[] args) throws Exception {
            SpringApplication.run(Application.class, args);
        }
    }

    插件启动类继承SpringPluginBootstrap:

    public class PluginApplication extends SpringPluginBootstrap {
        public static void main(String[] args) {
            SpringApplication.run(PluginApplication.class, args);
        }
    }
    

    1.4、集成插件配置修改


    只需要在主程序的配置文件中配置即可
    ###############【插件的配置】################## 插件运行模式. dev: 开发环境, prod: 生产环境
    plugin.runMode= dev
    # 主程序的启动类所在包
    plugin.mainPackage= com.demo.preprocess.main
    # 插件rest接口前缀
    plugin.pluginRestPathPrefix= /
    # 插件存放的目录
    plugin.pluginPath[0]= ~\preprocess-plugins
    参数说明:
    plugin.runMode:插件模式支持dev/prod 两种 默认写成dev
    plugin.mainPackage: 主程序的启动类所在包
    plugin.pluginRestPathPrefix: 插件的rest接口前缀配置 默认/
    plugin.pluginPath[0]:插件存档的目录 写成1.1中说明的插件pom的父工程的名称“~”表示相对主程序的相对路径,也支持全路径,建议写成
    ~/插件的父pom工程名


    2、三方组件集成
    2.1、Nacos远程的配置注册中心
    前提:需要有Nacos服务,目前使用版本2.0.1
    主程序pom 引入nacos配置

        com.alibaba.cloud
        spring-cloud-starter-alibaba-nacos-config
        2.2.6.RELEASE



        com.alibaba.cloud
        spring-cloud-starter-alibaba-nacos-discovery
        2.2.6.RELEASE


        org.springframework.cloud
        spring-cloud-starter-bootstrap


    主程序的配置文件新增 bootstrap.properties:
    添加nacos的配置
    #服务发现nacos地址
    spring.cloud.nacos.discovery.server-addr=ip
    #服务发现分组
    spring.cloud.nacos.discovery.group=demo
    #服务配置nacos地址
    spring.cloud.nacos.config.server-addr=${spring.cloud.nacos.server-addr}
    #配置文件的文件后缀
    spring.cloud.nacos.config.fileExtension= properties
    #配置文件配置自动刷新
    spring.cloud.nacos.config.refresh-enabled=true
    #扩展的配置文件
    spring.cloud.nacos.config.shared-configs[0].data-id= demo-common.properties
    #开启扩展的配置自动刷新
    spring.cloud.nacos.config.shared-configs[0].refresh= true
    #项目名称
    spring.application.name= demo-preprocess
    插件改造和主程序一样添加,需要去掉配置中心的配置

    去除引入的注册中心的依赖包
        
               com.alibaba.cloud
        spring-cloud-starter-alibaba-nacos-discovery
        2.2.6.RELEASE

     

    去掉配置:

      #服务发现nacos地址
       spring.cloud.nacos.discovery.server-addr=ip
       #服务发现分组
       spring.cloud.nacos.discovery.group=demo

    2.2、Swagger可视化RESTful风格Web服务
    在项目的顶层的pom中引入Swagger需要的依赖:

        com.github.xiaoymin
        knife4j-spring-boot-starter
        2.0.7
        
            
                org.springframework
                spring-core
            

            
                org.springframework
                spring-aop
            

            
                org.springframework
                spring-beans
            

            
                org.springframework
                spring-context
            

        

    在主程序配置swagger即可:
    @Configuration@EnableSwagger2WebMvc
    public class Swagger2Config {

        @Value("${server.port}")
        private String port;
        @Value("${plugin.runMode}")
        private String runMode;
        @Bean
        public Docket createRestApi() {
            return new Docket(DocumentationType.SWAGGER_2)
                    .useDefaultResponseMessages(false)
                    .apiInfo(apiInfo())
                    .groupName(runMode)
                    .select()
                    .apis(RequestHandlerSelectors.withClassAnnotation(Api.class))
                    .paths(PathSelectors.any())
                    .build();
        }

        private ApiInfo apiInfo() {
            return new ApiInfoBuilder()
                    .title("QBFX-PREPROCESS接口文档")
                    .description("接口说明文档")
                    .termsOfServiceUrl("http://ip:" + port + "/**")
                    .contact(new Contact("qbfx-preprocess", "", ""))
                    .version("1.0")
                    .build();
        }    /**
         * 解决springboot2.6.x集成swagger报错
         *
         * @param webEndpointsSupplier
         * @param servletEndpointsSupplier
         * @param controllerEndpointsSupplier
         * @param endpointMediaTypes
         * @param corsProperties
         * @param webEndpointProperties
         * @param environment
         * @return
         */
        @Bean
        public WebMvcEndpointHandlerMapping webEndpointServletHandlerMapping(WebEndpointsSupplier webEndpointsSupplier
                , ServletEndpointsSupplier servletEndpointsSupplier, ControllerEndpointsSupplier controllerEndpointsSupplier
                , EndpointMediaTypes endpointMediaTypes, CorsEndpointProperties corsProperties
                , WebEndpointProperties webEndpointProperties, Environment environment) {
            List allEndpoints = new ArrayList<>();
            Collection webEndpoints = webEndpointsSupplier.getEndpoints();
            allEndpoints.addAll(webEndpoints);
            allEndpoints.addAll(servletEndpointsSupplier.getEndpoints());
            allEndpoints.addAll(controllerEndpointsSupplier.getEndpoints());
            String basePath = webEndpointProperties.getBasePath();
            EndpointMapping endpointMapping = new EndpointMapping(basePath);
            boolean shouldRegisterLinksMapping = webEndpointProperties.getDiscovery().isEnabled()
                    && (org.springframework.util.StringUtils.hasText(basePath)
                    || ManagementPortType.get(environment).equals(ManagementPortType.DIFFERENT));
            return new WebMvcEndpointHandlerMapping(endpointMapping, webEndpoints, endpointMediaTypes, corsProperties.toCorsConfiguration()
                    , new EndpointLinksResolver(allEndpoints, basePath), shouldRegisterLinksMapping);
        }
    }
    主程序配置文件中配置:
    # 路径匹配
    spring.mvc.pathmatch.matching-strategy= ant_path_matcher
    访问地址:http://ip:port/doc.html
    查看插件的rest接口也注册成功,可以正常使用,注意请求的路径多一个插件的项目名

  • 相关阅读:
    linux的yum 、yum的周边环境
    Git项目管理快速入门,轻松易上手
    虚幻C++ day5
    做人力资源选择小公司or大公司?看完这篇再做决定
    Node.js 应用开发详解14 工具应用:使用 clinicj 工具实现通用性安全检查
    STM32CubeMX 学习(5)输入捕获实验
    (附源码)springboot大学生竞赛管理平台 毕业设计
    c++数据结构算法复习基础-- 3 --线性表-单向链表-笔试面试常见问题
    栈题目:函数的独占时间
    ubuntu静态ip地址设置
  • 原文地址:https://blog.csdn.net/qq_34410726/article/details/126572489