VictoriaMetrics时序数据库(TSDB)的使用

1:通过docker拉去镜像,设置挂载路径,设置数据保存天数,设置http数据接收端口,如下直接运行即可

bash 复制代码
docker run -d -p 4242:4242 -p 8428:8428  -v /opt/victoria:/victoria-metrics-data --name victoria victoriametrics/victoria-metrics:latest --opentsdbHTTPListenAddr=:4242 --retentionPeriod=36d

也可以设置文件的读写权重

bash 复制代码
docker run -d -p 4242:4242 -p 8428:8428  -v /opt/victoria:/victoria-metrics-data:rw --name victoria victoriametrics/victoria-metrics:latest --opentsdbHTTPListenAddr=:4242 --retentionPeriod=36d

2:发送数据到tsdb

2-1:windows环境下

bash 复制代码
curl -H "Content-Type: application/json" -d "{\"metric\":\"x.y.z\",\"value\":45.34,\"tags\":{\"t1\":\"v1\",\"t2\":\"v2\"}}" http://localhost:4242/api/put

2-2:linux环境下

bash 复制代码
curl -H 'Content-Type: application/json' -d '{"metric":"x.y.z","value":45.34,"tags":{"t1":"v1","t2":"v2"}}' http://localhost:4242/api/put

3:查询tsdb的数据

bash 复制代码
GET | POST http://localhost:8428/api/v1/query?query=...&time=...&step=...
bash 复制代码
GET | POST http://localhost:8428/api/v1/query_range?query=...&start=...&end=...&step=...

查询延迟

默认情况下,Victoria Metrics 不会立即返回最近写入的样本。-search.latencyOffset相反,它检索在命令行标志指定的时间之前写入的最后结果,该时间的默认偏移量为 30 秒。query对于和来说都是如此,query_range并且可能会给人这样的印象:数据写入 VM 时有 30 秒的延迟

此标志可防止由于在最后的抓取间隔中仅抓取部分值而导致不一致的结果

3:设置账号密码登录vmui与推送与查询使用账号密码

bash 复制代码
docker run -d -p 4242:4242 -p 8428:8428  -v C:/victoria:/victoria-metrics-data --name victoria victoriametrics/victoria-metrics:latest --opentsdbHTTPListenAddr=:4242 --retentionPeriod=36d  --httpAuth.username=admin -httpAuth.password=123456

3-1:使用基础java类推送数据

java 复制代码
	public static void main2(String[] args) {
        String url = "http://localhost:4242/api/put";
        String username = "admin";
        String password = "123456";

        // 构建请求JSON数据
        String jsonData = "{\"metric\":\"point\",\"value\":45.34,\"tags\":{\"t1\":\"v1\",\"t2\":\"v2\"}}";

        try {
            URL obj = new URL(url);
            HttpURLConnection conn = (HttpURLConnection) obj.openConnection();

            // 设置请求方法为 POST
            conn.setRequestMethod("POST");

            // 设置基本身份验证信息
            String auth = username + ":" + password;
            byte[] encodedAuth = java.util.Base64.getEncoder().encode(auth.getBytes(StandardCharsets.UTF_8));
            String authHeaderValue = "Basic " + new String(encodedAuth);
            conn.setRequestProperty("Authorization", authHeaderValue);

            // 设置请求头为 JSON 格式
            conn.setRequestProperty("Content-Type", "application/json");

            // 启用输出流,并写入请求体数据
            conn.setDoOutput(true);
            OutputStream os = conn.getOutputStream();
            os.write(jsonData.getBytes(StandardCharsets.UTF_8));
            os.flush();
            os.close();

            // 获取响应
            int responseCode = conn.getResponseCode();
            BufferedReader in = new BufferedReader(new InputStreamReader(conn.getInputStream()));
            String inputLine;
            StringBuilder response = new StringBuilder();
            while ((inputLine = in.readLine()) != null) {
                response.append(inputLine);
            }
            in.close();

            // 输出响应结果
            System.out.println("Response Code: " + responseCode);
            System.out.println("Response Body: " + response.toString());
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

3-2:使用hutool工具集推送数据

java 复制代码
    public static void main(String[] args) {
        String url = "http://localhost:4242/api/put";
        String username = "admin";
        String password = "123456";

        // 构建请求JSON数据
        String jsonData = "{\"metric\":\"point\",\"value\":40.34,\"tags\":{\"t1\":\"v1\",\"t2\":\"v2\"}}";

        // 发送POST请求
        HttpResponse response = HttpRequest.post(url)
                .basicAuth(username, password)
                .body(jsonData)
                .header("Content-Type", "application/json")
                .execute();

        // 获取响应
        int statusCode = response.getStatus();
        String responseBody = response.body();

        // 输出响应结果
        System.out.println("Response Code: " + statusCode);
        System.out.println("Response Body: " + responseBody);
    }
xml 复制代码
<dependency>
    <groupId>cn.hutool</groupId>
    <artifactId>hutool-http</artifactId>
    <version>5.7.6</version>
</dependency>
相关推荐
m0_550024632 分钟前
持续集成/持续部署(CI/CD) for Python
jvm·数据库·python
AC赳赳老秦3 分钟前
代码生成超越 GPT-4:DeepSeek-V4 编程任务实战与 2026 开发者效率提升指南
数据库·数据仓库·人工智能·科技·rabbitmq·memcache·deepseek
啦啦啦_999916 分钟前
Redis-2-queryFormat()方法
数据库·redis·缓存
玄同7651 小时前
SQLite + LLM:大模型应用落地的轻量级数据存储方案
jvm·数据库·人工智能·python·语言模型·sqlite·知识图谱
吾日三省吾码1 小时前
别只会“加索引”了!这 3 个 PostgreSQL 反常识优化,能把性能和成本一起打下来
数据库·postgresql
chian-ocean1 小时前
百万级图文检索实战:`ops-transformer` + 向量数据库构建语义搜索引擎
数据库·搜索引擎·transformer
小Tomkk1 小时前
数据库 变更和版本控制管理工具 --Bytebase 安装部署(linux 安装篇)
linux·运维·数据库·ci/cd·bytebase
qq_12498707532 小时前
基于JavaWeb的大学生房屋租赁系统(源码+论文+部署+安装)
java·数据库·人工智能·spring boot·计算机视觉·毕业设计·计算机毕业设计
倒流时光三十年2 小时前
SpringBoot 数据库同步 Elasticsearch 性能优化
数据库·spring boot·elasticsearch
码农小卡拉3 小时前
深入解析Spring Boot文件加载顺序与加载方式
java·数据库·spring boot