Bash脚本,用于查询时间范围可变的数据库

问题描述

我正在尝试编写一个bash脚本来查询InfluxDB数据库。

查询如下:

select * INTO telegraf.aggregated_1m.net FROM telegraf_agregat_bak.aggregat_1m_bak.net WHERE time > '2020-03-17T13:00' AND time <= '2020-03-20T13:00' GROUP BY *

我想每15分钟运行一次,我可以使用sleep命令来运行它。问题是,每次脚本运行时,我都需要更改查询中的时间范围。因此,如果您得到我:D

,则查询中的时间范围将不同
#!/bin/bash
while true
do
   now="$(date +%s%3N)"
   number="$((1 + RANDOM % 10))"
   echo "Welcome $i times. $number"
   curl -G -XPOST 'http://localhost:8086/query?pretty=true' --data-urlencode "db=telegraf_agregat_bak" --data-urlencode "q= SELECT * INTO telegraf.aggregated_1m.net FROM telegraf_agregat_bak.aggregat_1m_bak.net WHERE time > '2020-03-17' AND time <= '2020-03-20' GROUP BY *"
   sleep 15m
done

感谢您对该主题的任何建议!

解决方法

您可以在bash中使用变量:

...
sleep "$1"
...

并使用如下脚本:

$ ./script.sh 15m

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...