ThingsBoard初始化数据库Postgres+Cassandra

本章将介绍ThingsBoard初始化数据Postgres+Cassandra,两种数据库结合使用,以及源码的编译安装。本机环境:Centos7、Docker、Postgres、Cassandra

环境安装

开发环境要求:

  1. docker ;
  2. Docker;
  3. Postgres:
  4. Cassandra

 Postgres数据库的安装以及使用,可查看👇文章

https://xulushi.blog.csdn.net/article/details/136784786?spm=1001.2014.3001.5502icon-default.png?t=N7T8https://xulushi.blog.csdn.net/article/details/136784786?spm=1001.2014.3001.5502

1、使用Docker创建Cassandra容器化创建
docker run -p 9042:9042 --name cassandra  -e CASSANDRA_USERNAME=cassandra -e CASSANDRA_PASSWORD=cassandra  -d cassandra:lastest

docker run  :运行容器

name :容器到名称为cassandra

-e CASSANDRA_USERNAME=cassandra  :数据库账号

-e CASSANDRA_PASSWORD=cassandra :数据库密码
9042:9042 :将容器的9042端口映射到主机9042上
-d :程序后台执行

cassandra:lastest cassandra最新版本号

docker logs postgres
 2、使用DBeaverEE链接数据库,(你们也可以用你们自己的根据自己情况)
填入:服务器地址+端口+账号+密码

测试连接是否正常

3、将初始化数据库工程,移动到对应的目录下

4、打开application目录下的thingsboard.yml,更改datasource链接地址 

localhost:修改成你们自己的地址以及数据库名称

username:Cassandra数据库用户名

password:Cassandra数据库密码

cassandra:# Thingsboard cluster namecluster_name: "${CASSANDRA_CLUSTER_NAME:Thingsboard Cluster}"# Thingsboard keyspace namekeyspace_name: "${CASSANDRA_KEYSPACE_NAME:thingsboard}"# Specify node listurl: "${CASSANDRA_URL:47.104.235.15:9042}"# Specify the local data center namelocal_datacenter: "${CASSANDRA_LOCAL_DATACENTER:datacenter1}"ssl:# Enable/disable secure connectionenabled: "${CASSANDRA_USE_SSL:false}"# Enable/disable validation of Cassandra server hostname# If enabled, the hostname of the Cassandra server must match the CN of the server certificatehostname_validation: "${CASSANDRA_SSL_HOSTNAME_VALIDATION:true}"# Set trust store for client authentication of the server (optional, uses trust store from default SSLContext if not set)trust_store: "${CASSANDRA_SSL_TRUST_STORE:}"# The password for Cassandra trust store keytrust_store_password: "${CASSANDRA_SSL_TRUST_STORE_PASSWORD:}"# Set key store for server authentication of the client (optional, uses key store from default SSLContext if not set)# A key store is only needed if the Cassandra server requires client authenticationkey_store: "${CASSANDRA_SSL_KEY_STORE:}"# The password for the Cassandra key storekey_store_password: "${CASSANDRA_SSL_KEY_STORE_PASSWORD:}"# Comma-separated list of cipher suites (optional, uses Java default cipher suites if not set)cipher_suites: "${CASSANDRA_SSL_CIPHER_SUITES:}"# Enable/disable JMXjmx: "${CASSANDRA_USE_JMX:false}"# Enable/disable metrics collection.metrics: "${CASSANDRA_USE_METRICS:false}"# NONE SNAPPY LZ4compression: "${CASSANDRA_COMPRESSION:none}"# Specify cassandra cluster initialization timeout in milliseconds (if no hosts are available during startup)init_timeout_ms: "${CASSANDRA_CLUSTER_INIT_TIMEOUT_MS:300000}"# Specify cassandra cluster initialization retry interval (if no hosts available during startup)init_retry_interval_ms: "${CASSANDRA_CLUSTER_INIT_RETRY_INTERVAL_MS:3000}"# Cassandra max local requests per connectionmax_requests_per_connection_local: "${CASSANDRA_MAX_REQUESTS_PER_CONNECTION_LOCAL:32768}"# Cassandra max remote requests per connectionmax_requests_per_connection_remote: "${CASSANDRA_MAX_REQUESTS_PER_CONNECTION_REMOTE:32768}"# Credential parameterscredentials: "${CASSANDRA_USE_CREDENTIALS:false}"# Specify your usernameusername: "${CASSANDRA_USERNAME:cassandra}"# Specify your passwordpassword: "${CASSANDRA_PASSWORD:cassandra}"# Astra DB connect https://astra.datastax.com/

将遥测数据以及最新数据存放入cassandra中,来较少DB数据库的压力,当在生产环境的情况下,如果说遥测数据未存放到cassandra中,就会给DB造成巨大的压力

# Database telemetry parameters
database:ts_max_intervals: "${DATABASE_TS_MAX_INTERVALS:700}" # Max number of DB queries generated by a single API call to fetch telemetry recordsts:type: "${DATABASE_TS_TYPE:cassandra}" # cassandra, sql, or timescale (for hybrid mode, DATABASE_TS_TYPE value should be cassandra, or timescale)ts_latest:type: "${DATABASE_TS_LATEST_TYPE:cassandra}" # cassandra, sql, or timescale (for hybrid mode, DATABASE_TS_TYPE value should be cassandra, or timescale)
5、 初始化数据库

完成后分别查看cassandra和postgres数据库的表结构是否都创建成功

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/763980.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Django日志(一)

一、概念与配置 1.1、概述 日志是程序员经常在代码中使用快速和方便的调试工具。它在调试方面比print更加的优雅和灵活 而且日志记录对于调试很有用,可以提供更多,更好的结构化,有关应用程序的状态和运行状况的信息 Django框架的日志通过python内置的logging模块实现的,可…

基于Gabor滤波器的指纹图像识别,Matlab实现

博主简介: 专注、专一于Matlab图像处理学习、交流,matlab图像代码代做/项目合作可以联系(QQ:3249726188) 个人主页:Matlab_ImagePro-CSDN博客 原则:代码均由本人编写完成,非中介,提供…

2024年【山东省安全员C证】考试试卷及山东省安全员C证复审模拟考试

题库来源:安全生产模拟考试一点通公众号小程序 山东省安全员C证考试试卷是安全生产模拟考试一点通生成的,山东省安全员C证证模拟考试题库是根据山东省安全员C证最新版教材汇编出山东省安全员C证仿真模拟考试。2024年【山东省安全员C证】考试试卷及山东省…

【Linux】信号的处理{信号处理的时机/了解寄存器/内核态与用户态/信号操作函数}

文章目录 0.对于信号捕捉的理解1.信号处理的时机1.1 何时处理信号?1.2 内核态和用户态1.3 内核态和用户态的切换 2.了解寄存器3.信号捕捉的原理4.信号操作函数4.1sighandler_t signal(int signum, sighandler_t handler);4.2int sigaction(int signum, const struct…

express+mysql+vue,从零搭建一个商城管理系统15--快递查询(对接快递100)

提示:学习express,搭建管理系统 文章目录 前言一、安装md5,axios二、新建config/logistics.js三、修改routes/order.js四、查询物流信息五、试错与误区总结 前言 需求:主要学习express,所以先写service部分 快递100API…

工业项目中你连DCS系统都没见过?

什么是DCS DCS,即分散控制系统,是一种用于监控和控制工业过程的系统。它通过连接多个控制器、传感器和执行器实现自动化控制,提高生产效率和安全性。在中国,随着工业化和自动化水平的提高,DCS技术得到了广泛应用和快速…

外包干了10天,技术倒退明显

先说情况,大专毕业,18年通过校招进入湖南某软件公司,干了接近6年的功能测试,今年年初,感觉自己不能够在这样下去了,长时间呆在一个舒适的环境会让一个人堕落!而我已经在一个企业干了四年的功能测试&#xf…

SpringMVC 简介及入门级的快速搭建详细步骤

MVC 回顾 MVC,即Model-View-Controller(模型-视图-控制器)设计模式,是一种广泛应用于软件工程中,特别是Web应用开发中的架构模式。它将应用程序分为三个核心组件: Model(模型)&#…

PagePlug多条件查询方案

正确实现 使用Case When来编写查询条件 SELECT * FROM pc_ticket_tax_cloud WHERE 11 AND (CASE WHEN {{data_table.searchText ! }} THEN xsddm like {{data_table.searchText || ""}}%ELSE 11 END ) AND (CASE WHEN {{doc_code_input.text ! }} THEN doc_code li…

Git浅谈配置文件和免密登录

一、文章内容 简述git三种配置ssh免密登录以及遇见的问题git可忽略文件git remote 相关操作 二、Git三种配置 项目配置文件(局部):项目路径/.git/config 文件 git config --local user.name name git config --local user.email 123qq.cc全局配置文(所有用户): …

【Web】记录CISCN 2021 总决赛 ezj4va题目复现——AspectJWeaver

目录 前言 原理分析 step 0 step 1 EXP 前文:【Web】浅聊Java反序列化之AspectJWeaver——任意文件写入-CSDN博客 前言 这就是当年传说中的零解题嘛😭,快做🤮了 有了之前的经验,思路顺挺快的,中间不…

网络基础(一)初识

1、计算机网络背景 1.1、网络发展 1. 独立模式: 计算机之间相互独立; 2. 网络互联: 多台计算机连接在一起,完成数据共享; 3. 局域网LAN: 计算机数量更多了, 通过交换机和路由器连接在一起; 4. 广域网WAN: 将远隔千里的计算机都连在一起;…

【python】python汽车效能数据集—回归建模(源码+数据集)【独一无二】

👉博__主👈:米码收割机 👉技__能👈:C/Python语言 👉公众号👈:测试开发自动化【获取源码商业合作】 👉荣__誉👈:阿里云博客专家博主、5…

yaml 语法和在线解析工具

文章目录 在线解析工具1. 简介2. 语法规则3. 数据类型3.1 数组:3.2对象:3.3 标量3.4 复合结构3.5 锚点3.5.1 单个锚点3.5.6 多个锚点 3.6 引号 参考 在线解析工具 工具1 工具2 1. 简介 Yaml是一种可读性高的数据标记语言,Yaml文件是一种配…

45.i++和++i

目录 一.基本概念 二.区别 三.总结 四.视频教程 一.基本概念 i和i两者的作用都是自增加1。单独使用的话,i和i,效果都是一样的,就是ii1。 int main() {int i 0;i; } int main() {int i 0;i; } 最后的结果都是1。 二.区别 如上单独使…

SpringBoot—@ConditionalOnBean与@ConditionalOnClass

一、ConditionalOnBean概念 需求场景 比如下面一种场景,我在实例化People对象的时候,需要注入一个City对象。这个时候问题来了,如果city没有实例化,那么下面就会报空指针或者直接报错。 所以这里需求很简单,就是当前c…

就业班 第二阶段 2401--3.19 day4 主从复制

一、MySQL-Replication(主从复制) 1.1、MySQL Replication 主从复制(也称 AB 复制)允许将来自一个MySQL数据库服务器(主服务器)的数据复制到一个或多个MySQL数据库服务器(从服务器)…

MySQL面试题--最全面-索引

目录 一、索引 1.MySQL是如何让实现的索引机制? 2.InnoDB索引与MyISAM索引实现的区别是什么? 3.一个表中如果没有创建索引,那么还会创建B树吗? 4.说一下B树索引实现原理(数据结构) 5.聚簇索引与非聚簇…

弱电工程包括哪些工程?

​一、弱电工程的分部有哪些? 分为基础、主体、装饰工程、强电、弱电、消防、暖通、给排水工程,桩基、筏板、模板、钢筋、混凝土、砌体、粉刷、地坪等 二、弱电工程系统包括哪些? 弱电系统包括:闭路电视监控系统、防盗报警系统、门禁系统、电子巡更…

[小程序开发] 分包加载

一、介绍 分包加载是一种小程序的优化技术,将小程序不同功能的代码,分别打包成不同的子包,在构建时打包成不同的分包,用户在使用时按需进行加载,在构建小程序分包项目时,构建会输出一个或多个分包&#xff…