• spring initializr脚手架搭建详解


    这是我参与「掘金日新计划 · 12 月更文挑战」的第3天,点击查看活动详情

    前段时间,我在「基于start.spring.io,我实现了Java脚手架定制」一文中讲述了敝司的微服务脚手架落地过程中的前世今生,并提到了基于 spring initializr 的搭建了 2.0 版本的脚手架。今天我打算和你分享一下这其中的实现过程与细节,项目已经开源在 Github 上。

    start-parent:github.com/studeyang/s…

    欢迎 star

    1、项目结构介绍

    项目分为 initializr、start-client、start-site 三个部分,重要部分说明如下。

    1.  start-parent
    2.   |- initializr                   代码生成
    3.     |- initializr-actuator
    4.     |- initializr-bom
    5.     |- initializr-docs
    6.     |- initializr-generator         生成基础工程代码
    7.     |- initializr-generator-spring 生成 spring 工程代码
    8.     |- initializr-generator-test   单元测试的封装
    9.     |- initializr-generator-zebra   生成 zebra 分层架构
    10.     |- initializr-metadata         工程元数据(pom 相关定义)
    11.     |- initializr-parent
    12.     |- initializr-service-sample
    13.     |- initializr-version-resolver 版本解析
    14.     |- initializr-web
    15.   |- start-client                   脚手架前端
    16.   |- start-site                     脚手架后端
    17. 复制代码

    工程间的依赖关系图我作了简化,图示如下。

    了解了项目的整体情况,下面请跟随我的思路,一起将工程搭建起来。

    2、集成Gitlab

    如果你想使用项目中的「创建工程」功能,则需要进行此步骤的配置。这里我以gitlab.com为例,介绍如何完成与 Gitlab 的集成。

    首先需要让 Gitlab 信任我们的应用,以完成后面的登录授权跳转。在 Gitlab 平台配置脚手架应用。

    这里我配置了本地开发环境的 Redirect URI,如果后续需要部署到服务器,则应该配置脚手架服务器的后端地址。

    配置完成后,Gitlab 就将我们的应用记录了下来,并分配了 Application ID 和 Secret,这两个字段值我们需要配置到 start-site application.yml 文件中:

    1.  security:
    2.   base-url: https://gitlab.com
    3.   authorization-uri: ${security.base-url}/oauth/authorize
    4.   token-uri: ${security.base-url}/oauth/token
    5.   user-info-uri: ${security.base-url}/api/v4/user
    6.   redirect-uri: http://127.0.0.1:8081/oauth/redirect
    7.   client-id: gitlab client id
    8.   client-secret: gitlab client secret
    9.   admin:
    10.     name: your gitlab admin username
    11.     password: your gitlab admin password
    12. 复制代码

    这里我简单介绍一下相关字段,authorization-uri, token-uri, user-info-uri 这三个字段是固定的,不需要配置。

    • base-url:如果你使用gitlab管理项目,base-url可以设置成你搭建的gitlab地址;
    • redirect-uri:gitlab 认证后跳转的地址,这里使用了后端来接收跳转,因为跳转会携带 code 参数,避免暴露在浏览器,提高安全性;
    • client-id:gitlab 分配的 Application ID;
    • client-secret:gitlab 分配的 Secret;
    • admin.name:gitlab 的账号,用于创建工程,并将初始的工程代码提交,建议配置管理员账号;
    • admin.password:gitlab 的账号密码;

    3、添加组件

    接下来添加组件依赖。这里我以casslog-spring-boot-starterJar 包为例,如果该组件仅支持部分版本的 SpringBoot,那可以配置 compatibility-range,例如:

    1.  compatibility-range: "[1.4.2.RELEASE,1.5.7.RELEASE]"
    2. 复制代码

    完整的配置如下。

    1.  initializr:
    2.   dependencies:
    3.     - name: 开源基础设施
    4.       bom: kmw
    5.       repository: my-rep
    6.       content:
    7.         - name: Casslog
    8.           id: casslog
    9.           groupId: io.github.studeyang
    10.           artifactId: casslog-spring-boot-starter
    11.           description: 日志工具类
    12.           starter: true
    13.           compatibility-range: "[1.4.2.RELEASE,1.5.7.RELEASE]"
    14.           links:
    15.             - rel: guide
    16.               href: {用户手册}
    17.               description: Example 快速开始
    18.             - rel: reference
    19.               href: {参考文档}
    20. 复制代码

    配置dependencies。

    • 「name」组件依赖类别的名称,例如:开源基础设施
    • 「bom」该类别下的依赖包管理库
    • 「repository」该类别下的依赖包所属仓库
    • 「content」具体的依赖包

    配置content。

    • 「name」依赖包名称
    • 「id」依赖包唯一标识(代码中使用)
    • 「groupId」依赖包 groupId
    • 「artifactId」依赖包 artifactId
    • 「description」依赖包 description
    • 「starter」是否是 spring-boot-starter
    • 「compatibility-range」依赖的 springboot 版本
    • 「links」组件的使用文档

    配置好的效果图如下。

    4、部署应用

    下面就可以将脚手架部署到服务器上了。

    这里提醒一下,记得修改 Gitlab 的 redirect-uri 为脚手架服务器的地址。

    4.1 步骤一:工程打包

    1.  # 打包前端工程
    2.  cd {projectRoot}/start-client
    3.  sh ../mvnw install
    4.  ​
    5.  # 打包 initializr 项目
    6.  cd {projectRoot}/initializr
    7.  sh ../mvnw clean install -Dmaven.test.skip=true
    8.  ​
    9.  # 打包 start-site
    10.  cd {projectRoot}/start-site
    11.  sh ../mvnw clean install -Dmaven.test.skip=true
    12. 复制代码

    4.2 步骤二:打 Docker 镜像

    1.  cd {projectRoot}/start-site
    2.  docker build -t start-site:0.0.1 .
    3. 复制代码

    运行镜像即可。效果图如下。

    5、使用脚手架的正确姿势

    5.1 通过HELP.md管理使用文档

    在「3、添加组件」过程中所配置的文档链接将会在 HELP.md 文件中展示,示意图如下:

    5.2 保存/分享工程

    你配置好的工程可以通过「分享...」功能保存下来。

    5.3 在IDEA中使用脚手架

    可在 IDEA 中快速创建工程,只需要配置好脚手架服务器地址即可。需要注意的是社区版的 IDEA 是没有这个功能的。

    小结

    本文向你介绍了 Spring Initializr 脚手架的搭建过程,如果你在此过程中遇到了问题,可以提 ISSUE 或者在公众号「杨同学technotes」后台给我留言。

  • 相关阅读:
    如何解决双因素和多因素身份认证的大问题
    车联网产业中网络安全与数据安全应该怎么做
    leetcode-28. 实现 strStr()-20220829-KMP算法
    编译器的符号表管理
    文件操作 和 IO - 详解
    1-10嵌入式Linux系统开发与应用|嵌入式Linux|第三章 Linux编程环境|下篇
    springboot--单元测试
    探秘磁盘的奥秘:物理结构、缓存和虚拟内存的作用
    打车系统网约车系统开发支持APP公众号H5小程序版本源码
    一文理解虚拟机栈
  • 原文地址:https://blog.csdn.net/BASK2311/article/details/128092245