亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Springboot使用influxDB時(shí)序數(shù)據(jù)庫(kù)的實(shí)現(xiàn)

瀏覽:98日期:2023-02-19 17:15:38
目錄引入依賴配置構(gòu)建實(shí)體類保存數(shù)據(jù)查詢數(shù)據(jù)

項(xiàng)目中需要存放大量設(shè)備日志,且需要對(duì)其進(jìn)行簡(jiǎn)單的數(shù)據(jù)分析,信息提取工作.

結(jié)合眾多考量因素,項(xiàng)目決定使用時(shí)序數(shù)據(jù)庫(kù)中的領(lǐng)頭羊InfluxDB.

引入依賴

項(xiàng)目中使用influxdb-java,在pom文件中添加如下依賴(github地址:https://github.com/influxdata/influxdb-java):

<dependency><groupId>org.influxdb</groupId><artifactId>influxdb-java</artifactId><version>2.15</version> </dependency>

application.yaml文件配置如下所示(請(qǐng)按照實(shí)際情況填寫):

spring: influx: url: * password: admin user: 123 database: log_management配置

(1) 創(chuàng)建配置類

@Configurationpublic class InfluxDbConfig { @Value('${spring.influx.url:’’}') private String influxDBUrl; @Value('${spring.influx.user:’’}') private String userName; @Value('${spring.influx.password:’’}') private String password; @Value('${spring.influx.database:’’}') private String database; @Bean public InfluxDbUtils influxDbUtils() {return new InfluxDbUtils(userName, password, influxDBUrl, database, ''); }}

@Data public class InfluxDbUtils { private String userName; private String password; private String url; public String database; private String retentionPolicy; // InfluxDB實(shí)例 private InfluxDB influxDB; // 數(shù)據(jù)保存策略 public static String policyNamePix = 'logRetentionPolicy_'; public InfluxDbUtils(String userName, String password, String url, String database, String retentionPolicy) {this.userName = userName;this.password = password;this.url = url;this.database = database;this.retentionPolicy = retentionPolicy == null || ''.equals(retentionPolicy) ? 'autogen' : retentionPolicy;this.influxDB = influxDbBuild(); } /** * 連接數(shù)據(jù)庫(kù) ,若不存在則創(chuàng)建 * * @return influxDb實(shí)例 */ private InfluxDB influxDbBuild() {if (influxDB == null) { influxDB = InfluxDBFactory.connect(url, userName, password);}try { createDB(database); influxDB.setDatabase(database);} catch (Exception e) { log.error('create influx db failed, error: {}', e.getMessage());} finally { influxDB.setRetentionPolicy(retentionPolicy);}influxDB.setLogLevel(InfluxDB.LogLevel.BASIC);return influxDB; } }構(gòu)建實(shí)體類

InfluxDB中,measurement對(duì)應(yīng)于傳統(tǒng)關(guān)系型數(shù)據(jù)庫(kù)中的table(database為配置文件中的log_management).InfluxDB里存儲(chǔ)的數(shù)據(jù)稱為時(shí)間序列數(shù)據(jù),時(shí)序數(shù)據(jù)有零個(gè)或多個(gè)數(shù)據(jù)點(diǎn).數(shù)據(jù)點(diǎn)包括time(一個(gè)時(shí)間戳),measurement(例如logInfo),零個(gè)或多個(gè)tag,其對(duì)應(yīng)于level,module,device_id),至少一個(gè)field(即日志內(nèi)容,msg=something error).InfluxDB會(huì)根據(jù)tag數(shù)值建立時(shí)間序列(因此tag數(shù)值不能選取諸如UUID作為特征值,易導(dǎo)致時(shí)間序列過(guò)多,導(dǎo)致InfluxDB崩潰),并建立相應(yīng)索引,以便優(yōu)化諸如查詢速度.

@Builder@Data@Measurement(name = 'logInfo')public class LogInfo { // Column中的name為measurement中的列名 // 此外,需要注意InfluxDB中時(shí)間戳均是以UTC時(shí)保存,在保存以及提取過(guò)程中需要注意時(shí)區(qū)轉(zhuǎn)換 @Column(name = 'time') private String time; // 注解中添加tag = true,表示當(dāng)前字段內(nèi)容為tag內(nèi)容 @Column(name = 'module', tag = true) private String module; @Column(name = 'level', tag = true) private String level; @Column(name = 'device_id', tag = true) private String deviceId; @Column(name = 'msg') private String msg;}保存數(shù)據(jù)

以下代碼為單條日志保存,influxdb-java亦支持批量保存(因?yàn)榕cInfluxDB通訊均是通過(guò)http,因此建議批量保存以減少性能損耗).

LogInfo logInfo = LogInfo.builder().level(jsonObject.getString('level')).module(module).deviceId(deviceId).msg(jsonObject.getString('msg')).build(); Point point = Point.measurementByPOJO(logInfo.getClass()).addFieldsFromPOJO(logInfo).time(jsonObject.getLong('time'), TimeUnit.MILLISECONDS).build(); // 出于業(yè)務(wù)考量,設(shè)備可以設(shè)置不同的保存策略(策略名為固定前綴+設(shè)備ID) influxDB.write(influxDBUtils.database, InfluxDbUtils.policyNamePix + deviceId, point);查詢數(shù)據(jù)

因?yàn)榇a與業(yè)務(wù)耦合比較厲害,因此此處僅截選做概要示范.

// InfluxDB支持分頁(yè)查詢,因此可以設(shè)置分頁(yè)查詢條件 String pageQuery = ' LIMIT ' + request.getPageSize() + ' OFFSET ' + ((request.getPageNum() - 1) * request.getPageSize()); // 此處查詢所有內(nèi)容,如果 String queryCmd = 'SELECT * FROM '// 查詢指定設(shè)備下的日志信息// 要指定從 RetentionPolicyName(保存策略前綴+設(shè)備ID).measurement(logInfo) 中查詢指定數(shù)據(jù))+ InfluxDbUtils.policyNamePix + request.getDeviceId() + '.' + 'logInfo'// 添加查詢條件(注意查詢條件選擇tag值,選擇field數(shù)值會(huì)嚴(yán)重拖慢查詢速度)+ queryCondition// 查詢結(jié)果需要按照時(shí)間排序+ ' ORDER BY time DESC'// 添加分頁(yè)查詢條件+ pageQuery;

選擇時(shí)序數(shù)據(jù)庫(kù),不建議使用刪除以及更新操作,因此不做介紹.

可以通過(guò)創(chuàng)建或者RetentionPolicy,來(lái)添加或者更新數(shù)據(jù)的刪除時(shí)間.

到此這篇關(guān)于Springboot使用influxDB時(shí)序數(shù)據(jù)庫(kù)的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Springboot使用influxDB內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 国产精品黄页网站在线播放免费 | 国产免费大片 | 免费国产人做人视频在线观看 | 精品一区二区三区色花堂 | 国产身材极品喷水 在线播放 | 草草影院欧美 | 国产免费一区不卡在线 | 日韩在线视频不卡一区二区三区 | 亚洲国产精品专区 | 2022国内精品免费福利视频 | 色老头xxxwww作爱视频 | 啪啪中文字幕 | 国产精品免费aⅴ片在线观看 | 免费成人| zoofilia杂交videos新另类 | 99自拍视频在线观看 | 国产高清视频在线播放 | 中文字幕日本精品一区二区三区 | 中文字幕成人 | 国产精品免费看久久久久 | 日本精品久久久中文字幕 | 91国偷自产一区二区三区蜜臀 | 99久久综合狠狠综合久久一区 | 免费网站观看 | 国产成人一区二区三区高清 | a毛片免费播放全部完整 | 一区二区三区在线观看免费 | 中日韩一级片 | www.国产一区二区三区 | 激情在线日韩视频免费 | 国产精品麻豆入口 | 久操香蕉| 国产精品久久久久久久毛片 | 欧美电影精品久久久久 | 欧美精品v日韩精品v国产精品 | 国产精品区网红主播在线观看 | 91草草| 色婷婷久| 福利片视频区 | 日本v片免费一区二区三区 日本wwwwwxxxxx | 欧美亚洲午夜 |