问题描述
我正在尝试编写一个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