发布时间:2025-11-02 21:19:37 来源:创站工坊 作者:应用开发

本文转载自微信公众号「JAVA日知录」,基于作者飘渺Jam。微服务转载本文请联系JAVA日知录公众号。实战
现有 一个微服务项目,基于按照业务拆分为如下几个模块
book-web 前端,微服务采用 Vue MVVM,实战服务端 Thymeleaf SSR 渲染,基于友好 SEO MPA。微服务服务端 路由,实战Spring MVC book-gateway 微服务网关,基于Spring Cloud Gateway book-service 接口提供方,微服务Spring Cloud Alibaba Dubbo 服务消费方 book-server 数据承载方,实战Spring Cloud Alibaba Dubbo 服务提供方 book-common 实体,基于Dubbo 接口 jar cloud-common 微服务公共 jar common pom school-parent 最上级 父工程 pom在项目根路径下执行,源码下载微服务Maven 命令,实战截取 2 段输出
mvn clean install -pl com.lab:book-common -am -Ptest [INFO] Reactor Build Order: [INFO] [INFO] school_parent [pom] [INFO] common [pom] [INFO] cloud-common [jar] [INFO] book-common [INFO] Reactor Summary for school_parent 0.0.1-SNAPSHOT: [INFO] [INFO] school_parent ...................................... SUCCESS [ 0.761 s] [INFO] common ............................................. SUCCESS [ 0.083 s] [INFO] cloud-common ....................................... SUCCESS [ 6.430 s] [INFO] book-common ........................................ SUCCESS [ 3.236 s] [INFO] ------------------------------------------------------------------------ [INFO] BUILD SUCCESS [INFO] ------------------------------------------------------------------------ [INFO] Total time: 11.880 s [INFO] Finished at: 2020-05-03T14:13:12+08:00 [INFO] ------------------------------------------------------------------------docker 和 docker-compose 适合 测试环境使用,生产环境用 Kubernetes,安装 步骤命令本站基本都有:http://javadaily.cn/
root@jazz-pc:/opt# docker ps --format "table {{.Names}} ------------- {{.Image}}" NAMES ------------- IMAGE rmqbroker ------------- apacherocketmq/rocketmq:4.5.2-alpine rmqnamesrv ------------- apacherocketmq/rocketmq:4.5.2-alpine seata-server ------------- seataio/seata-server:1.2.0 nacos ------------- nacos/nacos-server:1.2.1 minio ------------- minio/minio es ------------- elasticsearch:7.6.2 zookeeper ------------- zookeeper mysql ------------- mysql:5.7 mongo ------------- mongo redis ------------- redissettings.xml 文件,加个国内镜像
<mirror> <id>aliyunmaven</id> <mirrorOf>*</mirrorOf> <name>阿里云公共仓库</name> <url>https://maven.aliyun.com/repository/public</url> </mirror>顶级父工程 pom.xml 添加,跳过 单元测试 编译和执行
<maven.test.skip>true</maven.test.skip> <skipTests>true</skipTests>如果有 Maven Nexus,则另外添加设置,install 替换为 deploy
Jenkins JDK 环境 >=1.8 and <=11 目前最新版本不支持 Java 14
Jenkins 安装一般会卡住 2 次,则是去国外下载插件数据缓慢的原因,kill -9 进程 ID,ps -ef | grep jenkins 找到进程 ID。亿华云
第一次卡住修改 :/root/.jenkins/hudson.model.UpdateCenter.xml 文件里面链接内容为 国内镜像地址 https://mirrors.tuna.tsinghua.edu.cn/jenkins/updates/update-center.json
第二次卡住执行替换命令:
cd /root/.jenkins/updates sed -i s/http:\/\/updates.jenkins-ci.org\/download/https:\/\/mirrors.tuna.tsinghua.edu.cn\/jenkins/g default.json && sed -i s/http:\/\/www.google.com/https:\/\/www.baidu.com/g default.json
book-web 执行构建 Build Now

book-web 前端 浏览器访问

login.html 登录模板示例页面,调用 /api/login 接口,内容如下
<!DOCTYPE html> <html xmlns:th="http://www.thymeleaf.org"> <head> <meta charset="UTF-8"/> <title>理想生活上天猫,登录页面</title> <r th:insert="common/header::#headerApp"/> </head> <body> <div id="app"> <el-row :gutter="20"> <el-col :span="24"> </el-col> </el-row> <el-row :gutter="20"> <el-col :span="1"> </el-col> <el-col :span="4"> <img alt="我是亿华云计算一只天猫" src="//img.alicdn.com/tfs/TB11ojWRXXXXXafaFXXXXXXXXXX-190-27.png"> </el-col> <el-col :span="19"> </el-col> </el-row> <el-row :gutter="20"> <el-col :span="15"> <img alt="九寨沟" src="/images/JiuZhaiGou.jpg" width="800" height="490"> </el-col> <el-col :span="7"> <template> <el-tabs v-model="activeName" @tab-click="handleClick"> <el-tab-pane label="密码登录" name="first"> <el-form ref="form" :model="userForm" label-width="80px"> <el-row> <el-input placeholder="会员名/邮箱/手机号" prefix-icon="el-icon-user" v-model="userForm.name"></el-input> </el-row> <el-row> <el-input placeholder="请输入密码" prefix-icon="el-icon-lock" v-model="userForm.password" show-password></el-input> </el-row> <el-row> <el-button @click="login" type="danger">登录</el-button> </el-row> </el-form> </el-tab-pane> <el-tab-pane label="短信登录" name="second">短信登录</el-tab-pane> </el-tabs> </template> </el-col> <el-col :span="2"> </el-col> </el-row> </div> <r th:replace="common/footer::.footerApp"/> <script src="/js/request.js"></script> <script> new Vue({ el: #app, data: { userForm:{}, activeName: first }, methods: { login() { request({ url: /api/login,method: post,data: this.userForm, headers: { content-type: application/json;charset=UTF-8,"token": } }).then(response=>{ var res = response.data; this.$message(res.message); }) }, handleClick(tab, event) { //console.log(tab, event); } } }); </script> </body> </html>