feat: 初始化连接池
parent
a0cf7e7c3a
commit
b71163984e
|
@ -25,4 +25,9 @@ public class ServiceNameConstants {
|
||||||
* 数据源管理
|
* 数据源管理
|
||||||
*/
|
*/
|
||||||
public static final String DATA_SOURCE_SERVICE = "muyu-data-source";
|
public static final String DATA_SOURCE_SERVICE = "muyu-data-source";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 数据引擎管理
|
||||||
|
*/
|
||||||
|
public static final String RULE_ENGINE_SERVICE = "muyu-ruleengine";
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,6 +2,8 @@ package com.muyu.data.source.client.config;
|
||||||
|
|
||||||
import com.muyu.common.core.domain.Result;
|
import com.muyu.common.core.domain.Result;
|
||||||
import com.muyu.common.core.web.page.TableDataInfo;
|
import com.muyu.common.core.web.page.TableDataInfo;
|
||||||
|
import com.muyu.data.source.client.pool.MysqlPool;
|
||||||
|
import com.muyu.data.source.client.pool.config.MysqlPoolConfig;
|
||||||
import com.muyu.data.source.domain.DataSource;
|
import com.muyu.data.source.domain.DataSource;
|
||||||
import com.muyu.data.source.domain.req.DataSourceQueryReq;
|
import com.muyu.data.source.domain.req.DataSourceQueryReq;
|
||||||
import com.muyu.data.source.remote.RemoteDataManagerService;
|
import com.muyu.data.source.remote.RemoteDataManagerService;
|
||||||
|
@ -10,6 +12,7 @@ import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.boot.ApplicationArguments;
|
import org.springframework.boot.ApplicationArguments;
|
||||||
import org.springframework.boot.ApplicationRunner;
|
import org.springframework.boot.ApplicationRunner;
|
||||||
|
|
||||||
|
import java.sql.Connection;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -31,5 +34,13 @@ public class DataSourceClientRunner implements ApplicationRunner {
|
||||||
public void run(ApplicationArguments args) throws Exception {
|
public void run(ApplicationArguments args) throws Exception {
|
||||||
Result<List<DataSource>> dataSourceList = remoteDataManagerService.postList(new DataSourceQueryReq());
|
Result<List<DataSource>> dataSourceList = remoteDataManagerService.postList(new DataSourceQueryReq());
|
||||||
log.info(dataSourceList);
|
log.info(dataSourceList);
|
||||||
|
List<DataSource> data = dataSourceList.getData();
|
||||||
|
for (DataSource datum : data) {
|
||||||
|
MysqlPool mysqlPool = new MysqlPool(MysqlPoolConfig.buildConfig(datum));
|
||||||
|
mysqlPool.init();
|
||||||
|
Connection conn = mysqlPool.getConn();
|
||||||
|
mysqlPool.reaplase(conn);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,6 +16,7 @@ public class BaseConfig {
|
||||||
|
|
||||||
public static void driver(String driverName){
|
public static void driver(String driverName){
|
||||||
try {
|
try {
|
||||||
|
|
||||||
Class.forName(driverName);
|
Class.forName(driverName);
|
||||||
} catch (ClassNotFoundException e) {
|
} catch (ClassNotFoundException e) {
|
||||||
throw new RuntimeException(e);
|
throw new RuntimeException(e);
|
||||||
|
|
|
@ -5,6 +5,7 @@ import com.baomidou.mybatisplus.annotation.IdType;
|
||||||
import com.baomidou.mybatisplus.annotation.TableId;
|
import com.baomidou.mybatisplus.annotation.TableId;
|
||||||
import com.muyu.common.core.annotation.Excel;
|
import com.muyu.common.core.annotation.Excel;
|
||||||
import com.muyu.data.source.client.pool.BaseConfig;
|
import com.muyu.data.source.client.pool.BaseConfig;
|
||||||
|
import com.muyu.data.source.domain.DataSource;
|
||||||
import com.muyu.data.source.domain.SysDataSource;
|
import com.muyu.data.source.domain.SysDataSource;
|
||||||
import io.swagger.annotations.ApiModelProperty;
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
import lombok.Builder;
|
import lombok.Builder;
|
||||||
|
@ -97,12 +98,13 @@ public class MysqlPoolConfig extends BaseConfig {
|
||||||
@ApiModelProperty(name = "驱动名称", value = "驱动名称")
|
@ApiModelProperty(name = "驱动名称", value = "驱动名称")
|
||||||
private String driverName;
|
private String driverName;
|
||||||
|
|
||||||
public static MysqlPoolConfig buildConfig(SysDataSource sysDataSource) {
|
public static MysqlPoolConfig buildConfig(DataSource sysDataSource) {
|
||||||
return MysqlPoolConfig.builder()
|
return MysqlPoolConfig.builder()
|
||||||
.id(sysDataSource.getId())
|
.id(sysDataSource.getId())
|
||||||
.initialQuantity(sysDataSource.getInitialQuantity())
|
.initialQuantity(sysDataSource.getInitialQuantity())
|
||||||
.maximumFrequency(sysDataSource.getMaximumFrequency())
|
.maximumFrequency(sysDataSource.getMaximumFrequency())
|
||||||
.maximumQuantity(sysDataSource.getMaximumQuantity())
|
.maximumQuantity(sysDataSource.getMaximumQuantity())
|
||||||
|
.maximumTime(sysDataSource.getMaximumTime())
|
||||||
.driverName(sysDataSource.getDriverName())
|
.driverName(sysDataSource.getDriverName())
|
||||||
.hostAddress(sysDataSource.getHostAddress())
|
.hostAddress(sysDataSource.getHostAddress())
|
||||||
.hostPort(sysDataSource.getHostPort())
|
.hostPort(sysDataSource.getHostPort())
|
||||||
|
|
|
@ -106,6 +106,11 @@ public class DataSource extends BaseEntity {
|
||||||
@ApiModelProperty(name = "数据库用户密码", value = "数据库用户密码")
|
@ApiModelProperty(name = "数据库用户密码", value = "数据库用户密码")
|
||||||
private String databaseUserPassword;
|
private String databaseUserPassword;
|
||||||
|
|
||||||
|
/** 数据库用户密码 */
|
||||||
|
@Excel(name = "连接驱动")
|
||||||
|
@ApiModelProperty(name = "连接驱动", value = "连接驱动")
|
||||||
|
private String driverName;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 查询构造器
|
* 查询构造器
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -5,6 +5,7 @@ import com.muyu.common.security.annotation.EnableMyFeignClients;
|
||||||
import com.muyu.common.swagger.annotation.EnableCustomSwagger2;
|
import com.muyu.common.swagger.annotation.EnableCustomSwagger2;
|
||||||
import org.springframework.boot.SpringApplication;
|
import org.springframework.boot.SpringApplication;
|
||||||
import org.springframework.boot.autoconfigure.SpringBootApplication;
|
import org.springframework.boot.autoconfigure.SpringBootApplication;
|
||||||
|
import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 数据启动类 DataSourceApplication
|
* 数据启动类 DataSourceApplication
|
||||||
|
@ -15,7 +16,7 @@ import org.springframework.boot.autoconfigure.SpringBootApplication;
|
||||||
@EnableCustomConfig
|
@EnableCustomConfig
|
||||||
@EnableCustomSwagger2
|
@EnableCustomSwagger2
|
||||||
@EnableMyFeignClients
|
@EnableMyFeignClients
|
||||||
@SpringBootApplication
|
@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class})
|
||||||
public class DataSourceUnitApplication {
|
public class DataSourceUnitApplication {
|
||||||
public static void main(String[] args) {
|
public static void main(String[] args) {
|
||||||
SpringApplication.run(DataSourceUnitApplication.class, args);
|
SpringApplication.run(DataSourceUnitApplication.class, args);
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<configuration scan="true" scanPeriod="60 seconds" debug="false">
|
<configuration scan="true" scanPeriod="60 seconds" debug="false">
|
||||||
<!-- 日志存放路径 -->
|
<!-- 日志存放路径 -->
|
||||||
<property name="log.path" value="logs/muyu-system"/>
|
<property name="log.path" value="logs/muyu-data-unit"/>
|
||||||
<!-- 日志输出格式 -->
|
<!-- 日志输出格式 -->
|
||||||
<property name="log.pattern" value="%d{HH:mm:ss.SSS} [%thread] %-5level %logger{20} - [%method,%line] - %msg%n"/>
|
<property name="log.pattern" value="%d{HH:mm:ss.SSS} [%thread] %-5level %logger{20} - [%method,%line] - %msg%n"/>
|
||||||
|
|
||||||
|
|
|
@ -16,5 +16,23 @@
|
||||||
<maven.compiler.target>17</maven.compiler.target>
|
<maven.compiler.target>17</maven.compiler.target>
|
||||||
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
||||||
</properties>
|
</properties>
|
||||||
|
<dependencies>
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.muyu</groupId>
|
||||||
|
<artifactId>muyu-ruleengine-remote</artifactId>
|
||||||
|
<version>3.6.3</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.alibaba</groupId>
|
||||||
|
<artifactId>druid</artifactId>
|
||||||
|
<version>1.2.6</version>
|
||||||
|
<scope>compile</scope>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.muyu</groupId>
|
||||||
|
<artifactId>muyu-ruleengine-common</artifactId>
|
||||||
|
<version>3.6.3</version>
|
||||||
|
</dependency>
|
||||||
|
</dependencies>
|
||||||
|
|
||||||
</project>
|
</project>
|
||||||
|
|
|
@ -0,0 +1,15 @@
|
||||||
|
package com.muyu.ruleenign.client.config;
|
||||||
|
|
||||||
|
import org.springframework.context.annotation.ComponentScan;
|
||||||
|
import org.springframework.context.annotation.Import;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 引擎配置RuleEngineClientConfig
|
||||||
|
*
|
||||||
|
* @author DeKangLiu
|
||||||
|
* Date 2024/5/10 19:06
|
||||||
|
*/
|
||||||
|
@ComponentScan
|
||||||
|
@Import(value = {RuleEngineClientRunner.class})
|
||||||
|
public class RuleEngineClientConfig {
|
||||||
|
}
|
|
@ -0,0 +1,31 @@
|
||||||
|
package com.muyu.ruleenign.client.config;
|
||||||
|
|
||||||
|
import com.muyu.common.core.domain.Result;
|
||||||
|
import com.muyu.ruleengine.domain.Ruleengine;
|
||||||
|
import com.muyu.ruleengine.domain.req.RuleengineQueryReq;
|
||||||
|
import com.muyu.ruleengine.remote.RemoteRuleEngineManagerService;
|
||||||
|
import lombok.extern.log4j.Log4j2;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.boot.ApplicationArguments;
|
||||||
|
import org.springframework.boot.ApplicationRunner;
|
||||||
|
import org.springframework.boot.autoconfigure.SpringBootApplication;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 引擎初始化加载 RuleEngineClientRunner
|
||||||
|
*
|
||||||
|
* @author DeKangLiu
|
||||||
|
* Date 2024/5/10 19:07
|
||||||
|
*/
|
||||||
|
@Log4j2
|
||||||
|
public class RuleEngineClientRunner implements ApplicationRunner {
|
||||||
|
@Autowired
|
||||||
|
private RemoteRuleEngineManagerService remoteRuleEngineManagerService;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void run(ApplicationArguments args) throws Exception {
|
||||||
|
Result<List<Ruleengine>> listResult = remoteRuleEngineManagerService.ruleEngineList(new RuleengineQueryReq());
|
||||||
|
log.info("初始化加载规则引擎列表:{}", listResult);
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1 @@
|
||||||
|
com.muyu.ruleenign.client.config.RuleEngineClientConfig
|
|
@ -16,5 +16,16 @@
|
||||||
<maven.compiler.target>17</maven.compiler.target>
|
<maven.compiler.target>17</maven.compiler.target>
|
||||||
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
||||||
</properties>
|
</properties>
|
||||||
|
<dependencies>
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.muyu</groupId>
|
||||||
|
<artifactId>muyu-common-core</artifactId>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.muyu</groupId>
|
||||||
|
<artifactId>muyu-ruleengine-common</artifactId>
|
||||||
|
<version>3.6.3</version>
|
||||||
|
</dependency>
|
||||||
|
</dependencies>
|
||||||
|
|
||||||
</project>
|
</project>
|
||||||
|
|
|
@ -0,0 +1,29 @@
|
||||||
|
package com.muyu.ruleengine.remote;
|
||||||
|
|
||||||
|
import com.muyu.common.core.constant.ServiceNameConstants;
|
||||||
|
import com.muyu.common.core.domain.Result;
|
||||||
|
import com.muyu.ruleengine.domain.Ruleengine;
|
||||||
|
import com.muyu.ruleengine.domain.req.RuleengineQueryReq;
|
||||||
|
import com.muyu.ruleengine.remote.factory.RuleEngineManagerFactory;
|
||||||
|
import org.springframework.cloud.openfeign.FeignClient;
|
||||||
|
import org.springframework.web.bind.annotation.PostMapping;
|
||||||
|
import org.springframework.web.bind.annotation.RequestBody;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 初始化加载 RemoteRuleEngineManagerService
|
||||||
|
*
|
||||||
|
* @author DeKangLiu
|
||||||
|
* Date 2024/5/10 18:55
|
||||||
|
*/
|
||||||
|
@FeignClient(
|
||||||
|
contextId = "RemoteRuleEngineManagerService",
|
||||||
|
value = ServiceNameConstants.RULE_ENGINE_SERVICE,
|
||||||
|
fallbackFactory = RuleEngineManagerFactory.class,
|
||||||
|
path = "/ruleengine"
|
||||||
|
)
|
||||||
|
public interface RemoteRuleEngineManagerService {
|
||||||
|
@PostMapping("/ruleEngineList")
|
||||||
|
public Result<List<Ruleengine>> ruleEngineList(@RequestBody RuleengineQueryReq ruleengineQueryReq);
|
||||||
|
}
|
|
@ -0,0 +1,28 @@
|
||||||
|
package com.muyu.ruleengine.remote.factory;
|
||||||
|
|
||||||
|
import com.muyu.common.core.domain.Result;
|
||||||
|
import com.muyu.ruleengine.domain.Ruleengine;
|
||||||
|
import com.muyu.ruleengine.domain.req.RuleengineQueryReq;
|
||||||
|
import com.muyu.ruleengine.remote.RemoteRuleEngineManagerService;
|
||||||
|
import org.springframework.cloud.openfeign.FallbackFactory;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 熔断 RuleEngineManagerFactory
|
||||||
|
*
|
||||||
|
* @author DeKangLiu
|
||||||
|
* Date 2024/5/10 18:55
|
||||||
|
*/
|
||||||
|
public class RuleEngineManagerFactory implements FallbackFactory<RemoteRuleEngineManagerService> {
|
||||||
|
@Override
|
||||||
|
public RemoteRuleEngineManagerService create(Throwable cause) {
|
||||||
|
return new RemoteRuleEngineManagerService() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Result<List<Ruleengine>> ruleEngineList(RuleengineQueryReq ruleengineQueryReq) {
|
||||||
|
return Result.error(cause.getMessage());
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1 @@
|
||||||
|
com.muyu.ruleengine.remote.factory.RuleEngineManagerFactory
|
|
@ -67,6 +67,11 @@ public class RuleengineController extends BaseController {
|
||||||
return getDataTable(list);
|
return getDataTable(list);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@PostMapping("/ruleEngineList")
|
||||||
|
public Result<List<Ruleengine>> ruleEngineList(@RequestBody RuleengineQueryReq ruleengineQueryReq) {
|
||||||
|
List<Ruleengine> list = ruleengineService.list(Ruleengine.queryBuild(ruleengineQueryReq));
|
||||||
|
return Result.success(list);
|
||||||
|
}
|
||||||
/**
|
/**
|
||||||
* 导出规则引擎列表
|
* 导出规则引擎列表
|
||||||
*/
|
*/
|
||||||
|
|
Loading…
Reference in New Issue