12 KiB
tmerclub项目新增一个微服务
说明: 本文以新增一个分销微服务(tmerclub-distribution)项目模块为例子
(默认已创建tmerclub_distribution数据库)
总体上分为5步:
新建tmerclub-distribution微服务模块
修改或者新增tmerclub_distribution的pom.xml、bootstrap.yml、Dockerfile、启动类上注解
nacos上新增tmerclub-distribution.yml文件,配置数据源;
nacos上修改tmerclub-gateway.yml文件配置路由;
nacos上新增tmerclub-distribution相关seata的配置;
新建tmerclub-api-distribution模块远程feign调用接口模块
tmerclub-distribution引入tmerclub-api-distribution模块,新增一些配置
1. 新增项目
a.在tmerclub上右键 New -> Module
b.我们要新增一个可以带启动类的项目,这里我们选择用springboot快速创建一个项目,选择Spring Initialiar
c.点击 Next 下一步
Group: com.mall4j.cloud
Artifact: tmerclub-distribution
Type: Maven
Language: Java
Packaging: Jar
Java version: 8
Version: 0.0.1-SNAPSHOT
Name: distribution
Description: tmerclub 分销服务
Package: com.mall4j.cloud.distribution
d.点击 Next 下一步,这里我们不需要选择任何依赖,我们需要在项目新增完成后,手动添加修改依赖
e.点击 Next 下一步
Module Name: tmerclub-distribution
Content root: 这个会根据 Module Name 自动修改。
Module file location: 这个会根据 Module Name 自动修改
最后点击 Finish 等待项目创建,创建完成的项目如下所示
2.修改项目tmerclub-distribution
a.我们需要删除掉一些文件和.mvn、test文件夹:
.mvn
application.properties
test
.gitignore
HELP.md
mvnw
mvnw.cmd
删除完成后的结果如下图所示
b.修改tmerclub-distribution的pom.xml文件, 依赖可根据实际需要引入或者删除,pom.xml修改后如下所示
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>tmerclub</artifactId>
<groupId>com.mall4j.cloud</groupId>
<version>0.0.1</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>tmerclub-distribution</artifactId>
<description>tmerclub 分销服务</description>
<packaging>jar</packaging>
<dependencies>
<!--注册中心客户端-->
<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.mall4j.cloud</groupId>
<artifactId>tmerclub-common-database</artifactId>
<version>${project.version}</version>
</dependency>
<dependency>
<groupId>com.mall4j.cloud</groupId>
<artifactId>tmerclub-common-security</artifactId>
<version>${project.version}</version>
</dependency>
<dependency>
<groupId>com.mall4j.cloud</groupId>
<artifactId>tmerclub-api-product</artifactId>
<version>${project.version}</version>
</dependency>
<dependency>
<groupId>com.mall4j.cloud</groupId>
<artifactId>tmerclub-api-search</artifactId>
<version>${project.version}</version>
</dependency>
<dependency>
<groupId>com.mall4j.cloud</groupId>
<artifactId>tmerclub-api-platform</artifactId>
<version>${project.version}</version>
</dependency>
<dependency>
<groupId>com.mall4j.cloud</groupId>
<artifactId>tmerclub-api-multishop</artifactId>
<version>${project.version}</version>
</dependency>
<dependency>
<groupId>com.mall4j.cloud</groupId>
<artifactId>tmerclub-api-order</artifactId>
<version>${project.version}</version>
</dependency>
<dependency>
<groupId>com.mall4j.cloud</groupId>
<artifactId>tmerclub-api-delivery</artifactId>
<version>${project.version}</version>
</dependency>
<dependency>
<groupId>com.mall4j.cloud</groupId>
<artifactId>tmerclub-common-rocketmq</artifactId>
<version>${project.version}</version>
</dependency>
<dependency>
<groupId>com.xuxueli</groupId>
<artifactId>xxl-job-core</artifactId>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
<plugin>
<groupId>io.fabric8</groupId>
<artifactId>docker-maven-plugin</artifactId>
<configuration>
<skip>false</skip>
</configuration>
</plugin>
</plugins>
</build>
</project>
在tmerclub的pom.xml的modules里面添加tmerclub-distribution模块
<modules>
<module>tmerclub-distribution</module>
</modules>
c. 新增bootstrap.yml文件,并且配置好项目的端口、名称以及nacos注册中心的地址
d. 修改启动类上的启动配置
@SpringBootApplication(scanBasePackages = { "com.mall4j.cloud" },exclude = UserDetailsServiceAutoConfiguration.class)
@EnableFeignClients(basePackages = {"com.mall4j.cloud.**.feign"})
e. 先去nacos上面新增一个tmerclub-distribution.yml配置文件,并且配置好数据源
Data ID: tmerclub-distribution.yml
Group: DEFAULT_GROUP
配置格式: YAML
配置内容:
#数据源
spring:
datasource:
url: jdbc:mysql://192.168.193.128:3306/tmerclub_distribution?characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=FALSE&useJDBCCompliantTimezoneShift=TRUE&useLegacyDatetimeCode=FALSE&serverTimezone=GMT%2B8&allowMultiQueries=true&rewriteBatchedStatements=true&allowPublicKeyRetrieval=TRUE&useAffectedRows=TRUE
username: root
PASSWORD: root
f.新增完成后,我们需要在我们的网关tmerclub-gateway,配置一下tmerclub-distribution的路由,在nacos上找到我们的tmerclub-gateway.yml文件,新增tmerclub-distribution路由配置
- id: tmerclub-distribution
uri: lb://tmerclub-distribution
predicates:
- Path=/tmerclub_distribution/**
filters:
- RewritePath=/tmerclub_distribution(?<segment>/?.*), $\{segment}
j.我们引入了seata,所以 还需要在nacos的application.yml上配置seata
seata:
enableAutoDataSourceProxy: false
config:
type: nacos
nacos:
namespace: nacos中seata的命名空间id
dataId: "seataServer.properties"
server-addr: ${spring.cloud.nacos.discovery.server-addr}
password: ${spring.cloud.nacos.discovery.password}
username: ${spring.cloud.nacos.discovery.username}
registry:
type: nacos
nacos:
server-addr: ${spring.cloud.nacos.discovery.server-addr}
password: ${spring.cloud.nacos.discovery.password}
username: ${spring.cloud.nacos.discovery.username}
namespace: ${seata.config.nacos.namespace}
我们尝试启动,如果启动成功且服务没有打印错误日志,我们这个微服务基本上是创建成功了。
接下来,我们需要完善一些服务需要的其他内容
3.新增远程调用api
就我们的项目结构设计而言,我们把feign远程调用的接口都抽取了出来,放在了tmerclub-api这个模块下面,所以我们要新增一个tmerclub-api-distribution模块
a.在tmerclub-api上右键 New -> Module
b.我们只是新增一个模块,这个地方不需要启动类,所以我们这里创建一个maven就好了
c.点击 Next 下一步
Parent: tmerclub-api // 选择tmerclub-api
Name: tmerclub-api-distribution
Lacation: 自动填写
GroupId: com.mall4j.cloud.api
Artifactld: tmerclub-api-distribution
Version: 0.01
4.点击 Finish ,创建完成后如图所示
删除test、resource文件夹,修改pom.xml文件,新增tmerclub-api-distribution的feign接口
修改后的pom.xml文件
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>tmerclub-api</artifactId>
<groupId>com.mall4j.cloud</groupId>
<version>0.0.1</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>tmerclub-api-distribution</artifactId>
<packaging>jar</packaging>
<description>分销对内接口</description>
<dependencies>
<dependency>
<groupId>com.mall4j.cloud</groupId>
<artifactId>tmerclub-common-order</artifactId>
<version>${project.version}</version>
</dependency>
<dependency>
<groupId>com.mall4j.cloud</groupId>
<artifactId>tmerclub-common-product</artifactId>
<version>${project.version}</version>
</dependency>
</dependencies>
</project>
新增的DistributionFeignClient.class类
接口上要加上注解@FeignClient(value = "tmerclub-distribution",contextId ="distribution")
package com.mall4j.cloud.api.distribution.feign;
import org.springframework.cloud.openfeign.FeignClient;
/**
* @author cl
* @date 2021-08-05 16:07:34
*/
@FeignClient(value = "tmerclub-distribution",contextId ="distribution")
public interface DistributionFeignClient {
}
4.完善tmerclub-distribution的配置和feign接口实现
在tmerclub-distribution项目引入tmerclub-api-distribution
<dependency>
<groupId>com.mall4j.cloud</groupId>
<artifactId>tmerclub-api-distribution</artifactId>
<version>${project.version}</version>
</dependency>
DistributionFeignController来实现DistributionFeignClient接口
public class DistributionFeignController implements DistributionFeignClient {
}
添加Swagger文档配置SwaggerConfiguration.class
/**
* Swagger文档,只有在测试环境才会使用
*
* @author FrozenWatermelon
*/
@Configuration
@EnableSwagger2
@EnableKnife4j
public class SwaggerConfiguration {
@Bean
public Docket baseRestApi() {
return new Docket(DocumentationType.SWAGGER_2).apiInfo(apiInfo()).select()
.apis(RequestHandlerSelectors.basePackage("com.mall4j.cloud.distribution.controller")).paths(PathSelectors.any())
.build();
}
@Bean
public ApiInfo apiInfo() {
return new ApiInfoBuilder().title("tmerclub商城接口文档").description("tmerclub商城接口文档Swagger版").termsOfServiceUrl("")
.contact(new Contact("广州蓝海创新科技有限公司", "", "")).version("1.0").build();
}
}
到这里微服务就创建完成了,相关基本配置也搭建好了。