Python工具箱系列(三十三)

2025-12-13 0 477

Timescaledb

在物联网时代,出现了大量以时间为中心海量产生的传感器数据,称为时序数据。这类数据的特点是:

  • 数据记录总有一个时间戳。
  • 数据几乎总是追加,不更新也不删除。
  • 大量使用近期的数据。很少更新或者回填时间间隔的缺失数据。
  • 与时间间隔频率关系不大。但累积的数据量大,可能会有峰值。
  • 对这类数据有多种聚合查询的需求,并且越快越好。例如,截止到目前为止,最大值/最小值/平均值是多少,数据流速是多少等。

为此,IT界兴起了时序数据库。TimeScaleDB是其中的佼佼者,截止到2022年7月,它的排名在第5名,值得使用。由于TimeScaleDB是postgresql的一个插件,因此非常便于安装与使用。同时,它也是一个开源的时间序列数据库,为快速获取和复杂查询进行了优化。此外,它也是多模型设计,在体现与时序数据相关的特性外,它执行的是“完整的SQL”,程序员很容易使用与管理它。

它的安装不复杂。使用以下命令在ubuntu bionic下安装单机版本。

apt install -y gnupg postgresql-common apt-transport-https lsb-release wget
/usr/share/postgresql-common/pgdg/apt.postgresql.org.sh
echo \"deb https://packagecloud.io/timescale/timescaledb/ubuntu/ $(lsb_release -c -s) main\" > /etc/apt/sources.list.d/timescaledb.list
wget --quiet -O - https://packagecloud.io/timescale/timescaledb/gpgkey | apt-key add -
apt update
apt install -y timescaledb-2-postgresql-14
# 做一个调整
timescaledb-tune --quiet --yes
# 重新启动数据库服务
systemctl restart postgresql

# 以postgres用户启动命令行
su postgres -c psql

# 在psql命令行环境中。输入以下命令,从而关联到timescaledb这个扩展上。
CREATE database sensordb;
\\c sensordb
CREATE EXTENSION IF NOT EXISTS timescaledb;
\\q

# 再次连接
su postgres -c \'psql -d sensordb\'
# 显示扩展列表(extensions)
\\dx

创建时序相关得表

在sensordb下创建测试用的表,这个创建的过程有些特殊。相关命令如下:

# 传感器表,传统的表
CREATE TABLE sensors(
 id SERIAL PRIMARY KEY,
 type VARCHAR(50),
 location VARCHAR(50)
);

# 传感器数据库,这个将转换成为超表
CREATE TABLE sensor_data (
 time TIMESTAMP NOT NULL,
 sensor_id INTEGER,
 pm25 DOUBLE PRECISION,
 temperature DOUBLE PRECISION,
 FOREIGN KEY (sensor_id) REFERENCES sensors (id)
);

# CREATE EXTENSION IF NOT EXISTS timescaledb;

# 转换为超表
SELECT create_hypertable(\'sensor_data\', \'time\');

# 生成4个传感器
INSERT INTO sensors (type, location) VALUES
(\'a\',\'地板\'),
(\'a\', \'天花板\'),
(\'b\',\'地板\'),
(\'b\', \'天花板\');

# 测试一下。
select * from sensors;

接下来,使用python连接时序数据库,并且模拟相关的数据插入到表中。

使用Python模拟数据

import psycopg2
import random
import datetime

# 事先创建后数据库demodb
demodb = psycopg2.connect(database=\"sensordb\", user=\"postgres\",
             password=\"88488848\", host=\"172.17.2.151\", port=\"5432\")

democur = demodb.cursor()

currenttime = datetime.datetime.now()

# 插入模拟出来的数据。
for _ in range(100000):
  currenttime = currenttime+datetime.timedelta(seconds=1)
  for id in range(1,5,1):
    pm25 = random.uniform(0, 300)
    temp = random.uniform(0, 40)
    insertsql = f\'\'\'insert into sensor_data(sensor_id,pm25,temperature,time) values({id},{pm25},{temp},\'{currenttime}\')\'\'\'
    democur.execute(insertsql)
  demodb.commit()

democur.close()
demodb.close()  

这里插入10万秒的数据,相当于100000/86400=1.15(天)的数据。在插入数据的同时,就可以同时在数据库中进行按30分钟的分桶查询,这是时序数据库的一个特殊功能。

# su postgres -c \'psql -d sensordb\'

SELECT
 time_bucket(\'30 minutes\', time) AS period,
 AVG(temperature) AS avg_temp,
 last(temperature, time) AS last_temp,
 AVG(pm25) AS avg_pm25
FROM sensor_data
GROUP BY period;

SELECT
 time_bucket(\'60 minutes\', time) AS period,
 AVG(temperature) AS avg_temp,
 last(temperature, time) AS last_temp,
 AVG(pm25) AS avg_pm25
FROM sensor_data
GROUP BY period;

此时,按30分钟时间窗口聚会的数据查询效果如下图所示:

Python工具箱系列(三十三)

<img src=\"data:image/svg+xml;utf8,\” class=\”origin_image zh-lightbox-thumb lazy\” width=\”613\” />

可以看出,TimeScaleDB已经将数据按30分钟来聚合分析。当然,改成任意时间也是可以的,例如,可以改成5秒分析一次也可以,生成结果的时间也非常快。

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

申明:本文由第三方发布,内容仅代表作者观点,与本网站无关。对本文以及其中全部或者部分内容的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。本网发布或转载文章出于传递更多信息之目的,并不意味着赞同其观点或证实其描述,也不代表本网对其真实性负责。

左子网 编程相关 Python工具箱系列(三十三) https://www.zuozi.net/36275.html

常见问题
  • 1、自动:拍下后,点击(下载)链接即可下载;2、手动:拍下后,联系卖家发放即可或者联系官方找开发者发货。
查看详情
  • 1、源码默认交易周期:手动发货商品为1-3天,并且用户付款金额将会进入平台担保直到交易完成或者3-7天即可发放,如遇纠纷无限期延长收款金额直至纠纷解决或者退款!;
查看详情
  • 1、描述:源码描述(含标题)与实际源码不一致的(例:货不对板); 2、演示:有演示站时,与实际源码小于95%一致的(但描述中有”不保证完全一样、有变化的可能性”类似显著声明的除外); 3、发货:不发货可无理由退款; 4、安装:免费提供安装服务的源码但卖家不履行的; 5、收费:价格虚标,额外收取其他费用的(但描述中有显著声明或双方交易前有商定的除外); 6、其他:如质量方面的硬性常规问题BUG等。 注:经核实符合上述任一,均支持退款,但卖家予以积极解决问题则除外。
查看详情
  • 1、左子会对双方交易的过程及交易商品的快照进行永久存档,以确保交易的真实、有效、安全! 2、左子无法对如“永久包更新”、“永久技术支持”等类似交易之后的商家承诺做担保,请买家自行鉴别; 3、在源码同时有网站演示与图片演示,且站演与图演不一致时,默认按图演作为纠纷评判依据(特别声明或有商定除外); 4、在没有”无任何正当退款依据”的前提下,商品写有”一旦售出,概不支持退款”等类似的声明,视为无效声明; 5、在未拍下前,双方在QQ上所商定的交易内容,亦可成为纠纷评判依据(商定与描述冲突时,商定为准); 6、因聊天记录可作为纠纷评判依据,故双方联系时,只与对方在左子上所留的QQ、手机号沟通,以防对方不承认自我承诺。 7、虽然交易产生纠纷的几率很小,但一定要保留如聊天记录、手机短信等这样的重要信息,以防产生纠纷时便于左子介入快速处理。
查看详情

相关文章

猜你喜欢
发表评论
暂无评论
官方客服团队

为您解决烦忧 - 24小时在线 专业服务