feat: 初始化连接池

master
baize 2024-05-12 22:36:39 +08:00
parent a0cf7e7c3a
commit b71163984e
16 changed files with 167 additions and 3 deletions

View File

@ -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";
} }

View File

@ -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);
}
} }
} }

View File

@ -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);

View File

@ -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())

View File

@ -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;
/** /**
* *
*/ */

View File

@ -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);

View File

@ -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"/>

View File

@ -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>

View File

@ -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 {
}

View File

@ -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);
}
}

View File

@ -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>

View File

@ -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);
}

View File

@ -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());
}
};
}
}

View File

@ -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);
}
/** /**
* *
*/ */