mirror of
https://gitee.com/beecue/fastbee.git
synced 2025-12-17 16:36:03 +08:00
2022年5月24日01:05:38 还原ApplicationStart,讲TDengine相关类型和配置归于同一个包
This commit is contained in:
@@ -1,34 +1,21 @@
|
|||||||
package com.ruoyi.framework.config;
|
package com.ruoyi.framework.config;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.*;
|
import java.util.ArrayList;
|
||||||
import javax.servlet.*;
|
import java.util.Arrays;
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.List;
|
||||||
import javax.sql.DataSource;
|
import javax.sql.DataSource;
|
||||||
|
|
||||||
import com.alibaba.druid.pool.DruidDataSource;
|
|
||||||
import com.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceBuilder;
|
|
||||||
import com.alibaba.druid.spring.boot.autoconfigure.properties.DruidStatProperties;
|
|
||||||
import com.alibaba.druid.util.Utils;
|
|
||||||
import com.ruoyi.common.enums.DataSourceType;
|
|
||||||
import com.ruoyi.common.utils.spring.SpringUtils;
|
|
||||||
import com.ruoyi.framework.config.properties.DruidProperties;
|
|
||||||
import com.ruoyi.framework.datasource.DynamicDataSource;
|
|
||||||
import org.apache.ibatis.io.VFS;
|
import org.apache.ibatis.io.VFS;
|
||||||
import org.apache.ibatis.session.SqlSessionFactory;
|
import org.apache.ibatis.session.SqlSessionFactory;
|
||||||
import org.mybatis.spring.SqlSessionFactoryBean;
|
import org.mybatis.spring.SqlSessionFactoryBean;
|
||||||
import org.mybatis.spring.SqlSessionTemplate;
|
import org.mybatis.spring.SqlSessionTemplate;
|
||||||
import org.mybatis.spring.annotation.MapperScan;
|
|
||||||
import org.mybatis.spring.boot.autoconfigure.SpringBootVFS;
|
import org.mybatis.spring.boot.autoconfigure.SpringBootVFS;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.beans.factory.annotation.Qualifier;
|
import org.springframework.beans.factory.annotation.Qualifier;
|
||||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
|
|
||||||
import org.springframework.boot.context.properties.ConfigurationProperties;
|
|
||||||
import org.springframework.boot.jdbc.DataSourceBuilder;
|
|
||||||
import org.springframework.boot.web.servlet.FilterRegistrationBean;
|
|
||||||
import org.springframework.context.annotation.Bean;
|
import org.springframework.context.annotation.Bean;
|
||||||
import org.springframework.context.annotation.Configuration;
|
import org.springframework.context.annotation.Configuration;
|
||||||
import org.springframework.context.annotation.Primary;
|
import org.springframework.context.annotation.Primary;
|
||||||
import org.springframework.core.annotation.Order;
|
|
||||||
import org.springframework.core.env.Environment;
|
import org.springframework.core.env.Environment;
|
||||||
import org.springframework.core.io.DefaultResourceLoader;
|
import org.springframework.core.io.DefaultResourceLoader;
|
||||||
import org.springframework.core.io.Resource;
|
import org.springframework.core.io.Resource;
|
||||||
@@ -47,8 +34,8 @@ import com.ruoyi.common.utils.StringUtils;
|
|||||||
* @author ruoyi
|
* @author ruoyi
|
||||||
*/
|
*/
|
||||||
@Configuration
|
@Configuration
|
||||||
@MapperScan(basePackages = {"com.ruoyi.iot.mapper", "com.ruoyi.system.mapper", "com.ruoyi.quartz.mapper", "com.ruoyi.generator.mapper"}, sqlSessionTemplateRef = "mysqlSqlSessionTemplate")
|
public class MyBatisConfig
|
||||||
public class MyBatisConfig {
|
{
|
||||||
@Autowired
|
@Autowired
|
||||||
private Environment env;
|
private Environment env;
|
||||||
|
|
||||||
@@ -132,11 +119,10 @@ public class MyBatisConfig {
|
|||||||
|
|
||||||
@Bean(name = "mysqlSessionFactory")
|
@Bean(name = "mysqlSessionFactory")
|
||||||
@Primary
|
@Primary
|
||||||
public SqlSessionFactory sqlSessionFactory(@Qualifier("dynamicDataSource") DataSource dataSource) throws Exception
|
public SqlSessionFactory sqlSessionFactory(DataSource dataSource) throws Exception
|
||||||
{
|
{
|
||||||
String typeAliasesPackage = "com.ruoyi.**.domain";//env.getProperty("mybatis.typeAliasesPackage");
|
String typeAliasesPackage = env.getProperty("mybatis.typeAliasesPackage");
|
||||||
String mapperLocations = "classpath:mapper/iot/*Mapper.xml,classpath:mapper/system/*Mapper.xml,classpath:mapper/quartz/*Mapper.xml";
|
String mapperLocations = env.getProperty("mybatis.mapperLocations");
|
||||||
// String typeAliasesPackage = "com.ruoyi.**.domain";
|
|
||||||
String configLocation = env.getProperty("mybatis.configLocation");
|
String configLocation = env.getProperty("mybatis.configLocation");
|
||||||
typeAliasesPackage = setTypeAliasesPackage(typeAliasesPackage);
|
typeAliasesPackage = setTypeAliasesPackage(typeAliasesPackage);
|
||||||
VFS.addImplClass(SpringBootVFS.class);
|
VFS.addImplClass(SpringBootVFS.class);
|
||||||
@@ -157,8 +143,7 @@ public class MyBatisConfig {
|
|||||||
|
|
||||||
@Bean(name = "mysqlSqlSessionTemplate")
|
@Bean(name = "mysqlSqlSessionTemplate")
|
||||||
@Primary
|
@Primary
|
||||||
public SqlSessionTemplate mysqlSqlSessionTemplate(@Qualifier("mysqlSessionFactory") SqlSessionFactory sqlSessionFactory) throws Exception {
|
public SqlSessionTemplate mysqlSqlSessionTemplate(@Qualifier("mysqlSessionFactory") SqlSessionFactory sqlSessionFactory) {
|
||||||
return new SqlSessionTemplate(sqlSessionFactory);
|
return new SqlSessionTemplate(sqlSessionFactory);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -1,76 +0,0 @@
|
|||||||
package com.ruoyi.iot.init;
|
|
||||||
|
|
||||||
|
|
||||||
//import com.ruoyi.mysql.config.TDengineConfig;
|
|
||||||
|
|
||||||
//import com.ruoyi.iot.tdengine.config.TDengineConfig;
|
|
||||||
import com.alibaba.druid.pool.DruidDataSource;
|
|
||||||
import com.ruoyi.iot.tdengine.config.TDengineConfig;
|
|
||||||
import com.ruoyi.iot.domain.DeviceLog;
|
|
||||||
import com.ruoyi.iot.mapper.DeviceMapper;
|
|
||||||
import com.ruoyi.iot.tdengine.mapper.TDDeviceLogMapper;
|
|
||||||
import org.mybatis.spring.SqlSessionTemplate;
|
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.beans.factory.annotation.Qualifier;
|
|
||||||
import org.springframework.boot.ApplicationArguments;
|
|
||||||
import org.springframework.boot.ApplicationRunner;
|
|
||||||
import org.springframework.context.ApplicationContext;
|
|
||||||
import org.springframework.stereotype.Component;
|
|
||||||
|
|
||||||
import javax.sql.DataSource;
|
|
||||||
import java.util.Date;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 类名: ApplicationStarted
|
|
||||||
* 描述: TODO
|
|
||||||
* 时间: 2022/5/18,0018 1:41
|
|
||||||
* 开发人: wxy
|
|
||||||
*/
|
|
||||||
@Component
|
|
||||||
public class ApplicationStarted implements ApplicationRunner {
|
|
||||||
|
|
||||||
private static final Logger LOGGER = LoggerFactory.getLogger(ApplicationStarted.class);
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
private TDengineConfig dengineConfig;
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
private TDDeviceLogMapper deviceLogMapper;
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
private DeviceMapper deviceMapper;
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void run(ApplicationArguments args) {
|
|
||||||
deviceMapper.selectDeviceByDeviceId(0L);
|
|
||||||
System.out.println("初始化MySql链接成功");
|
|
||||||
initTDengine();
|
|
||||||
System.out.println("初始化TDengine链接成功");
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @Method
|
|
||||||
* @Description 开始初始化加载系统参数,创建数据库和超级表
|
|
||||||
* @Param null
|
|
||||||
* @return
|
|
||||||
* @date 2022/5/22,0022 14:27
|
|
||||||
* @author wxy
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public void initTDengine() {
|
|
||||||
try {
|
|
||||||
String dbName = dengineConfig.getDbName();
|
|
||||||
int db = deviceLogMapper.createDB(dbName);
|
|
||||||
deviceLogMapper.createSTable(dbName);
|
|
||||||
|
|
||||||
System.out.println(db);
|
|
||||||
} catch (Exception e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
System.out.println("ERROR");
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -1,25 +0,0 @@
|
|||||||
package com.ruoyi.iot.log.service;
|
|
||||||
|
|
||||||
import com.ruoyi.iot.domain.DeviceLog;
|
|
||||||
|
|
||||||
import com.ruoyi.iot.model.MonitorModel;
|
|
||||||
import org.springframework.stereotype.Service;
|
|
||||||
|
|
||||||
import java.util.Date;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @package iot.iot.log
|
|
||||||
* 类名: LogService
|
|
||||||
* 描述: 设备日志记录接口
|
|
||||||
* 时间: 2022/5/19,0019 18:04
|
|
||||||
* 开发人: admin
|
|
||||||
*/
|
|
||||||
public interface ILogService {
|
|
||||||
|
|
||||||
int saveDeviceLog(DeviceLog deviceLog);
|
|
||||||
|
|
||||||
List<DeviceLog> selectDeviceLogList(DeviceLog deviceLog);
|
|
||||||
|
|
||||||
List<MonitorModel> selectMonitorList(DeviceLog deviceLog);
|
|
||||||
}
|
|
||||||
@@ -1,74 +0,0 @@
|
|||||||
package com.ruoyi.iot.log.service.factory;
|
|
||||||
|
|
||||||
import com.alibaba.fastjson.JSONObject;
|
|
||||||
import com.ruoyi.framework.config.MyBatisConfig;
|
|
||||||
import com.ruoyi.iot.log.service.impl.MySqlLogServiceImpl;
|
|
||||||
import com.ruoyi.iot.log.service.impl.TdengineLogServiceImpl;
|
|
||||||
import com.ruoyi.iot.model.MonitorModel;
|
|
||||||
import com.ruoyi.iot.tdengine.config.TDengineConfig;
|
|
||||||
import com.ruoyi.iot.domain.DeviceLog;
|
|
||||||
import com.ruoyi.iot.log.service.ILogService;
|
|
||||||
import com.ruoyi.iot.mapper.DeviceLogMapper;
|
|
||||||
import com.ruoyi.iot.tdengine.mapper.TDDeviceLogMapper;
|
|
||||||
import com.ruoyi.iot.util.SnowflakeIdWorker;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.context.ApplicationContext;
|
|
||||||
import org.springframework.context.annotation.Bean;
|
|
||||||
import org.springframework.lang.Nullable;
|
|
||||||
import org.springframework.scheduling.annotation.Async;
|
|
||||||
import org.springframework.stereotype.Component;
|
|
||||||
import org.springframework.stereotype.Service;
|
|
||||||
|
|
||||||
import javax.annotation.PostConstruct;
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.Date;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 类名: DeviceLogServiceImpl
|
|
||||||
* 描述: TODO
|
|
||||||
* 时间: 2022/5/19,0019 18:09
|
|
||||||
* 开发人: wxy
|
|
||||||
*/
|
|
||||||
@Component
|
|
||||||
public class LogServiceFactory {
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
private ApplicationContext applicationContext;
|
|
||||||
|
|
||||||
@Bean
|
|
||||||
public ILogService getLogService() {
|
|
||||||
//先获取TDengine的配置,检测TDengine是否已经配置
|
|
||||||
if (containBean(TDengineConfig.class)) {
|
|
||||||
TDengineConfig tDengineConfig = applicationContext.getBean(TDengineConfig.class);
|
|
||||||
TDDeviceLogMapper tDDeviceLogMapper = applicationContext.getBean(TDDeviceLogMapper.class);
|
|
||||||
ILogService logService = new TdengineLogServiceImpl(tDengineConfig, tDDeviceLogMapper);
|
|
||||||
return logService;
|
|
||||||
} else if (containBean(MyBatisConfig.class)) {
|
|
||||||
//没有配置TDengine,那么使用MySQL的日志配置
|
|
||||||
DeviceLogMapper deviceLogMapper = applicationContext.getBean( DeviceLogMapper.class);
|
|
||||||
ILogService logService = new MySqlLogServiceImpl(deviceLogMapper);
|
|
||||||
return logService;
|
|
||||||
} else {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @Method containBean
|
|
||||||
* @Description 根据类判断是否有对应bean
|
|
||||||
* @Param 类
|
|
||||||
* @return
|
|
||||||
* @date 2022/5/22,0022 14:12
|
|
||||||
* @author wxy
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
private boolean containBean(@Nullable Class<?> T) {
|
|
||||||
String[] beans = applicationContext.getBeanNamesForType(T);
|
|
||||||
if (beans == null || beans.length == 0) {
|
|
||||||
return false;
|
|
||||||
} else {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,38 +0,0 @@
|
|||||||
package com.ruoyi.iot.log.service.impl;
|
|
||||||
|
|
||||||
import com.ruoyi.iot.domain.DeviceLog;
|
|
||||||
import com.ruoyi.iot.log.service.ILogService;
|
|
||||||
import com.ruoyi.iot.mapper.DeviceLogMapper;
|
|
||||||
import com.ruoyi.iot.model.MonitorModel;
|
|
||||||
import org.springframework.stereotype.Service;
|
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 类名: MySqlLogServiceImpl
|
|
||||||
* 描述: MySQL存储日志实现类
|
|
||||||
* 时间: 2022/5/22,0022 13:37
|
|
||||||
* 开发人: admin
|
|
||||||
*/
|
|
||||||
public class MySqlLogServiceImpl implements ILogService {
|
|
||||||
|
|
||||||
private DeviceLogMapper deviceLogMapper;
|
|
||||||
|
|
||||||
public MySqlLogServiceImpl(DeviceLogMapper _deviceLogMapper){
|
|
||||||
this.deviceLogMapper=_deviceLogMapper;
|
|
||||||
}
|
|
||||||
@Override
|
|
||||||
public int saveDeviceLog(DeviceLog deviceLog) {
|
|
||||||
return deviceLogMapper.insertDeviceLog(deviceLog);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public List<DeviceLog> selectDeviceLogList(DeviceLog deviceLog) {
|
|
||||||
return deviceLogMapper.selectDeviceLogList(deviceLog);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public List<MonitorModel> selectMonitorList(DeviceLog deviceLog) {
|
|
||||||
return deviceLogMapper.selectMonitorList(deviceLog);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,57 +0,0 @@
|
|||||||
package com.ruoyi.iot.log.service.impl;
|
|
||||||
|
|
||||||
import com.ruoyi.iot.domain.DeviceLog;
|
|
||||||
import com.ruoyi.iot.log.service.ILogService;
|
|
||||||
import com.ruoyi.iot.model.MonitorModel;
|
|
||||||
import com.ruoyi.iot.tdengine.config.TDengineConfig;
|
|
||||||
import com.ruoyi.iot.tdengine.mapper.TDDeviceLogMapper;
|
|
||||||
import com.ruoyi.iot.util.SnowflakeIdWorker;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.context.ApplicationContext;
|
|
||||||
import org.springframework.context.annotation.Primary;
|
|
||||||
import org.springframework.stereotype.Service;
|
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 类名: TdengineLogServiceImpl
|
|
||||||
* 描述: TDengine存储日志数据实现类
|
|
||||||
* 时间: 2022/5/22,0022 13:38
|
|
||||||
* 开发人: admin
|
|
||||||
*/
|
|
||||||
public class TdengineLogServiceImpl implements ILogService {
|
|
||||||
|
|
||||||
private ApplicationContext applicationContext;
|
|
||||||
|
|
||||||
private TDDeviceLogMapper tdDeviceLogMapper;
|
|
||||||
|
|
||||||
private TDengineConfig tDengineConfig;
|
|
||||||
|
|
||||||
private SnowflakeIdWorker snowflakeIdWorker;
|
|
||||||
|
|
||||||
private String dbName;
|
|
||||||
|
|
||||||
public TdengineLogServiceImpl(TDengineConfig _tDengineConfig,TDDeviceLogMapper _tdDeviceLogMapper) {
|
|
||||||
this.tdDeviceLogMapper = _tdDeviceLogMapper;
|
|
||||||
this.tDengineConfig = _tDengineConfig;
|
|
||||||
snowflakeIdWorker=new SnowflakeIdWorker(1);
|
|
||||||
this.dbName=_tDengineConfig.getDbName();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int saveDeviceLog(DeviceLog deviceLog) {
|
|
||||||
long logId = snowflakeIdWorker.nextId();
|
|
||||||
deviceLog.setLogId(logId);
|
|
||||||
return tdDeviceLogMapper.save(dbName,deviceLog);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public List<DeviceLog> selectDeviceLogList(DeviceLog deviceLog) {
|
|
||||||
return tdDeviceLogMapper.selectDeviceLogList(dbName,deviceLog);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public List<MonitorModel> selectMonitorList(DeviceLog deviceLog) {
|
|
||||||
return tdDeviceLogMapper.selectMonitorList(dbName,deviceLog);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -3,7 +3,6 @@ package com.ruoyi.iot.mqtt;
|
|||||||
import com.alibaba.fastjson.JSON;
|
import com.alibaba.fastjson.JSON;
|
||||||
import com.ruoyi.iot.domain.Device;
|
import com.ruoyi.iot.domain.Device;
|
||||||
import com.ruoyi.iot.domain.DeviceLog;
|
import com.ruoyi.iot.domain.DeviceLog;
|
||||||
import com.ruoyi.iot.log.service.ILogService;
|
|
||||||
import com.ruoyi.iot.model.NtpModel;
|
import com.ruoyi.iot.model.NtpModel;
|
||||||
import com.ruoyi.iot.model.ThingsModels.IdentityAndName;
|
import com.ruoyi.iot.model.ThingsModels.IdentityAndName;
|
||||||
import com.ruoyi.iot.model.ThingsModels.ThingsModelValueItem;
|
import com.ruoyi.iot.model.ThingsModels.ThingsModelValueItem;
|
||||||
@@ -11,6 +10,7 @@ import com.ruoyi.iot.model.ThingsModels.ThingsModelValueRemarkItem;
|
|||||||
import com.ruoyi.iot.model.ThingsModels.ThingsModelValuesInput;
|
import com.ruoyi.iot.model.ThingsModels.ThingsModelValuesInput;
|
||||||
import com.ruoyi.iot.service.IDeviceLogService;
|
import com.ruoyi.iot.service.IDeviceLogService;
|
||||||
import com.ruoyi.iot.service.IDeviceService;
|
import com.ruoyi.iot.service.IDeviceService;
|
||||||
|
import com.ruoyi.iot.tdengine.service.ILogService;
|
||||||
import org.eclipse.paho.client.mqttv3.MqttAsyncClient;
|
import org.eclipse.paho.client.mqttv3.MqttAsyncClient;
|
||||||
import org.eclipse.paho.client.mqttv3.MqttClient;
|
import org.eclipse.paho.client.mqttv3.MqttClient;
|
||||||
import org.eclipse.paho.client.mqttv3.MqttException;
|
import org.eclipse.paho.client.mqttv3.MqttException;
|
||||||
|
|||||||
@@ -2,7 +2,6 @@ package com.ruoyi.iot.tdengine.config;
|
|||||||
|
|
||||||
import com.alibaba.druid.pool.DruidDataSource;
|
import com.alibaba.druid.pool.DruidDataSource;
|
||||||
import com.ruoyi.common.utils.StringUtils;
|
import com.ruoyi.common.utils.StringUtils;
|
||||||
import com.ruoyi.iot.tdengine.mapper.TDDeviceLogMapper;
|
|
||||||
import org.apache.ibatis.session.SqlSessionFactory;
|
import org.apache.ibatis.session.SqlSessionFactory;
|
||||||
import org.mybatis.spring.SqlSessionFactoryBean;
|
import org.mybatis.spring.SqlSessionFactoryBean;
|
||||||
import org.mybatis.spring.SqlSessionTemplate;
|
import org.mybatis.spring.SqlSessionTemplate;
|
||||||
@@ -31,13 +30,10 @@ import java.util.List;
|
|||||||
* 开发人: wxy
|
* 开发人: wxy
|
||||||
*/
|
*/
|
||||||
@Configuration
|
@Configuration
|
||||||
@MapperScan(basePackages = {"com.ruoyi.iot.tdengine.mapper"}, sqlSessionTemplateRef = "tdengineSqlSessionTemplate")
|
@MapperScan(basePackages = {"com.ruoyi.iot.tdengine.dao"}, sqlSessionTemplateRef = "tdengineSqlSessionTemplate")
|
||||||
@ConditionalOnProperty(name = "spring.datasource.druid.tdengine-server.enabled", havingValue = "true")
|
@ConditionalOnProperty(name = "spring.datasource.druid.tdengine-server.enabled", havingValue = "true")
|
||||||
public class TDengineConfig {
|
public class TDengineConfig {
|
||||||
|
|
||||||
@Autowired
|
|
||||||
private TDDeviceLogMapper deviceLogMapper;
|
|
||||||
|
|
||||||
@Value("${spring.datasource.druid.tdengine-server.dbName}")
|
@Value("${spring.datasource.druid.tdengine-server.dbName}")
|
||||||
private String dbName;
|
private String dbName;
|
||||||
|
|
||||||
@@ -64,22 +60,6 @@ public class TDengineConfig {
|
|||||||
return new SqlSessionTemplate(sqlSessionFactory);
|
return new SqlSessionTemplate(sqlSessionFactory);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// @Bean
|
|
||||||
// @ConditionalOnProperty(name = "spring.datasource.druid.tdengine-server.enabled", havingValue = "true")
|
|
||||||
// public TDDeviceLogMapper genTdengineLogMapper(@Qualifier("tDengineDataSource") TDDeviceLogMapper mapper) {
|
|
||||||
// if(this.deviceLogMapper==null){
|
|
||||||
// this.deviceLogMapper=mapper;
|
|
||||||
// }
|
|
||||||
// return this.deviceLogMapper;
|
|
||||||
// }
|
|
||||||
|
|
||||||
public TDDeviceLogMapper getTDengineLogMapper() {
|
|
||||||
return deviceLogMapper;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public String getDbName() {
|
public String getDbName() {
|
||||||
return dbName;
|
return dbName;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -10,7 +10,7 @@ import org.springframework.stereotype.Repository;
|
|||||||
* 开发人: wxy
|
* 开发人: wxy
|
||||||
*/
|
*/
|
||||||
@Repository
|
@Repository
|
||||||
public interface DatabaseMapper {
|
public interface DatabaseDAO {
|
||||||
|
|
||||||
int createDB();
|
int createDB();
|
||||||
|
|
||||||
@@ -16,7 +16,7 @@ import java.util.List;
|
|||||||
* 开发人: wxy
|
* 开发人: wxy
|
||||||
*/
|
*/
|
||||||
@Repository
|
@Repository
|
||||||
public interface TDDeviceLogMapper {
|
public interface TDDeviceLogDAO {
|
||||||
|
|
||||||
|
|
||||||
int createDB( String database);
|
int createDB( String database);
|
||||||
@@ -2,7 +2,7 @@ package com.ruoyi.iot.tdengine.init;
|
|||||||
|
|
||||||
|
|
||||||
import com.ruoyi.iot.tdengine.config.TDengineConfig;
|
import com.ruoyi.iot.tdengine.config.TDengineConfig;
|
||||||
import com.ruoyi.iot.tdengine.dao.TDDeviceLogMapper;
|
import com.ruoyi.iot.tdengine.dao.TDDeviceLogDAO;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
@@ -31,8 +31,8 @@ public class ApplicationStarted implements ApplicationRunner {
|
|||||||
//先获取TDengine的配置,检测TDengine是否已经配置
|
//先获取TDengine的配置,检测TDengine是否已经配置
|
||||||
if (containBean(TDengineConfig.class)) {
|
if (containBean(TDengineConfig.class)) {
|
||||||
TDengineConfig tDengineConfig = applicationContext.getBean(TDengineConfig.class);
|
TDengineConfig tDengineConfig = applicationContext.getBean(TDengineConfig.class);
|
||||||
TDDeviceLogMapper tDDeviceLogMapper = applicationContext.getBean(TDDeviceLogMapper.class);
|
TDDeviceLogDAO tDDeviceLogDAO = applicationContext.getBean(TDDeviceLogDAO.class);
|
||||||
initTDengine(tDengineConfig, tDDeviceLogMapper);
|
initTDengine(tDengineConfig, tDDeviceLogDAO);
|
||||||
System.out.println("初始化TDengine成功");
|
System.out.println("初始化TDengine成功");
|
||||||
}else{
|
}else{
|
||||||
System.out.println("MySQL初始化成功");
|
System.out.println("MySQL初始化成功");
|
||||||
@@ -47,7 +47,7 @@ public class ApplicationStarted implements ApplicationRunner {
|
|||||||
* @date 2022/5/22,0022 14:27
|
* @date 2022/5/22,0022 14:27
|
||||||
* @author wxy
|
* @author wxy
|
||||||
*/
|
*/
|
||||||
public void initTDengine(TDengineConfig dengineConfig, TDDeviceLogMapper deviceLogMapper) {
|
public void initTDengine(TDengineConfig dengineConfig, TDDeviceLogDAO deviceLogMapper) {
|
||||||
try {
|
try {
|
||||||
String dbName = dengineConfig.getDbName();
|
String dbName = dengineConfig.getDbName();
|
||||||
int db = deviceLogMapper.createDB(dbName);
|
int db = deviceLogMapper.createDB(dbName);
|
||||||
|
|||||||
@@ -1,25 +0,0 @@
|
|||||||
package com.ruoyi.iot.tdengine.mapper;
|
|
||||||
|
|
||||||
import org.springframework.stereotype.Repository;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @package com.ruoyi.mysql.mysql.tdengine
|
|
||||||
* 类名: DatabaseMapper
|
|
||||||
* 描述: TODO
|
|
||||||
* 时间: 2022/5/16,0016 1:27
|
|
||||||
* 开发人: wxy
|
|
||||||
*/
|
|
||||||
@Repository
|
|
||||||
public interface DatabaseMapper {
|
|
||||||
|
|
||||||
int createDB();
|
|
||||||
|
|
||||||
int dropDatabase();
|
|
||||||
|
|
||||||
int useDatabase();
|
|
||||||
|
|
||||||
int createTable();
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -1,42 +0,0 @@
|
|||||||
package com.ruoyi.iot.tdengine.mapper;
|
|
||||||
|
|
||||||
import com.ruoyi.iot.domain.DeviceLog;
|
|
||||||
import com.ruoyi.iot.model.MonitorModel;
|
|
||||||
import org.apache.ibatis.annotations.Param;
|
|
||||||
import org.springframework.stereotype.Repository;
|
|
||||||
|
|
||||||
import java.lang.management.MonitorInfo;
|
|
||||||
import java.util.Date;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @package com.ruoyi.mysql.mysql.tdengine
|
|
||||||
* 类名: DatabaseMapper
|
|
||||||
* 描述: TODO
|
|
||||||
* 时间: 2022/5/16,0016 1:27
|
|
||||||
* 开发人: wxy
|
|
||||||
*/
|
|
||||||
@Repository
|
|
||||||
public interface TDDeviceLogMapper {
|
|
||||||
|
|
||||||
|
|
||||||
int createDB( String database);
|
|
||||||
|
|
||||||
int createSTable(String database);
|
|
||||||
|
|
||||||
int createTable(String database,String deviceId);
|
|
||||||
|
|
||||||
int save(@Param("database") String database,@Param("device") DeviceLog deviceLog);
|
|
||||||
|
|
||||||
List<DeviceLog> selectSTable(String database,DeviceLog deviceLog);
|
|
||||||
|
|
||||||
int delete(String dbName, DeviceLog deviceLog);
|
|
||||||
|
|
||||||
// List<DeviceLog> selectLogListByPage(String dbName, Integer pageSize, Integer pageNum, String deviceNum, Date beginDate, Date endDate);
|
|
||||||
|
|
||||||
List<DeviceLog> selectLogList(String dbName, Long deviceId, String serialNumber, Long isMonitor, Long logType, Date beginDate, Date endDate);
|
|
||||||
|
|
||||||
List<MonitorModel> selectMonitorList(@Param("database") String database, @Param("device") DeviceLog deviceLog);
|
|
||||||
|
|
||||||
List<DeviceLog> selectDeviceLogList(@Param("database") String database,@Param("device") DeviceLog deviceLog);
|
|
||||||
}
|
|
||||||
@@ -6,7 +6,7 @@ import com.ruoyi.iot.tdengine.service.impl.TdengineLogServiceImpl;
|
|||||||
import com.ruoyi.iot.tdengine.config.TDengineConfig;
|
import com.ruoyi.iot.tdengine.config.TDengineConfig;
|
||||||
import com.ruoyi.iot.tdengine.service.ILogService;
|
import com.ruoyi.iot.tdengine.service.ILogService;
|
||||||
import com.ruoyi.iot.mapper.DeviceLogMapper;
|
import com.ruoyi.iot.mapper.DeviceLogMapper;
|
||||||
import com.ruoyi.iot.tdengine.dao.TDDeviceLogMapper;
|
import com.ruoyi.iot.tdengine.dao.TDDeviceLogDAO;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.context.ApplicationContext;
|
import org.springframework.context.ApplicationContext;
|
||||||
import org.springframework.context.annotation.Bean;
|
import org.springframework.context.annotation.Bean;
|
||||||
@@ -30,8 +30,8 @@ public class LogServiceFactory {
|
|||||||
//先获取TDengine的配置,检测TDengine是否已经配置
|
//先获取TDengine的配置,检测TDengine是否已经配置
|
||||||
if (containBean(TDengineConfig.class)) {
|
if (containBean(TDengineConfig.class)) {
|
||||||
TDengineConfig tDengineConfig = applicationContext.getBean(TDengineConfig.class);
|
TDengineConfig tDengineConfig = applicationContext.getBean(TDengineConfig.class);
|
||||||
TDDeviceLogMapper tDDeviceLogMapper = applicationContext.getBean(TDDeviceLogMapper.class);
|
TDDeviceLogDAO tDDeviceLogDAO = applicationContext.getBean(TDDeviceLogDAO.class);
|
||||||
ILogService logService = new TdengineLogServiceImpl(tDengineConfig, tDDeviceLogMapper);
|
ILogService logService = new TdengineLogServiceImpl(tDengineConfig, tDDeviceLogDAO);
|
||||||
return logService;
|
return logService;
|
||||||
} else if (containBean(MyBatisConfig.class)) {
|
} else if (containBean(MyBatisConfig.class)) {
|
||||||
//没有配置TDengine,那么使用MySQL的日志配置
|
//没有配置TDengine,那么使用MySQL的日志配置
|
||||||
|
|||||||
@@ -4,7 +4,7 @@ import com.ruoyi.iot.domain.DeviceLog;
|
|||||||
import com.ruoyi.iot.tdengine.service.ILogService;
|
import com.ruoyi.iot.tdengine.service.ILogService;
|
||||||
import com.ruoyi.iot.model.MonitorModel;
|
import com.ruoyi.iot.model.MonitorModel;
|
||||||
import com.ruoyi.iot.tdengine.config.TDengineConfig;
|
import com.ruoyi.iot.tdengine.config.TDengineConfig;
|
||||||
import com.ruoyi.iot.tdengine.dao.TDDeviceLogMapper;
|
import com.ruoyi.iot.tdengine.dao.TDDeviceLogDAO;
|
||||||
import com.ruoyi.iot.util.SnowflakeIdWorker;
|
import com.ruoyi.iot.util.SnowflakeIdWorker;
|
||||||
import org.springframework.context.ApplicationContext;
|
import org.springframework.context.ApplicationContext;
|
||||||
|
|
||||||
@@ -20,7 +20,7 @@ public class TdengineLogServiceImpl implements ILogService {
|
|||||||
|
|
||||||
private ApplicationContext applicationContext;
|
private ApplicationContext applicationContext;
|
||||||
|
|
||||||
private TDDeviceLogMapper tdDeviceLogMapper;
|
private TDDeviceLogDAO tdDeviceLogDAO;
|
||||||
|
|
||||||
private TDengineConfig tDengineConfig;
|
private TDengineConfig tDengineConfig;
|
||||||
|
|
||||||
@@ -28,8 +28,8 @@ public class TdengineLogServiceImpl implements ILogService {
|
|||||||
|
|
||||||
private String dbName;
|
private String dbName;
|
||||||
|
|
||||||
public TdengineLogServiceImpl(TDengineConfig _tDengineConfig,TDDeviceLogMapper _tdDeviceLogMapper) {
|
public TdengineLogServiceImpl(TDengineConfig _tDengineConfig, TDDeviceLogDAO _tdDeviceLogDAO) {
|
||||||
this.tdDeviceLogMapper = _tdDeviceLogMapper;
|
this.tdDeviceLogDAO = _tdDeviceLogDAO;
|
||||||
this.tDengineConfig = _tDengineConfig;
|
this.tDengineConfig = _tDengineConfig;
|
||||||
snowflakeIdWorker=new SnowflakeIdWorker(1);
|
snowflakeIdWorker=new SnowflakeIdWorker(1);
|
||||||
this.dbName=_tDengineConfig.getDbName();
|
this.dbName=_tDengineConfig.getDbName();
|
||||||
@@ -39,16 +39,16 @@ public class TdengineLogServiceImpl implements ILogService {
|
|||||||
public int saveDeviceLog(DeviceLog deviceLog) {
|
public int saveDeviceLog(DeviceLog deviceLog) {
|
||||||
long logId = snowflakeIdWorker.nextId();
|
long logId = snowflakeIdWorker.nextId();
|
||||||
deviceLog.setLogId(logId);
|
deviceLog.setLogId(logId);
|
||||||
return tdDeviceLogMapper.save(dbName,deviceLog);
|
return tdDeviceLogDAO.save(dbName,deviceLog);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<DeviceLog> selectDeviceLogList(DeviceLog deviceLog) {
|
public List<DeviceLog> selectDeviceLogList(DeviceLog deviceLog) {
|
||||||
return tdDeviceLogMapper.selectDeviceLogList(dbName,deviceLog);
|
return tdDeviceLogDAO.selectDeviceLogList(dbName,deviceLog);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<MonitorModel> selectMonitorList(DeviceLog deviceLog) {
|
public List<MonitorModel> selectMonitorList(DeviceLog deviceLog) {
|
||||||
return tdDeviceLogMapper.selectMonitorList(dbName,deviceLog);
|
return tdDeviceLogDAO.selectMonitorList(dbName,deviceLog);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
<!DOCTYPE mapper
|
<!DOCTYPE mapper
|
||||||
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
||||||
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||||
<mapper namespace="com.ruoyi.iot.tdengine.mapper.DatabaseMapper">
|
<mapper namespace="com.ruoyi.iot.tdengine.dao.DatabaseDAO">
|
||||||
|
|
||||||
<!-- 创建数据库-->
|
<!-- 创建数据库-->
|
||||||
<update id="createDB" parameterType="java.lang.String">
|
<update id="createDB" parameterType="java.lang.String">
|
||||||
@@ -19,24 +19,6 @@
|
|||||||
use ${dbName};
|
use ${dbName};
|
||||||
</update>
|
</update>
|
||||||
|
|
||||||
|
|
||||||
<update id="createsTable">
|
|
||||||
create stable if not exists ${tableName}
|
|
||||||
(ts timestamp,
|
|
||||||
log_id BIGINT,
|
|
||||||
identity NCHAR(100),
|
|
||||||
log_type NCHAR(20),
|
|
||||||
log_value NCHAR(100),
|
|
||||||
device_id BIGINT,
|
|
||||||
device_name NCHAR(100),
|
|
||||||
serial_number NCHAR(100),
|
|
||||||
is_monitor int,
|
|
||||||
create_by NCHAR(100),
|
|
||||||
create_time timestamp,
|
|
||||||
remark NCHAR(1000),
|
|
||||||
);
|
|
||||||
</update>
|
|
||||||
|
|
||||||
<update id="createTable">
|
<update id="createTable">
|
||||||
create stable if not exists ${tableName}
|
create stable if not exists ${tableName}
|
||||||
(ts timestamp,
|
(ts timestamp,
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
<!DOCTYPE mapper
|
<!DOCTYPE mapper
|
||||||
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
||||||
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||||
<mapper namespace="com.ruoyi.iot.tdengine.mapper.TDDeviceLogMapper">
|
<mapper namespace="com.ruoyi.iot.tdengine.dao.TDDeviceLogDAO">
|
||||||
|
|
||||||
<resultMap id="BaseResultMap" type="com.ruoyi.iot.domain.DeviceLog">
|
<resultMap id="BaseResultMap" type="com.ruoyi.iot.domain.DeviceLog">
|
||||||
<id column="ts" property="ts"/>
|
<id column="ts" property="ts"/>
|
||||||
|
|||||||
Reference in New Issue
Block a user