如何解决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
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。