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