Compare commits

...

32 Commits

Author SHA1 Message Date
Number7 82ec79ccaf fix():修改报文基础类型方法 2024-09-30 15:47:20 +08:00
Number7 551f5f5496 Merge remote-tracking branch 'refs/remotes/origin/dev.template' into dev
# Conflicts:
#	cloud-modules/saas/saas-server/src/main/java/com/muyu/server/service/impl/TemplateServiceImpl.java
2024-09-30 15:28:30 +08:00
袁子龙 f93af8b4a6 Merge remote-tracking branch 'origin/dev.business' into dev
# Conflicts:
#	cloud-modules/saas/saas-common/src/main/java/com/muyu/common/domain/CarType.java
#	cloud-modules/saas/saas-common/src/main/java/com/muyu/common/domain/DataType.java
#	cloud-modules/saas/saas-common/src/main/java/com/muyu/common/domain/MessageTemplate.java
#	cloud-modules/saas/saas-common/src/main/java/com/muyu/common/domain/MessageTemplateType.java
#	cloud-modules/saas/saas-common/src/main/java/com/muyu/common/domain/SysCar.java
#	cloud-modules/saas/saas-common/src/main/java/com/muyu/common/domain/SysCarLog.java
#	cloud-modules/saas/saas-common/src/main/java/com/muyu/common/domain/Template.java
#	cloud-modules/saas/saas-server/src/main/java/com/muyu/server/config/MqttConfigure.java
#	cloud-modules/saas/saas-server/src/main/java/com/muyu/server/service/impl/SysCarServiceImpl.java
2024-09-30 11:00:49 +08:00
袁子龙 1272d0e0b7 refactor:修改注释 2024-09-30 10:59:09 +08:00
Number7 1f072d4ca2 fix():修改报文接口字段问题 2024-09-30 10:29:58 +08:00
SuiXxx 8de7f88912 Merge remote-tracking branch 'origin/dev.vehiclegateway' into dev 2024-09-30 09:29:07 +08:00
SuiXxx ddf4ede829 feat():查询ESC信息 2024-09-30 09:28:12 +08:00
86191 83ab8a27a7 feat():围栏和故障的缓存 2024-09-30 09:26:07 +08:00
86191 d38d77b331 Merge branch 'dev' of https://gitea.qinmian.online/group-four/cloud-car into dev 2024-09-30 09:25:55 +08:00
86191 bc3053d834 feat():围栏和故障的缓存 2024-09-30 09:25:37 +08:00
86191 4ecdbe3881 feat():围栏和故障的缓存 2024-09-30 09:24:09 +08:00
86191 d586c26468 Merge branch 'master' of https://gitea.qinmian.online/group-four/cloud-car
# Conflicts:
#	cloud-common/pom.xml
2024-09-30 09:23:34 +08:00
86191 7b36e4b359 feat():围栏和故障的缓存 2024-09-30 09:22:46 +08:00
袁子龙 29cb1ffadb refactor:修改注释 2024-09-29 22:03:51 +08:00
袁子龙 2488248967 refactor:修改注释 2024-09-29 16:12:34 +08:00
袁子龙 dea0f07c90 refactor:修改注释 2024-09-29 16:03:17 +08:00
SuiXxx 7d7950e925 Merge branch 'dev' of https://gitea.qinmian.online/group-four/cloud-car into dev 2024-09-29 16:03:03 +08:00
SuiXxx e3f65e7f1e Merge remote-tracking branch 'origin/dev.vehiclegateway' into dev 2024-09-29 16:01:31 +08:00
SuiXxx f4faf4d828 feat():开启关闭ESC 2024-09-29 15:38:08 +08:00
SuiXxx a0994c3e7a feat():开启关闭ESC 2024-09-29 15:36:30 +08:00
Number7 0228051467 Merge remote-tracking branch 'refs/remotes/origin/dev.template' into dev 2024-09-29 15:12:21 +08:00
袁子龙 688154709d refactor:修改注释 2024-09-29 14:51:02 +08:00
刘武 c35dea9159 Merge branch 'dev' of https://gitea.qinmian.online/group-four/cloud-car into dev 2024-09-29 12:29:08 +08:00
袁子龙 3f9a930c95 refactor:修改yml的nacos命名空间 2024-09-29 12:28:21 +08:00
袁子龙 030f16e6a8 refactor:添加注释和swagger 2024-09-29 12:25:16 +08:00
刘武 3aab1823a1 fix(): 依赖修改 2024-09-29 11:42:32 +08:00
刘武 6079949a7a feat(): 事件处理模块优化 2024-09-29 11:31:24 +08:00
刘武 cd0d2e4475 Merge remote-tracking branch 'origin/dev'
# Conflicts:
#	cloud-modules/cloud-modules-wechat/pom.xml
2024-09-29 11:29:55 +08:00
袁子龙 e716ad9bfc test:测试 2024-09-29 11:18:52 +08:00
袁子龙 71083dc580 fix: swagger上级服务依赖错误 2024-09-29 11:00:41 +08:00
袁子龙 52453e089b refactor:重构 2024-09-29 10:32:28 +08:00
Number7 9747b41b34 kafka 2024-09-29 10:31:32 +08:00
176 changed files with 1779 additions and 1297 deletions

View File

@ -0,0 +1,24 @@
package com.muyu.auth.form;
import lombok.Data;
/**
*
* @author
* @package com.muyu.auth.form
* @name Enterprise
* @date 2024/9/30 10:30
*/
@Data
public class Enterprise {
/**
*
*/
private String firmName;
/**
*
*/
private String databaseName;
}

View File

@ -7,7 +7,7 @@ nacos:
addr: 47.101.53.251:8848
user-name: nacos
password: nacos
namespace: four
namespace: yzl
# Spring
spring:
application:

View File

@ -0,0 +1,28 @@
<?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">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.muyu</groupId>
<artifactId>cloud-common</artifactId>
<version>3.6.3</version>
</parent>
<groupId>com.muyu.cache</groupId>
<artifactId>cloud-common-cache</artifactId>
<properties>
<maven.compiler.source>17</maven.compiler.source>
<maven.compiler.target>17</maven.compiler.target>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<dependency>
<groupId>com.muyu</groupId>
<artifactId>cloud-common-redis</artifactId>
</dependency>
</dependencies>
</project>

View File

@ -0,0 +1,38 @@
package com.muyu.cache;/**
* @author yuping
* @package com.muyu.cache
* @name CacheAbsBasic
* @date 2024/9/29 20:10
*/
import com.muyu.common.redis.service.RedisService;
import org.springframework.beans.factory.annotation.Autowired;
import static cn.hutool.core.lang.ansi.AnsiEncoder.encode;
/**
* @Author YuPing
* @Description
* @Version 1.0
* @Data 2024-09-29 20:10:09
*/
public abstract class CacheAbsBasic<K,V> implements CacheBasic<K,V>{
@Autowired
private RedisService redisService; // spring redis 工具类
@Override
public void put(K key, V value) {
redisService.setCacheObject(encodeKey(key), value); // 编码 --> 缓存基础的对象 Integer String 实体类等
}
@Override
public V get(K key) {
return redisService.getCacheObject(encode(key)); // 获取缓存的基本对象 编码
}
@Override
public void remove(K key) {
redisService.deleteObject(encode(key));
}
}

View File

@ -0,0 +1,16 @@
package com.muyu.cache;
/**
* @author yuping
* @package com.muyu.cache
* @name CacheBasic
* @date 2024/9/29 20:08
*/
public interface CacheBasic <K,V> extends PrimaryKeyBasic<K>{
void put(K key, V value);
V get(K key);
void remove(K key);
}

View File

@ -0,0 +1,34 @@
package com.muyu.cache;
/**
* @author yuping
* @package com.muyu.cache
* @name PrimaryKeyBasic
* @date 2024/9/29 20:03
*/
public interface PrimaryKeyBasic <K> {
/**
* key
* @return key
*/
public String keyPre();
/**
* key
* @param key
* @return
*/
public default String encodeKey(K key) {
return keyPre() + key.toString(); //key 前缀
}
/**
* key
* @param key key
* @return key
*/
public K decode(String key);
}

View File

@ -138,10 +138,10 @@
</dependency>
<!-- Java Specification Requests 标准库-->
<!-- <dependency>-->
<!-- <groupId>javax.annotation</groupId>-->
<!-- <artifactId>jsr250-api</artifactId>-->
<!-- </dependency>-->
<!-- <dependency>-->
<!-- <groupId>javax.annotation</groupId>-->
<!-- <artifactId>jsr250-api</artifactId>-->
<!-- </dependency>-->
<dependency>
<groupId>javax.annotation</groupId>

View File

@ -5,21 +5,21 @@
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.muyu</groupId>
<artifactId>cloud-server</artifactId>
<artifactId>cloud-common</artifactId>
<version>3.6.3</version>
<relativePath>../../pom.xml</relativePath>
</parent>
<groupId>com.muyu</groupId>
<groupId>com.bwie</groupId>
<artifactId>cloud-common-swagger</artifactId>
<description>
cloud-common-swagger swagger2文档聚合
cloud-common-swagger系统接口
</description>
<properties>
<maven.compiler.source>17</maven.compiler.source>
<maven.compiler.target>17</maven.compiler.target>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<!-- SpringBoot Web -->
<dependency>

View File

@ -1,10 +1,21 @@
package com.muyu.common.swagger.annotation;
import com.muyu.common.swagger.config.SwaggerAutoConfiguration;
import org.springframework.context.annotation.Import;
import java.lang.annotation.*;
/**
* @author
* @packagecom.muyu.common.swagger.annotation
* @nameEnableCustomSwagger2
* @date2024/9/29 10:01
*/
@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Inherited
@Import({SwaggerAutoConfiguration.class})
public @interface EnableCustomSwagger2 {
}

View File

@ -22,9 +22,9 @@ import java.util.function.Predicate;
/**
* @author
* @packagecom.muyu.common.swagger.config
* @nameSwaggerAutoConfiguration
* @date2024/9/29 10:07
* @package com.muyu.common.swagger.config
* @name SwaggerAutoConfiguration
* @date 2024/9/29 10:07
*/
@Configuration
@EnableSwagger2

View File

@ -12,6 +12,7 @@ import java.util.List;
import java.util.stream.Collectors;
/**
* springboot 2.6.x
* @author
* @packagecom.muyu.common.swagger.config
* @nameSwaggerBeanPostProcessor

View File

@ -300,4 +300,3 @@ public class SwaggerProperties {
}
}
}

View File

@ -22,6 +22,7 @@
<module>cloud-common-rabbit</module>
<module>cloud-common-saas</module>
<module>cloud-common-swagger</module>
<module>cloud-common-cache</module>
</modules>
<artifactId>cloud-common</artifactId>

View File

@ -7,7 +7,7 @@ nacos:
addr: 47.101.53.251:8848
user-name: nacos
password: nacos
namespace: four
namespace: yzl
# Spring
spring:

View File

@ -6,7 +6,7 @@ nacos:
addr: 47.101.53.251:8848
user-name: nacos
password: nacos
namespace: four
namespace: yzl
# SPRING_AMQP_DESERIALIZATION_TRUST_ALL=true spring.amqp.deserialization.trust.all
# Spring
amqp:

View File

@ -7,7 +7,7 @@ nacos:
addr: 47.101.53.251:8848
user-name: nacos
password: nacos
namespace: four
namespace: yzl
# Spring
spring:

View File

@ -9,7 +9,7 @@ import org.springframework.stereotype.Service;
import java.util.List;
/**
*
*
*
* @author ruoyi
*/

View File

@ -40,7 +40,7 @@ import java.util.zip.ZipEntry;
import java.util.zip.ZipOutputStream;
/**
*
*
*
* @author ruoyi
*/

View File

@ -7,7 +7,7 @@ nacos:
addr: 47.101.53.251:8848
user-name: nacos
password: nacos
namespace: four
namespace: yzl
# SPRING_AMQP_DESERIALIZATION_TRUST_ALL=true spring.amqp.deserialization.trust.all
# Spring
spring:

View File

@ -7,7 +7,7 @@ import com.muyu.system.domain.vo.TreeSelect;
import java.util.List;
/**
*
*
*
* @author muyu
*/

View File

@ -7,7 +7,7 @@ nacos:
addr: 47.101.53.251:8848
user-name: nacos
password: nacos
namespace: four
namespace: yzl
# SPRING_AMQP_DESERIALIZATION_TRUST_ALL=true spring.amqp.deserialization.trust.all
# Spring
spring:

View File

@ -102,6 +102,36 @@
<artifactId>org.eclipse.paho.client.mqttv3</artifactId>
<version>1.2.5</version>
</dependency>
<dependency>
<groupId>com.aliyun</groupId>
<artifactId>ecs20140526</artifactId>
<version>5.1.8</version>
</dependency>
<dependency>
<groupId>com.aliyun</groupId>
<artifactId>tea-openapi</artifactId>
<version>0.3.2</version>
</dependency>
<dependency>
<groupId>com.aliyun</groupId>
<artifactId>tea-console</artifactId>
<version>0.0.1</version>
</dependency>
<dependency>
<groupId>com.aliyun</groupId>
<artifactId>tea-util</artifactId>
<version>0.2.21</version>
</dependency>
<dependency>
<groupId>com.aliyun</groupId>
<artifactId>aliyun-java-sdk-ecs</artifactId>
<version>4.2.0</version><!-- 请根据实际情况使用最新的版本 -->
</dependency>
</dependencies>
<build>

View File

@ -0,0 +1,173 @@
package com.muyu.vehicle;
import com.aliyun.ecs20140526.Client;
import com.aliyun.ecs20140526.models.*;
import com.aliyun.tea.TeaException;
import com.aliyun.teaopenapi.models.Config;
import com.aliyun.teautil.Common;
import com.aliyun.teautil.models.RuntimeOptions;
import com.muyu.vehicle.domain.InstanceInfo;
import com.muyu.vehicle.service.OpenInstance;
import com.muyu.vehicle.service.SelectInstance;
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.stereotype.Component;
import java.util.ArrayList;
import java.util.List;
@Component
@Log4j2
public class ManageInstance implements ApplicationRunner {
/**
* ACCESS_KEY_ID
*/
public static final String ALIBABA_CLOUD_ACCESS_KEY_ID="LTAI5tGabdxedjfCh2uXHNrw";
/**
*ACCESS_KEY_SECRET
*/
public static final String ACCESS_KEY_SECRET="NHb7wHVpesLW6Axc0bFBs6ThhuNR10";
/**
* ID
*/
public static final String IMAGE_ID="m-uf6agr9i6g27gj23om34";
/**
*
*/
public static final String INSTANCE_TYPE="ecs.e-c1m1.large";
/**
* ID
*/
public static final String SECURITY_GROUP_ID="sg-uf6glo8c4k17szhxu7sk";
/**
*ID
*/
public static final String V_SWITCH_ID="vsw-uf6xy4rbt9ggcz93t6oib";
/**
*
*/
public static final String INSTANCE_CHARGE_TY="PostPaid";
/**
* 使AK&SKClient
* @return Client
* @throws Exception
*/
public static Client createClient() throws Exception {
// 工程代码泄露可能会导致 AccessKey 泄露,并威胁账号下所有资源的安全性。以下代码示例仅供参考。
Config config = new Config()
// 必填,请确保代码运行环境设置了环境变量 ALIBABA_CLOUD_ACCESS_KEY_ID。
.setAccessKeyId(ALIBABA_CLOUD_ACCESS_KEY_ID)
// 必填,请确保代码运行环境设置了环境变量 ALIBABA_CLOUD_ACCESS_KEY_SECRET。
.setAccessKeySecret(ACCESS_KEY_SECRET);
// Endpoint 请参考 https://api.aliyun.com/product/Ecs
config.endpoint = "ecs-cn-hangzhou.aliyuncs.com";
return new com.aliyun.ecs20140526.Client(config);
}
public static void generateInstance() throws Exception {
// 创建阿里云ECS客户端
Client client = ManageInstance.createClient();
// 配置系统盘参数
RunInstancesRequest.RunInstancesRequestSystemDisk systemDisk=
new RunInstancesRequest.RunInstancesRequestSystemDisk()
.setSize("40")
.setCategory("cloud_essd");
// 创建创建实例请求对象并设置参数
RunInstancesRequest runInstancesRequest = new RunInstancesRequest()
.setRegionId("cn-shanghai") // 设置地域ID
.setImageId(IMAGE_ID) // 设置镜像ID
.setInstanceType(INSTANCE_TYPE) // 设置实例类型
.setSecurityGroupId(SECURITY_GROUP_ID) // 设置安全组ID
.setVSwitchId(V_SWITCH_ID) // 设置虚拟交换机ID
.setInstanceName("cloud-MQTT") // 设置实例名称
.setInstanceChargeType(INSTANCE_CHARGE_TY) // 设置实例付费类型为后付费按量付费
.setSystemDisk(systemDisk) // 设置系统盘配置
.setHostName("root") // 设置主机名
.setPassword("2112A-four") // 设置实例密码
.setAmount(2) // 设置创建实例的数量
.setInternetChargeType("PayByTraffic")
.setInternetMaxBandwidthOut(1);
//创建运行时选择对象
RuntimeOptions runTime=
new RuntimeOptions();
// 尝试执行创建实例请求
try {
ArrayList<String> list = new ArrayList<>();
// 复制代码运行请自行打印 API 的返回值
RunInstancesResponse runInstancesResponse = client.runInstancesWithOptions(runInstancesRequest, runTime);
RunInstancesResponseBody body = runInstancesResponse.getBody();
for (String instance : body.getInstanceIdSets().getInstanceIdSet()) {
list.add(instance);
}
log.info("ESC创建成功,实例ID为:" + list);
} catch (TeaException error) {
// 错误 message
log.info(error.getMessage());
// 诊断地址
log.info(error.getData().get("Recommend"));
Common.assertAsString(error.message);
} catch (Exception _error) {
TeaException error = new TeaException(_error.getMessage(), _error);
// 此处仅做打印展示,请谨慎对待异常处理,在工程项目中切勿直接忽略异常。
// 错误 message
log.info("实例创建失败:"+error.getMessage());
}
}
private static List<InstanceInfo> selectInstance() throws Exception {
Client client = ManageInstance.createClient();
ArrayList<InstanceInfo> instanceInfos = new ArrayList<>();// 实例基础信息
DescribeInstancesRequest describeInstancesRequest = new DescribeInstancesRequest()
.setRegionId("cn-shanghai")
.setInternetChargeType("PayByTraffic")
.setInstanceChargeType("PostPaid")
.setInstanceName("cloud-MQTT") // 设置实例名称
;
// 创建运行时选项对象
RuntimeOptions runtime = new RuntimeOptions();
//实例ID Instances.Instance.InstanceId
//实例IP Instances.Instance.PublicIpAddress.IpAddress
//状态 Instances.Instance.Status
DescribeInstancesResponse resp =client.describeInstancesWithOptions(describeInstancesRequest, runtime);
DescribeInstancesResponseBody body = resp.getBody();
for (DescribeInstancesResponseBody.DescribeInstancesResponseBodyInstancesInstance instance : body.getInstances().getInstance()){
InstanceInfo instanceInfo = new InstanceInfo();
instanceInfo.setInstanceId(instance.getInstanceId());
instanceInfo.setIpAddress(String.valueOf(instance.getPublicIpAddress().getIpAddress()));
instanceInfo.setStatus(instance.getStatus());
instanceInfos.add(instanceInfo);
}
log.info("实例信息为:"+Common.toJSONString(instanceInfos));
return instanceInfos;
}
@Override
public void run(ApplicationArguments args) throws Exception {
generateInstance();
selectInstance();
}
}

View File

@ -1,132 +0,0 @@
package com.muyu.vehicle;
import com.alibaba.fastjson.JSONObject;
import com.muyu.web.common.ScheduledThreadPool;
import com.muyu.web.domain.MqttProperties;
import com.muyu.web.domain.VehicleInfo;
import com.muyu.web.domain.model.PositionModel;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.extern.log4j.Log4j2;
import org.eclipse.paho.client.mqttv3.MqttClient;
import org.eclipse.paho.client.mqttv3.MqttConnectOptions;
import org.eclipse.paho.client.mqttv3.MqttException;
import org.eclipse.paho.client.mqttv3.persist.MemoryPersistence;
import java.util.Objects;
import java.util.concurrent.LinkedBlockingQueue;
import java.util.concurrent.ScheduledFuture;
@Data
@Builder
@Log4j2
@NoArgsConstructor
@AllArgsConstructor
public class VehicleInstance {
/**
* 线
*/
private String positionCode;
/**
*
*/
private LinkedBlockingQueue<PositionModel> positionQueue=new LinkedBlockingQueue<>();
/**
*
*/
private VehicleInfo vehicleInfo;
/**
* 线
*/
private VehicleThread vehicleThread;
/**
* MQTT
*/
private MqttProperties mqttProperties;
/**
* 线
*/
private ScheduledFuture<?>scheduledFuture;
/**
*
*/
private MqttClient client;
/**
* VIN
*/
public String getVin(){
return this.vehicleInfo.getVin();
}
/**
*
*/
public String getTenantId(){
return this.vehicleInfo.getTenantId();
}
/**
*
*/
public void sengMsg(String msg){
}
/**
*
*/
public void initClient(){
try {
client = new MqttClient(mqttProperties.getBroker(), mqttProperties.getClientId(), new MemoryPersistence());
MqttConnectOptions options = new MqttConnectOptions();
//设置用户名和密码
if (Objects.nonNull(mqttProperties.getUserName())&&Objects.nonNull(mqttProperties.getPassword())){
options.setUserName(mqttProperties.getUserName());
options.setPassword(mqttProperties.getPassword().toCharArray());
}
options.setConnectionTimeout(1);
options.setKeepAliveInterval(20);
//连接
client.connect(options);
log.debug("车辆:[{}]客户端初始化成功连接配置:{}",getVin(),
JSONObject.toJSONString(this.mqttProperties)
);
VehicleThread vehicleThread = new VehicleThread();
vehicleThread.setVehicleInstance(this);
this.setVehicleThread(vehicleThread);
ScheduledFuture<?> submit = ScheduledThreadPool.submit(vehicleThread);
this.setScheduledFuture(submit);
log.info("初始化车辆上报模拟线程开始:[{}]", this.getVin());
} catch (MqttException e) {
log.error("车辆:[{}] 客户端初始化异常", getVin(), e);
throw new RuntimeException(e);
}
}
/**
* 线
*/
public boolean isOnline(){
if (this.client==null){
return false;
}
return this.client.isConnected();
}
/**
* 线
*/
public boolean isSend(){
return this.vehicleThread!=null;
}
}

View File

@ -1,24 +0,0 @@
package com.muyu.vehicle;
import lombok.Data;
import lombok.extern.log4j.Log4j2;
@Data
@Log4j2
public class VehicleThread implements Runnable{
/**
* 线
*/
private volatile boolean isStop;
/**
*
*/
private VehicleInstance vehicleInstance;
@Override
public void run() {
if (!isStop){
log.info("{}-上报数据",this.vehicleInstance.getVin());
}
}
}

View File

@ -1,12 +0,0 @@
package com.muyu.vehicle.api;
/**
*
*/
public interface ClientAdmin {
/**
*
*/
}

View File

@ -1,24 +0,0 @@
package com.muyu.vehicle.core;
import com.muyu.vehicle.VehicleInstance;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
public class LocalContainer {
private static final Map<String,Map<String, VehicleInstance>> tenantVehicleDataMap
=new ConcurrentHashMap<>();
/**
* ID
*/
public static Map<String,VehicleInstance>getVehicleDataMap(String tenantId){
return tenantVehicleDataMap.computeIfAbsent(tenantId,k->new ConcurrentHashMap<>());
}
/**
*
*/
}

View File

@ -1,13 +0,0 @@
package com.muyu.vehicle.core;
import lombok.AllArgsConstructor;
import lombok.extern.log4j.Log4j2;
import org.springframework.boot.ApplicationArguments;
import org.springframework.boot.ApplicationRunner;
import org.springframework.context.annotation.Configuration;
@Log4j2
@Configuration
@AllArgsConstructor
public class VehicleConfiguration {
}

View File

@ -0,0 +1,18 @@
package com.muyu.vehicle.domain;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
@Data
@AllArgsConstructor
@NoArgsConstructor
public class InstanceInfo {
//实例ID
private String InstanceId;
private String IpAddress;
private String status;
}

View File

@ -0,0 +1,110 @@
package com.muyu.vehicle.service;
import com.aliyun.ecs20140526.Client;
import com.aliyun.ecs20140526.models.DeleteInstancesRequest;
import com.aliyun.ecs20140526.models.DescribeInstancesRequest;
import com.aliyun.ecs20140526.models.DescribeInstancesResponse;
import com.aliyun.ecs20140526.models.DescribeInstancesResponseBody;
import com.aliyun.tea.TeaException;
import com.aliyun.teaopenapi.models.Config;
import com.aliyun.teautil.Common;
import com.aliyun.teautil.models.RuntimeOptions;
import lombok.extern.log4j.Log4j2;
import org.springframework.beans.factory.DisposableBean;
import org.springframework.stereotype.Component;
import java.util.ArrayList;
@Component
@Log4j2
public class CloseInstance implements DisposableBean {
/**
* ACCESS_KEY_ID
*/
public static final String ALIBABA_CLOUD_ACCESS_KEY_ID="LTAI5tGabdxedjfCh2uXHNrw";
/**
*ACCESS_KEY_SECRET
*/
public static final String ACCESS_KEY_SECRET="NHb7wHVpesLW6Axc0bFBs6ThhuNR10";
public static Client createClient() throws Exception {
// 工程代码泄露可能会导致 AccessKey 泄露,并威胁账号下所有资源的安全性。以下代码示例仅供参考。
// 建议使用更安全的 STS 方式更多鉴权访问方式请参见https://help.aliyun.com/document_detail/378657.html。
Config config = new Config()
// 必填,请确保代码运行环境设置了环境变量 ALIBABA_CLOUD_ACCESS_KEY_ID。
.setAccessKeyId(ALIBABA_CLOUD_ACCESS_KEY_ID)
// 必填,请确保代码运行环境设置了环境变量 ALIBABA_CLOUD_ACCESS_KEY_SECRET。
.setAccessKeySecret(ACCESS_KEY_SECRET);
// Endpoint 请参考 https://api.aliyun.com/product/Ecs
config.endpoint = "ecs.cn-shanghai.aliyuncs.com";
return new Client(config);
}
public static void delInstance() throws Exception {
// 创建ECS客户端对象用于后续调用ECS相关API
Client client = CloseInstance.createClient();
DescribeInstancesRequest describeInstancesRequest = new DescribeInstancesRequest()
.setRegionId("cn-shanghai");
//创建运行时选择对象,用于配置运行时的选项参数
RuntimeOptions runtimeOptions = new RuntimeOptions();
//获取实例列表
DescribeInstancesResponse describeInstancesResponse = client.describeInstancesWithOptions(describeInstancesRequest, runtimeOptions);
//提取实例ID集合
ArrayList<String> list = new ArrayList<>();
DescribeInstancesResponseBody body = describeInstancesResponse.getBody();
for (DescribeInstancesResponseBody.DescribeInstancesResponseBodyInstancesInstance instance : body.getInstances().getInstance()) {
if (!instance.getInstanceId().equals("i-uf68jwsbbqq4b4xc893s")){
list.add(instance.getInstanceId());
}
}
log.info("搜索到实例Instance IDs: " + list);
// 创建删除实例请求对象,并设置请求参数
DeleteInstancesRequest deleteInstancesRequest = new DeleteInstancesRequest()
// 设置地域ID指定删除实例的地域
.setRegionId("cn-shanghai")
// 设置DryRun为true用于验证请求是否可以成功但不实际执行删除操作
.setDryRun(false)
// 设置Force为true表示即使实例有正在运行的任务也强制删除实例
.setForce(true)
// 设置TerminateSubscription为true表示删除按订阅付费的实例时终止订阅
.setTerminateSubscription(true)
.setInstanceId(list);
// 创建运行时选项对象,用于配置运行时的选项参数
RuntimeOptions runtime = new RuntimeOptions();
try {
// 复制代码运行请自行打印 API 的返回值
client.deleteInstancesWithOptions(deleteInstancesRequest, runtime);
} catch (TeaException error) {
// 此处仅做打印展示,请谨慎对待异常处理,在工程项目中切勿直接忽略异常。
// 错误 message
log.info(error.getMessage());
// 诊断地址
log.info(error.getData().get("Recommend"));
Common.assertAsString(error.message);
} catch (Exception _error) {
TeaException error = new TeaException(_error.getMessage(), _error);
// 此处仅做打印展示,请谨慎对待异常处理,在工程项目中切勿直接忽略异常。
// 错误 message
System.out.println(error.getMessage());
// 诊断地址
log.info(error.getData().get("Recommend"));
Common.assertAsString(error.message);
}
}
@Override
public void destroy() throws Exception {
log.info("开始删除实例");
delInstance();
}
}

View File

@ -0,0 +1,129 @@
package com.muyu.vehicle.service;
import com.aliyun.ecs20140526.Client;
import com.aliyun.ecs20140526.models.RunInstancesRequest;
import com.aliyun.ecs20140526.models.RunInstancesResponse;
import com.aliyun.ecs20140526.models.RunInstancesResponseBody;
import com.aliyun.tea.TeaException;
import com.aliyun.teaopenapi.models.Config;
import com.aliyun.teautil.Common;
import com.aliyun.teautil.models.RuntimeOptions;
import com.muyu.vehicle.ManageInstance;
import lombok.extern.log4j.Log4j2;
import java.util.ArrayList;
@Log4j2
public class OpenInstance {
/**
* ACCESS_KEY_ID
*/
public static final String ALIBABA_CLOUD_ACCESS_KEY_ID="LTAI5tGabdxedjfCh2uXHNrw";
/**
*ACCESS_KEY_SECRET
*/
public static final String ACCESS_KEY_SECRET="NHb7wHVpesLW6Axc0bFBs6ThhuNR10";
/**
* ID
*/
public static final String IMAGE_ID="m-uf6agr9i6g27gj23om34";
/**
*
*/
public static final String INSTANCE_TYPE="ecs.e-c1m1.large";
/**
* ID
*/
public static final String SECURITY_GROUP_ID="sg-uf6glo8c4k17szhxu7sk";
/**
*ID
*/
public static final String V_SWITCH_ID="vsw-uf6xy4rbt9ggcz93t6oib";
/**
*
*/
public static final String INSTANCE_CHARGE_TY="PostPaid";
/**
* 使AK&SKClient
* @return Client
* @throws Exception
*/
public static Client createClient() throws Exception {
// 工程代码泄露可能会导致 AccessKey 泄露,并威胁账号下所有资源的安全性。以下代码示例仅供参考。
Config config = new Config()
// 必填,请确保代码运行环境设置了环境变量 ALIBABA_CLOUD_ACCESS_KEY_ID。
.setAccessKeyId(ALIBABA_CLOUD_ACCESS_KEY_ID)
// 必填,请确保代码运行环境设置了环境变量 ALIBABA_CLOUD_ACCESS_KEY_SECRET。
.setAccessKeySecret(ACCESS_KEY_SECRET);
// Endpoint 请参考 https://api.aliyun.com/product/Ecs
config.endpoint = "ecs-cn-hangzhou.aliyuncs.com";
return new com.aliyun.ecs20140526.Client(config);
}
public static void generateInstance() throws Exception {
// 创建阿里云ECS客户端
Client client = OpenInstance.createClient();
// 配置系统盘参数
RunInstancesRequest.RunInstancesRequestSystemDisk systemDisk=
new RunInstancesRequest.RunInstancesRequestSystemDisk()
.setSize("40")
.setCategory("cloud_essd");
// 创建创建实例请求对象并设置参数
RunInstancesRequest runInstancesRequest = new RunInstancesRequest()
.setRegionId("cn-shanghai") // 设置地域ID
.setImageId(IMAGE_ID) // 设置镜像ID
.setInstanceType(INSTANCE_TYPE) // 设置实例类型
.setSecurityGroupId(SECURITY_GROUP_ID) // 设置安全组ID
.setVSwitchId(V_SWITCH_ID) // 设置虚拟交换机ID
.setInstanceName("cloud-MQTT") // 设置实例名称
.setInstanceChargeType(INSTANCE_CHARGE_TY) // 设置实例付费类型为后付费按量付费
.setSystemDisk(systemDisk) // 设置系统盘配置
.setHostName("root") // 设置主机名
.setPassword("2112A-four") // 设置实例密码
.setAmount(2) // 设置创建实例的数量
.setInternetChargeType("PayByTraffic")
.setInternetMaxBandwidthOut(1);
//创建运行时选择对象
RuntimeOptions runTime=
new RuntimeOptions();
// 尝试执行创建实例请求
try {
ArrayList<String> list = new ArrayList<>();
// 复制代码运行请自行打印 API 的返回值
RunInstancesResponse runInstancesResponse = client.runInstancesWithOptions(runInstancesRequest, runTime);
RunInstancesResponseBody body = runInstancesResponse.getBody();
for (String instance : body.getInstanceIdSets().getInstanceIdSet()) {
list.add(instance);
log.info("ESC创建成功,实例ID为:" + list);
}
} catch (TeaException error) {
// 错误 message
log.info(error.getMessage());
// 诊断地址
log.info(error.getData().get("Recommend"));
Common.assertAsString(error.message);
} catch (Exception _error) {
TeaException error = new TeaException(_error.getMessage(), _error);
// 此处仅做打印展示,请谨慎对待异常处理,在工程项目中切勿直接忽略异常。
// 错误 message
log.info("实例创建失败:"+error.getMessage());
}
}
}

View File

@ -0,0 +1,66 @@
package com.muyu.vehicle.service;
import com.aliyun.ecs20140526.Client;
import com.aliyun.ecs20140526.models.DescribeInstancesRequest;
import com.aliyun.ecs20140526.models.DescribeInstancesResponse;
import com.aliyun.ecs20140526.models.DescribeInstancesResponseBody;
import com.aliyun.teaopenapi.models.Config;
import com.aliyun.teautil.Common;
import com.aliyun.teautil.models.RuntimeOptions;
import com.muyu.vehicle.domain.InstanceInfo;
import lombok.extern.log4j.Log4j2;
import java.util.ArrayList;
@Log4j2
public class SelectInstance {
/**
* ACCESS_KEY_ID
*/
public static final String ALIBABA_CLOUD_ACCESS_KEY_ID="LTAI5tGabdxedjfCh2uXHNrw";
/**
*ACCESS_KEY_SECRET
*/
public static final String ACCESS_KEY_SECRET="NHb7wHVpesLW6Axc0bFBs6ThhuNR10";
public static Client createClient(String accessKeyId, String accessKeySecret) throws Exception {
Config config = new com.aliyun.teaopenapi.models.Config()
// 必填,您的 AccessKey ID
.setAccessKeyId(ALIBABA_CLOUD_ACCESS_KEY_ID)
// 必填,您的 AccessKey Secret
.setAccessKeySecret(ACCESS_KEY_SECRET);
// 访问的域名
config.endpoint = "ecs-cn-hangzhou.aliyuncs.com";
return new Client(config);
}
public static void main(String[] args_) throws Exception {
java.util.List<String> args = java.util.Arrays.asList(args_);
// 请确保代码运行环境设置了环境变量 ALIBABA_CLOUD_ACCESS_KEY_ID 和 ALIBABA_CLOUD_ACCESS_KEY_SECRET。
// 工程代码泄露可能会导致 AccessKey 泄露,并威胁账号下所有资源的安全性。以下代码示例仅供参考,建议使用更安全的 STS 方式
Client client = SelectInstance.createClient(ALIBABA_CLOUD_ACCESS_KEY_ID, ACCESS_KEY_SECRET);
DescribeInstancesRequest describeInstancesRequest = new DescribeInstancesRequest()
.setRegionId("cn-shanghai")
.setInternetChargeType("PayByTraffic")
.setInstanceChargeType("PostPaid")
.setInstanceName("cloud-MQTT") // 设置实例名称
;
//实例ID Instances.Instance.InstanceId
//实例IP Instances.Instance.PublicIpAddress.IpAddress
//状态 Instances.Instance.Status
RuntimeOptions runtime = new RuntimeOptions();
DescribeInstancesResponse resp = client.describeInstancesWithOptions(describeInstancesRequest, runtime);
DescribeInstancesResponseBody body = resp.getBody();
ArrayList<InstanceInfo> instanceInfos = new ArrayList<>();// 实例基础信息
for (DescribeInstancesResponseBody.DescribeInstancesResponseBodyInstancesInstance instance : body.getInstances().getInstance()){
InstanceInfo instanceInfo = new InstanceInfo();
instanceInfo.setInstanceId(instance.getInstanceId());
instanceInfo.setIpAddress(String.valueOf(instance.getPublicIpAddress().getIpAddress()));
instanceInfo.setStatus(instance.getStatus());
instanceInfos.add(instanceInfo);
}
log.info(Common.toJSONString(instanceInfos));
}
}

View File

@ -1,33 +0,0 @@
package com.muyu.web.common;
import net.sf.jsqlparser.statement.select.KSQLWindow;
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.ScheduledFuture;
import java.util.concurrent.TimeUnit;
public class ScheduledThreadPool {
/**
* 线 CPU*2+1
*/
private static final ScheduledExecutorService scheduledThreadPool= Executors.newScheduledThreadPool(
Runtime.getRuntime().availableProcessors()*2+1
);
public static ScheduledFuture<?>submit(Runnable thread){
// 参数分别是: 任务, 多久后开始执行, 每隔多久执行一次(周期),时间单位
return submit(thread, 1);
}
public static ScheduledFuture<?>submit(Runnable thread,long period){
return scheduledThreadPool.scheduleAtFixedRate(thread,0,period, TimeUnit.SECONDS);
}
/**
* 线
*/
public static void shutdown(){
scheduledThreadPool.shutdown();
}
}

View File

@ -1,40 +0,0 @@
package com.muyu.web.controller;
import com.muyu.common.core.utils.uuid.UUID;
import org.eclipse.paho.client.mqttv3.*;
public class testController {
public static void main(String[] args) {
String broker = "tcp://47.101.53.251:1883";
String clientId = "SX-"+ UUID.randomUUID().toString();
MqttClient client;
try {
client = new MqttClient(broker, clientId);
MqttConnectOptions connectOptions = new MqttConnectOptions();
connectOptions.setCleanSession(true);
System.out.println("Connect to broker:"+broker);
client.connect(connectOptions);
System.out.println("Connected");
client.setCallback(new MqttCallback() {
@Override
public void connectionLost(Throwable throwable) {
System.out.println("连接丢失");
}
@Override
public void messageArrived(String topic, MqttMessage mqttMessage) throws Exception {
System.out.println("消息到达:"+new String(mqttMessage.getPayload())+topic);
}
@Override
public void deliveryComplete(IMqttDeliveryToken iMqttDeliveryToken) {
}
});
} catch (MqttException e) {
throw new RuntimeException(e);
}
}
}

View File

@ -1,42 +0,0 @@
package com.muyu.web.domain;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
/**
* mqtt
*/
@Data
@AllArgsConstructor
@NoArgsConstructor
public class MqttProperties {
/**
*
*/
private String broker;
/**
*
*/
private String topic;
/**
*
*/
private String userName;
/**
*
*/
private String password;
/**
* ID
*/
private String clientId;
/**
*
*/
private int qos=0;
}

View File

@ -1,76 +0,0 @@
package com.muyu.web.domain;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import com.muyu.web.domain.model.ServerConfigModel;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.util.function.Supplier;
/**
*
*/
@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
@TableName(value = "server_config")
public class ServerConfig {
/**
*
*/
@TableId(value = "id",type = IdType.AUTO)
private Long id;
/**
*
*/
private String host;
/**
*
*/
private String port;
/**
*
*/
private String url;
/**
* MOTT
*/
private String defaultMqttAddr;
/**
* MQTT
*/
private String defaultMqttTopic;
/**
* MOTT
*/
private Integer defaultMqttQos;
public static ServerConfig modeBuild(ServerConfigModel serverConfigModel, Supplier<Long> idKey){
return builder()
.id(idKey.get())
.host(serverConfigModel.getHost())
.port(serverConfigModel.getPort())
.url(serverConfigModel.getUrl())
.defaultMqttAddr(serverConfigModel.getDefaultMqttAddr())
.defaultMqttTopic(serverConfigModel.getDefaultMqttTopic())
.defaultMqttQos(serverConfigModel.getDefaultMqttQos())
.build();
}
}

View File

@ -1,92 +0,0 @@
package com.muyu.web.domain;
import com.baomidou.mybatisplus.annotation.*;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.math.BigDecimal;
import java.util.Date;
import java.util.function.Supplier;
@Data
@NoArgsConstructor
@AllArgsConstructor
@Builder
@TableName("vehicle_info")
public class VehicleInfo {
/**
*
*/
@TableId(
value = "id",
type = IdType.AUTO
)
private Long id;
/**
* VIN
*/
private String vin;
/**
* VIN
*/
@TableField(value = "tenant_id", fill = FieldFill.INSERT)
private String tenantId;
/**
*
*/
@TableField("message_template_id")
private Long messageTemplateId;
/**
*
*/
@TableField("remaining_battery")
private BigDecimal remainingBattery;
/**
*
*/
@TableField("battery_level")
private BigDecimal batteryLevel;
/**
*
*/
@TableField("last_longitude")
private String lastLongitude;
/**
*
*/
@TableField("last_latitude")
private String lastLatitude;
/**
*
*/
@TableField("total_mileage")
private BigDecimal totalMileage;
/**
*
*/
@TableField(value = "create_time", fill = FieldFill.INSERT)
private Date createTime;
public static VehicleInfo create(String vin, Supplier<Long>messageTemplateId){
return VehicleInfo.builder()
.vin(vin)
.messageTemplateId(messageTemplateId.get())
.createTime(new Date())
.totalMileage(BigDecimal.ZERO)
.build();
}
}

View File

@ -1,37 +0,0 @@
package com.muyu.web.domain.model;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
Mqtt
*/
@Data
@NoArgsConstructor
@AllArgsConstructor
public class MqttServerModel {
private static final Logger log=LoggerFactory.getLogger(MqttServerModel.class);
/**
* MQTT
*/
private String broker;
/**
* MQTT
*/
private String topic;
public String getBroker(){
log.info("broker:{}",broker);
return broker.contains("tcp://")?broker:"tcp://"+broker+":1883";
}
}

View File

@ -1,33 +0,0 @@
package com.muyu.web.domain.model;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
/**
* @description:
*/
@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class PositionModel {
/**
*
*/
private String longitude;
/**
*
*/
private String latitude;
public static PositionModel strBuild (String positionStr) {
String[] split = positionStr.split(",");
return PositionModel.builder()
.longitude(split[0])
.latitude(split[1])
.build();
}
}

View File

@ -1,53 +0,0 @@
package com.muyu.web.domain.model;
import com.muyu.web.domain.ServerConfig;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
public class ServerConfigModel {
/**
*
*/
private String host;
/**
*
*/
private String port;
/**
*
*/
private String url;
/**
* MOTT
*/
private String defaultMqttAddr;
/**
* MQTT
*/
private String defaultMqttTopic;
/**
* MOTT
*/
private Integer defaultMqttQos;
public static ServerConfigModel serverConfigModelBuild(ServerConfig serverConfig){
return builder()
.host(serverConfig.getHost().trim())
.port(serverConfig.getPort())
.url(serverConfig.getUrl().trim())
.defaultMqttAddr(serverConfig.getDefaultMqttAddr().trim())
.defaultMqttTopic(serverConfig.getDefaultMqttTopic().trim())
.defaultMqttQos(serverConfig.getDefaultMqttQos())
.build();
}
}

View File

@ -1,34 +0,0 @@
package com.muyu.web.domain.req;
import com.alibaba.fastjson.annotation.JSONField;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class VehicleConnectionReq {
@JSONField(name = "vin")
private String vin;
/**
*
*/
private String timestamp;
/**
*
*/
@JSONField(name = "username")
private String userName;
/**
*
*/
private String nonce;
}

View File

@ -1,12 +0,0 @@
package com.muyu.web.service;
public interface VehicleInstanceService {
/**
*
*/
void vehicleClientStart(String vin);
}

View File

@ -1,25 +0,0 @@
package com.muyu.web.service.impl;
import com.muyu.common.core.utils.uuid.UUID;
import com.muyu.web.domain.req.VehicleConnectionReq;
import com.muyu.web.service.VehicleInstanceService;
import com.muyu.web.utils.MD5Util;
import lombok.extern.log4j.Log4j2;
import org.springframework.stereotype.Service;
@Log4j2
@Service
public class VehicleInstanceServiceImpl implements VehicleInstanceService {
@Override
public void vehicleClientStart(String vin) {
log.info("车辆{},开始上线",vin);
String timestamp = String.valueOf(System.currentTimeMillis());
VehicleConnectionReq.builder()
.vin(vin)
.timestamp(timestamp)
.userName(MD5Util.encrypted(vin+timestamp))
.nonce(MD5Util.encrypted(UUID.randomUUID().toString().replace("-","")))
.build();
//
}
}

View File

@ -1,52 +0,0 @@
package com.muyu.web.utils;
import lombok.extern.log4j.Log4j2;
import java.nio.charset.StandardCharsets;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.security.SecureRandom;
@Log4j2
public class MD5Util {
private static final Integer SALT_LENGTH = 12;
/**
* 16
*/
public static String byteToHexString(byte[]b){
StringBuilder stringBuilder = new StringBuilder();
for (byte value : b) {
String hex = Integer.toHexString(value & 0xFF);
if (hex.length()==1){
hex='0'+hex;
}
stringBuilder.append(hex.toUpperCase());
}
return stringBuilder.toString();
}
/**
*
*/
public static String encrypted(String str){
try {
byte[]pwd=null;
SecureRandom random = new SecureRandom();
byte[] salt = new byte[SALT_LENGTH];
random.nextBytes(salt);
MessageDigest md=null;
md = MessageDigest.getInstance("MD5");
md.update(salt);
md.update(str.getBytes(StandardCharsets.UTF_8));
byte[] digest = md.digest();
pwd=new byte[digest.length+SALT_LENGTH];
System.arraycopy(salt,0,pwd,0,SALT_LENGTH);
System.arraycopy(digest,0,pwd,SALT_LENGTH,digest.length);
return byteToHexString(pwd);
} catch (NoSuchAlgorithmException e) {
throw new RuntimeException(e);
}
}
}

View File

@ -7,7 +7,7 @@ nacos:
addr: 47.101.53.251:8848
user-name: nacos
password: nacos
namespace: four
namespace: yzl
# Spring
spring:
@ -54,3 +54,5 @@ logging:
level:
com.muyu.system.mapper: DEBUG

View File

@ -12,7 +12,7 @@
<artifactId>cloud-modules-wechat</artifactId>
<description>
cloud-modules-wechat 微信公众号
cloud-modules-wechat 微信公众号模块
</description>
<properties>

View File

@ -30,6 +30,7 @@
<artifactId>cloud-modules</artifactId>
<packaging>pom</packaging>
<description>
cloud-modules业务模块
</description>

View File

@ -14,6 +14,7 @@
<modules>
<module>saas-common</module>
<module>saas-server</module>
<module>saas-cache</module>
</modules>
<description>

View File

@ -0,0 +1,40 @@
<?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">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.muyu</groupId>
<artifactId>saas</artifactId>
<version>3.6.3</version>
</parent>
<artifactId>saas-cache</artifactId>
<properties>
<maven.compiler.source>17</maven.compiler.source>
<maven.compiler.target>17</maven.compiler.target>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<description>
saas-cache缓存模块
</description>
<dependencies>
<dependency>
<groupId>com.muyu.common</groupId>
<artifactId>saas-common</artifactId>
<version>3.6.3</version>
</dependency>
<dependency>
<groupId>com.muyu.cache</groupId>
<artifactId>cloud-common-cache</artifactId>
<version>3.6.3</version>
</dependency>
</dependencies>
</project>

View File

@ -0,0 +1,32 @@
package com.muyu.cache;
import com.muyu.common.domain.database.ElectronicFence;
import org.springframework.stereotype.Component;
/**
* @Author YuPing
* @Description
* @Version 1.0
* @Data 2024-09-29 20:53:46
*/
@Component
public class ElectronicFenceCacheService extends CacheAbsBasic<String, ElectronicFence>{
/**
* key
* @return
*/
@Override
public String keyPre() {
return "electronicFence";
}
/**
*
* @param key key
* @return
*/
@Override
public String decode(String key) {
return key.replace(keyPre(), "");
}
}

View File

@ -0,0 +1,32 @@
package com.muyu.cache;
import com.muyu.common.domain.database.ElectronicFenceGroup;
import org.springframework.stereotype.Component;
/**
* @Author YuPing
* @Description
* @Version 1.0
* @Data 2024-09-29 20:57:46
*/
@Component
public class ElectronicFenceGroupCacheService extends CacheAbsBasic<String, ElectronicFenceGroup>{
/**
* key
* @return
*/
@Override
public String keyPre() {
return "electronicFenceGroup";
}
/**
*
* @param key key
* @return
*/
@Override
public String decode(String key) {
return key.replace(keyPre(), "");
}
}

View File

@ -0,0 +1,32 @@
package com.muyu.cache;
import com.muyu.common.domain.Enterprise;
import org.springframework.stereotype.Component;
/**
* @author yuping
* @package com.muyu.cache
* @name EnterpriseCacheService
* @date 2024/9/29 20:21
*/
@Component
public class EnterpriseCacheService extends CacheAbsBasic<String, Enterprise>{
/**
*
* @return
*/
@Override
public String keyPre() {
return "enterprise:info:";
}
/**
*
* @param key key
* @return
*/
@Override
public String decode(String key) {
return key.replace(keyPre(), "");
}
}

View File

@ -0,0 +1,32 @@
package com.muyu.cache;
import com.muyu.common.domain.SysCarFault;
import org.springframework.stereotype.Component;
/**
* @Author YuPing
* @Description
* @Version 1.0
* @Data 2024-09-29 21:10:31
*/
@Component
public class SysCarFaultCacheService extends CacheAbsBasic<String, SysCarFault>{
/**
*
* @return
*/
@Override
public String keyPre() {
return "sysCarFault";
}
/**
*
* @param key key
* @return
*/
@Override
public String decode(String key) {
return key.replace(keyPre(), "");
}
}

View File

@ -0,0 +1,23 @@
package com.muyu.cache;
import com.muyu.common.domain.SysCarFaultMessage;
import org.springframework.stereotype.Component;
/**
* @Author YuPing
* @Description
* @Version 1.0
* @Data 2024-09-29 21:13:19
*/
@Component
public class SysCarFaultMessageCacheService extends CacheAbsBasic<String, SysCarFaultMessage>{
@Override
public String keyPre() {
return "sysCarFaultMessage";
}
@Override
public String decode(String key) {
return key.replace(keyPre(), "");
}
}

View File

@ -0,0 +1,5 @@
com.muyu.cache.ElectronicFenceCacheService
com.muyu.cache.ElectronicFenceGroupCacheService
com.muyu.cache.EnterpriseCacheService
com.muyu.cache.SysCarFaultCacheService
com.muyu.cache.SysCarFaultMessageCacheService

View File

@ -7,12 +7,11 @@ import lombok.Data;
import lombok.NoArgsConstructor;
/**
*
* @Authorliuxinyue
* @Packagecom.sheep.message.domain
* @Projectcloud-server-c
* @nameMessageTemplateType
* @Date2024/9/18 21:01
*
* @author sx
* @package com.muyu.common.domain
* @name CarType
* @date 2024/9/22 14:36
*/
@Data
@AllArgsConstructor

View File

@ -10,8 +10,8 @@ import lombok.NoArgsConstructor;
import lombok.experimental.SuperBuilder;
import java.io.Serializable;
/**
*
* @Authorliuxinyue
*
* @author liuxinyue
* @Packagecom.sheep.message.domain
* @Projectcloud-server-c
* @nameDataType

View File

@ -1,11 +1,13 @@
package com.muyu.common.domain;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
/**
* @Author YuPing
*
* @author yuping
* @Description
* @Version 1.0
* @Data 2024-09-26 20:22:04
@ -13,6 +15,7 @@ import lombok.NoArgsConstructor;
@Data
@NoArgsConstructor
@AllArgsConstructor
@TableName("enterprise")
public class Enterprise {
/**
*

View File

@ -1,5 +1,6 @@
package com.muyu.common.domain;
import com.baomidou.mybatisplus.annotation.TableName;
import io.swagger.v3.oas.annotations.tags.Tag;
import lombok.AllArgsConstructor;
import lombok.Data;
@ -9,8 +10,8 @@ import lombok.experimental.SuperBuilder;
import java.sql.Date;
/**
*
* @Authorliuxinyue
*
* @author liuxinyue
* @Packagecom.template.domain
* @Projectcloud-server
* @nameMessageTemplate
@ -21,6 +22,7 @@ import java.sql.Date;
@NoArgsConstructor
@SuperBuilder
@Tag(name = "报文")
@TableName("message_template")
public class MessageTemplate {
/**

View File

@ -11,7 +11,6 @@ import lombok.experimental.SuperBuilder;
import java.io.Serializable;
/**
*
* @Authorliuxinyue
* @Packagecom.sheep.message.domain
* @Projectcloud-server-c
@ -26,7 +25,6 @@ import java.io.Serializable;
@TableName(value = "message_template_type",autoResultMap = true)
public class MessageTemplateType implements Serializable {
/**
*
*/

View File

@ -10,12 +10,11 @@ import lombok.EqualsAndHashCode;
import lombok.NoArgsConstructor;
/**
*
* @Authorliuxinyue
* @Packagecom.sheep.message.domain
* @Projectcloud-server-c
* @nameMessageTemplateType
* @Date2024/9/18 21:01
*
* @author sx
* @package com.muyu.common.domain
* @name SysCar
* @date 2024-09-29 14:39:33
*/
@Data
@AllArgsConstructor
@ -23,7 +22,6 @@ import lombok.NoArgsConstructor;
@EqualsAndHashCode(callSuper = true)
@TableName(value = "sys_car",autoResultMap = true)
public class SysCar extends BaseEntity {
@TableId(value = "id",type = IdType.AUTO)
private Long id;
private String carVin;

View File

@ -9,7 +9,7 @@ import lombok.*;
/**
* sys_car_enterprise
* @author YuanZiLong
* @author
* @package com.muyu.breakdown.domain
* @name: SysCarEnterprise
* @date: 2024/9/26 19:54

View File

@ -12,7 +12,7 @@ import org.apache.commons.lang3.builder.ToStringStyle;
/**
* sys_car_fault
* @author YuanZiLong
* @author
* @package: com.muyu.breakdown.domain
* @name: SysCarFault
* @date: 2024/9/20 10:56

View File

@ -12,7 +12,7 @@ import java.util.Date;
/**
* sys_car_fault_log
* @author YuanZiLong
* @author
* @package: com.muyu.breakdown.domain
* @name: SysCarFaultLog
* @date: 2024/9/22 20:17

View File

@ -11,7 +11,7 @@ import java.util.Date;
/**
* sys_car_fault_message
* @author YuanZiLong
* @author
* @package: com.muyu.breakdown.domain
* @name: SysCarFaultMessage
* @date: 2024/9/22 11:57

View File

@ -11,12 +11,11 @@ import lombok.NoArgsConstructor;
import java.util.Date;
/**
*
* @Authorliuxinyue
* @Packagecom.sheep.message.domain
* @Projectcloud-server-c
* @nameMessageTemplateType
* @Date2024/9/18 21:01
* 线
* @author sx
* @package com.muyu.common.domain
* @name SysCarLog
* @date 2024-09-29 14:34:15
*/
@Data
@AllArgsConstructor

View File

@ -14,13 +14,14 @@ import org.springframework.format.annotation.DateTimeFormat;
import java.util.Date;
/**
*
* @Authorliuxinyue
*
* @author liuxinyue
* @Packagecom.template.domain
* @Projectcloud-server-c
* @nameTemplate
* @Date2024/9/20 12:04
*/
@Data
@AllArgsConstructor
@NoArgsConstructor

View File

@ -14,7 +14,7 @@ import java.util.Date;
/**
* warn_logs
*
* @author muyu
* @author sx
* @date 2024-09-20
*/

View File

@ -11,7 +11,7 @@ import lombok.NoArgsConstructor;
/**
* warn_rule
*
* @author muyu
* @author sx
* @date 2024-09-20
*/

View File

@ -11,7 +11,7 @@ import lombok.NoArgsConstructor;
/**
* warn_strategy
*
* @author muyu
* @author sx
* @date 2024-09-20
*/

View File

@ -16,7 +16,8 @@ import lombok.experimental.SuperBuilder;
import java.util.function.Supplier;
/**
* @Authoryuping
*
* @author yuping
* @Packagecom.muyu.fence.domain
* @Projectcloud-server
* @nameElectronicFence

View File

@ -16,7 +16,8 @@ import lombok.experimental.SuperBuilder;
import java.util.function.Supplier;
/**
* @Authoryuping
*
* @author yuping
* @Packagecom.muyu.fence.domain
* @Projectcloud-server
* @nameElectronicFenceGroup

View File

@ -9,7 +9,8 @@ import lombok.Data;
import lombok.NoArgsConstructor;
/**
* @Authoryuping
*
* @author yuping
* @Packagecom.muyu.fence.domain
* @Projectcloud-server
* @nameFenceGroupMid

View File

@ -10,7 +10,8 @@ import lombok.NoArgsConstructor;
import java.util.Date;
/**
* @Authoryuping
*
* @author yuping
* @Packagecom.muyu.fence.domain.req
* @Projectcloud-server
* @nameElectroicAdd

View File

@ -8,7 +8,8 @@ import lombok.NoArgsConstructor;
import java.util.Date;
/**
* @Authoryuping
*
* @author yuping
* @Packagecom.muyu.fence.domain.req
* @Projectcloud-server
* @nameElectroicFenceReq

View File

@ -6,7 +6,8 @@ import lombok.Data;
import lombok.NoArgsConstructor;
/**
* @Authoryuping
*
* @author yuping
* @Packagecom.muyu.fence.domain.req
* @Projectcloud-server
* @nameElectroicFenceUpdReq

View File

@ -9,7 +9,8 @@ import lombok.NoArgsConstructor;
import java.util.List;
/**
* @Authoryuping
*
* @author yuping
* @Packagecom.muyu.fence.domain.req
* @Projectcloud-server
* @nameElectronicFenceGroupAddReq

View File

@ -8,7 +8,8 @@ import lombok.Data;
import lombok.NoArgsConstructor;
/**
* @Authoryuping
*
* @author yuping
* @Packagecom.muyu.fence.domain.req
* @Projectcloud-server
* @nameElectronicFenceGroupListReq

View File

@ -11,7 +11,8 @@ import lombok.NoArgsConstructor;
import java.util.List;
/**
* @Authoryuping
*
* @author yuping
* @Packagecom.muyu.fence.domain.req
* @Projectcloud-server
* @nameElectronicFenceGroupAddReq

View File

@ -9,7 +9,8 @@ import lombok.NoArgsConstructor;
import java.util.List;
/**
* @Authoryuping
*
* @author yuping
* @Packagecom.muyu.fence.domain.req
* @Projectcloud-server
* @nameFenceAndGroupBoundReq

View File

@ -5,7 +5,8 @@ import lombok.Data;
import lombok.NoArgsConstructor;
/**
* @Authoryuping
*
* @author yuping
* @Packagecom.muyu.fence.domain
* @Projectcloud-server
* @nameFenceWay

View File

@ -5,6 +5,13 @@ import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
/**
*
* @author sx
* @package com.muyu.common.domain.req
* @name SysCarReq
* @date 2024/9/22 14:36
*/
@Data
@AllArgsConstructor
@NoArgsConstructor

View File

@ -8,7 +8,7 @@ import lombok.NoArgsConstructor;
/**
* warn_strategy
*
* @author muyu
* @author sx
* @date 2024-09-20
*/

View File

@ -8,6 +8,13 @@ import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.NoArgsConstructor;
/**
*
* @author sx
* @package com.muyu.common.domain.resp
* @name CarTypeResp
* @date 2024/9/22 14:36
*/
@Data
@AllArgsConstructor
@NoArgsConstructor

View File

@ -10,12 +10,13 @@ import lombok.NoArgsConstructor;
import java.util.List;
/**
* @Authoryuping
* @Packagecom.muyu.fence.domain.resp
* @Projectcloud-server
* @nameElectronicFenceGroupResp
* @Date2024/9/22 10:22
*
* @author yuping
* @package com.muyu.fence.domain.resp
* @name ElectronicFenceGroupResp
* @date 2024/9/22 14:36
*/
@Data
@AllArgsConstructor

View File

@ -7,12 +7,14 @@ import lombok.NoArgsConstructor;
import lombok.experimental.SuperBuilder;
/**
* @Authoryuping
*
* @author yuping
* @Packagecom.muyu.fence.domain
* @Projectcloud-server
* @nameElectronicFence
* @Date2024/9/17 16:34
*/
@Data
@AllArgsConstructor
@NoArgsConstructor

View File

@ -9,7 +9,8 @@ import lombok.Data;
import lombok.NoArgsConstructor;
/**
* @Authoryuping
*
* @author yuping
* @Packagecom.muyu.fence.domain.req
* @Projectcloud-server
* @nameGroupFenceListresp

View File

@ -6,7 +6,8 @@ import lombok.Data;
import lombok.NoArgsConstructor;
/**
* @Authorliuxinyue
*
* @author liuxinyue
* @Packagecom.muyu.domain.resp
* @Projectcloud-server
* @nameSysCarFaultLogVo

View File

@ -7,6 +7,13 @@ import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.NoArgsConstructor;
/**
*
* @author sx
* @package com.muyu.common.domain.resp
* @name SysCarVo
* @date 2024/9/22 14:36
*/
@Data
@AllArgsConstructor
@NoArgsConstructor

View File

@ -7,6 +7,13 @@ import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
/**
*
* @author sx
* @package com.muyu.common.domain.resp
* @name WarnLogsResp
* @date 2024/9/22 14:36
*/
@Data
@NoArgsConstructor
@AllArgsConstructor

View File

@ -6,6 +6,13 @@ import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
/**
*
* @author sx
* @package com.muyu.common.domain.resp
* @name WarnRuleResp
* @date 2024/9/22 14:36
*/
@Data
@NoArgsConstructor
@AllArgsConstructor

View File

@ -7,6 +7,13 @@ import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
/**
*
* @author sx
* @package com.muyu.common.domain.resp
* @anme WarnStrategyResp
* @date 2024/9/22 14:36
*/
@Data
@NoArgsConstructor
@AllArgsConstructor

View File

@ -14,6 +14,10 @@ import lombok.NoArgsConstructor;
/**
*
* @author yuping
* @package com.muyu.fence.domain
* @name ElectricFenceModel
* @date 2024/9/22 14:36
*/
@Data
@AllArgsConstructor

View File

@ -15,6 +15,10 @@ import java.util.Date;
*/
/**
*
* @author yuping
* @package com.muyu.fence.domain.utils
* @name ElectricFenceResultTmp
* @date 2024/9/22 14:36
*/
@Data
@AllArgsConstructor

View File

@ -18,6 +18,10 @@ import java.util.Date;
/**
*
* @author yuping
* @package com.muyu.fence.domain
* @name ElectronicFenceResult
* @date 2024/9/22 14:36
*/
@Data
@AllArgsConstructor

View File

@ -10,7 +10,8 @@ import lombok.NoArgsConstructor;
import lombok.experimental.SuperBuilder;
/**
* @Authoryuping
*
* @author yuping
* @Packagecom.muyu.fence.domain
* @Projectcloud-server
* @nameElectronicFenceSetting

View File

@ -1,239 +0,0 @@
package com.muyu.common.util;
import java.util.Collection;
import java.util.Collections;
/**
* kafka
* @author liuxinyue
* @Packagecom.muyu.common.util
* @nameKafkaCommonProperties
* @Date2024/9/29 12:26
*/
public class KafkaCommonProperties{
/**
* Kafka
*/
private String kafkaHost = "47.101.53.251:9092";
/**
* leader
*
* 0retry
* 1leaderlogfollower
* allleader-1
*/
private String ack = "all";
/**
*
*/
private Integer retryTimes = 1;
/**
* bytes16384bytes=16K
*/
private Integer batchSize = 16384;
/**
*
*/
private Integer lingerMs = 1;
/**
* 使bytes33554432bytes=32M.
*/
private Integer bufferMemory = 33554432;
/**
*
*/
private String keyEncoder = "org.apache.kafka.common.serialization.StringSerializer";
/**
*
*/
private String valueEncoder = "org.apache.kafka.common.serialization.StringSerializer";
/**
* topicID
*/
private String groupId = "my-group-id";
/**
* offset
*/
private String autoCommit = "true";
/**
* offsetenable.auto.committrue
*/
private String autoCommitIntervalMs = "1000";
/**
*
*/
private String keyDecoder = "org.apache.kafka.common.serialization.StringDeserializer";
/**
*
*/
private String valueDecoder = "org.apache.kafka.common.serialization.StringDeserializer";
/**
* offset
* earliesttopicoffset
* latestoffset
* noneoffset
*
*/
private String autoOffsetReset = "latest";
/**
* TOPIC
*/
private Collection<String> topic = Collections.singleton("my-topic");
public KafkaCommonProperties() {
}
public KafkaCommonProperties(String kafkaHost, String ack, Integer retryTimes, Integer batchSize, Integer lingerMs, Integer bufferMemory, String keyEncoder, String valueEncoder, String groupId, String autoCommit, String autoCommitIntervalMs, String keyDecoder, String valueDecoder, String autoOffsetReset, Collection<String> topic) {
this.kafkaHost = kafkaHost;
this.ack = ack;
this.retryTimes = retryTimes;
this.batchSize = batchSize;
this.lingerMs = lingerMs;
this.bufferMemory = bufferMemory;
this.keyEncoder = keyEncoder;
this.valueEncoder = valueEncoder;
this.groupId = groupId;
this.autoCommit = autoCommit;
this.autoCommitIntervalMs = autoCommitIntervalMs;
this.keyDecoder = keyDecoder;
this.valueDecoder = valueDecoder;
this.autoOffsetReset = autoOffsetReset;
this.topic = topic;
}
public String getKafkaHost() {
return kafkaHost;
}
public void setKafkaHost(String kafkaHost) {
this.kafkaHost = kafkaHost;
}
public String getAck() {
return ack;
}
public void setAck(String ack) {
this.ack = ack;
}
public Integer getRetryTimes() {
return retryTimes;
}
public void setRetryTimes(Integer retryTimes) {
this.retryTimes = retryTimes;
}
public Integer getBatchSize() {
return batchSize;
}
public void setBatchSize(Integer batchSize) {
this.batchSize = batchSize;
}
public Integer getLingerMs() {
return lingerMs;
}
public void setLingerMs(Integer lingerMs) {
this.lingerMs = lingerMs;
}
public Integer getBufferMemory() {
return bufferMemory;
}
public void setBufferMemory(Integer bufferMemory) {
this.bufferMemory = bufferMemory;
}
public String getKeyEncoder() {
return keyEncoder;
}
public void setKeyEncoder(String keyEncoder) {
this.keyEncoder = keyEncoder;
}
public String getValueEncoder() {
return valueEncoder;
}
public void setValueEncoder(String valueEncoder) {
this.valueEncoder = valueEncoder;
}
public String getGroupId() {
return groupId;
}
public void setGroupId(String groupId) {
this.groupId = groupId;
}
public String getAutoCommit() {
return autoCommit;
}
public void setAutoCommit(String autoCommit) {
this.autoCommit = autoCommit;
}
public String getAutoCommitIntervalMs() {
return autoCommitIntervalMs;
}
public void setAutoCommitIntervalMs(String autoCommitIntervalMs) {
this.autoCommitIntervalMs = autoCommitIntervalMs;
}
public String getKeyDecoder() {
return keyDecoder;
}
public void setKeyDecoder(String keyDecoder) {
this.keyDecoder = keyDecoder;
}
public String getValueDecoder() {
return valueDecoder;
}
public void setValueDecoder(String valueDecoder) {
this.valueDecoder = valueDecoder;
}
public String getAutoOffsetReset() {
return autoOffsetReset;
}
public void setAutoOffsetReset(String autoOffsetReset) {
this.autoOffsetReset = autoOffsetReset;
}
public Collection<String> getTopic() {
return topic;
}
public void setTopic(Collection<String> topic) {
this.topic = topic;
}
}

View File

@ -0,0 +1,16 @@
package com.muyu.common.util;
/**
* @author liuxinyue
* @Packagecom.muyu.common.util
* @nameKafkaConstants
* @Date2024/9/29 20:22
*/
public class KafkaConstants {
public final static String KafkaTopic="kafka_topic_test";
public final static String KafkaGrop="kafka_group_test";
}

View File

@ -0,0 +1,43 @@
package com.muyu.common.util;
import org.apache.kafka.clients.consumer.KafkaConsumer;
import org.apache.kafka.common.serialization.Deserializer;
import org.apache.kafka.common.serialization.StringDeserializer;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import java.util.HashMap;
/**
* @author liuxinyue
* @Packagecom.muyu.common.util
* @nameKafkaConsumerConfig
* @Date2024/9/29 20:19
*/
@Configuration
public class KafkaConsumerConfig
{
@Bean
public KafkaConsumer kafkaConsumer(){
HashMap<String, Object> map = new HashMap<>();
map.put("bootstrap.servers", "47.101.53.251:9092");
map.put("enable.auto.commit",true);
map.put("auto.commit.interval", 5000);
map.put("auto.offset.reset", "latest");
map.put("fetch.max.wait", 500);
map.put("fetch.min.size", 1);
map.put("heartbeat-interval", 3000);
map.put("max.poll.records", 500);
map.put("group.id", KafkaConstants.KafkaGrop);
//指定key使用的反序列化类
Deserializer keyDeserializer = new StringDeserializer();
//指定value使用的反序列化类
Deserializer valueDeserializer = new StringDeserializer();
//创建Kafka消费者
KafkaConsumer kafkaConsumer = new KafkaConsumer(map, keyDeserializer, valueDeserializer);
return kafkaConsumer;
}
}

View File

@ -1,64 +0,0 @@
package com.muyu.common.util;
import org.apache.kafka.clients.producer.*;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.util.Objects;
import java.util.Properties;
/**
* kafka
* @author liuxinyue
* @Packagecom.muyu.common.util
* @nameKafkaProducerTest
* @Date2024/9/29 12:27
*/
public class KafkaProducerTest {
private static final Logger logger = LoggerFactory.getLogger(KafkaProducerTest.class);
public static KafkaProducer<String, String> getDefaultKafkaProducer(KafkaCommonProperties kafkaCommonProperties) {
Properties properties = new Properties();
properties.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG, kafkaCommonProperties.getKafkaHost());
properties.put(ProducerConfig.ACKS_CONFIG, kafkaCommonProperties.getAck());
properties.put(ProducerConfig.RETRIES_CONFIG, kafkaCommonProperties.getRetryTimes());
properties.put(ProducerConfig.BATCH_SIZE_CONFIG, kafkaCommonProperties.getBatchSize());
properties.put(ProducerConfig.LINGER_MS_CONFIG, kafkaCommonProperties.getLingerMs());
properties.put(ProducerConfig.BUFFER_MEMORY_CONFIG, kafkaCommonProperties.getBufferMemory());
properties.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, kafkaCommonProperties.getKeyEncoder());
properties.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG, kafkaCommonProperties.getValueEncoder());
return new KafkaProducer<>(properties);
}
static class MyProducerCallback implements Callback {
@Override
public void onCompletion(RecordMetadata metadata, Exception exception) {
if (Objects.nonNull(exception)) {
logger.error(">>>>>>>>>>Producer生产消息异常", exception);
}
if (Objects.nonNull(metadata)) {
logger.info(">>>>>>>>>>Producer生产消息metadata{}partition:{}, offset{}", metadata, metadata.partition(), metadata.offset());
}
}
}
public static void main(String[] args) {
KafkaCommonProperties kafkaCommonProperties = new KafkaCommonProperties();
KafkaProducer<String, String> producer = getDefaultKafkaProducer(kafkaCommonProperties);
String message = "hello world ";
try {
for (int i = 0; i < 10; i++) {
// 异步写入数据
String topic = kafkaCommonProperties.getTopic().toArray()[0].toString();
ProducerRecord<String, String> producerRecord = new ProducerRecord<>(topic, message + i);
producer.send(producerRecord, new MyProducerCallback());
}
} catch (Exception ex) {
logger.error(">>>>>>>>生产数据异常:", ex);
throw new RuntimeException(ex);
} finally {
producer.close();
}
}
}

Some files were not shown because too many files have changed in this diff Show More