网易首页 > 网易号 > 正文 申请入驻

VictoriaLogs 和 Vector 的使用分享

0
分享至


新钛云服已累计为您分享891篇技术干货


PART.01

victoriaLogs 介绍与对比

victoriaLogs 是什么

VictoriaLogs是 VictoriaMetrics 体系里的日志数据库,目标是把“写入吞吐、存储成本、查询效率、运维复杂度”这四个维度做到更均衡:一个服务就能跑起来,HTTP 端口默认9428,常见的采集侧(Vector / FluentBit / Filebeat 等)可以直接对接它的写入 API。

核心数据模型


  • 消息字段:_msg

  • 时间字段:_time

  • 流字段(stream fields) :决定日志如何被分组与存储(类似 Loki 的 labels,但语义更贴近“分流/分桶”)


并且在写入时,你可以通过 query 参数/headers 显式指定:


  • _msg_field:哪一个字段是日志正文

  • _time_field:哪一个字段是时间戳

  • _stream_fields:哪些字段作为 stream fields


stream fields 不要高基数

stream fields 必须“稳定、低基数,比如 host / instance / pod / container / service / env 这种。把 trace_id / user_id / ip 之类高基数放进去,会制造海量 streams,显著增加资源消耗与查询成本。

这点后面会直接影响我们怎么设计 labels/fields(尤其是 filepath)。

什么时候更适合用 victoriaLogs?


  • vs Elasticsearch / OpenSearch

  • ES 强在生态与全文检索、聚合分析,但运维与成本通常更重(集群、shard、mapping、冷热分层、性能调优)。

  • VictoriaLogs 更像“把日志存起来并快速检索/聚合”,强调更简单的落地与更好的性价比(尤其是规模上来之后)。



  • vs Grafana Loki

  • Loki 是 label + chunk,label 设计同样要避免高基数。

  • VictoriaLogs 的 stream fields 也怕高基数,但它把“message/time/stream”的概念讲得更清晰,且写入 API 的兼容面(如 ES bulk / jsonline)让你更容易接入。


PART.02

VictoriaLogs 的搭建

Docker 方式启动

  -storageDataPath=victoria-logs-data


  • -storageDataPath:数据目录(默认 victoria-logs-data)

  • -httpListenAddr:默认 :9428

  • -retentionPeriod:日志保留期,默认 1w(按需改)


验证查询(LogsQL)

起服务后,可以用 /select/logsql/query 直接查:

  -d 'query=error' -d 'limit=10'

这会返回包含 error 的最新 10 条。

你后续常用的 LogsQL 习惯是:


  • 时间范围:_time:5m / _time:1h / _time:1d

  • 排除词:-kubernetes

  • 排序:| sort by (_time)

  • 取最新 N 条:| first 10 by (_time desc)


PART.03

Vector 介绍与对比

Vector 是什么

Vector是一个高性能的可观测数据管道:把 logs/metrics/traces 从各种 source 收进来,经过 transform(核心是 VRL),再发往各种 sink。它本质是一个单一可执行文件,部署和运维路径很“平台友好”。

我们本文会用到:


  • sources

  • journald:从 systemd journal 读日志(需要权限)

  • file:tail 文件日志(带 checkpoint)



  • transform

  • remap:用 VRL 做字段清洗/补齐/路由(但也是坑最多的部分)



  • sink

  • elasticsearch:发往 VictoriaLogs 的 /insert/elasticsearch/(官方推荐路径之一)


Vector vs Fluent Bit / Fluentd / Logstash / OTel Collector


  • vs Fluent Bit

  • Fluent Bit 更“采集器”,轻量、插件多,但复杂变换要么写 Lua,要么链路拆很多 filter。

  • Vector 的强项是VRL:写得好非常强,写得不好非常痛苦。



  • vs Fluentd / Logstash

  • Fluentd/Logstash 生态成熟,但运行时更重(Ruby/JVM)。

  • Vector 更偏“一个 Rust binary 的工程化组件”。



  • vs OpenTelemetry Collector

  • OTel Collector 适合统一 traces/metrics/logs,但日志处理表达力与生态取舍和 Vector 不同。

  • 你可以理解为:Vector 更像“日志/可观测数据路由器 + 可编程 transform


PART.04

Vector 的搭建

安装(Linux 常见方式)

官方提供安装脚本/包管理方式(不同发行版略有差异)。

安装后默认配置路径通常是:


  • /etc/vector/vector.yaml


基础运维命令


  • 校验配置:


vector validate /etc/vector/vector.yaml

(强烈建议每次改配置先跑它)


  • systemd 管理(包安装通常自带 service):


journalctl -u vector -f

Vector 也支持通过信号触发 reload 的方式(具体以你的部署方式为准)。

PART.05

Vector 的注意事项

fail-safe + fallible

VRL 是fail-safe的——只要存在潜在运行时错误没被处理,编译期就不让你过。这在日志这种“脏数据”有优势,但会显著抬高配置难度。

建议把 VRL 流程固定成下面 3 种:


  1. 能不用 fallible 函数就不用:优先用 exists() / is_nullish() 这类 infallible 的逻辑兜底。

  2. 本地 REPL:vector vrl 可以进交互 REPL,先把片段跑通再放进配置。

  3. Playground:VRL Playground 适合分享/对照输入输出


可选加速:打开 API 后用 `vector tap` 抽样观察某个组件的事件流,定位字段长什么样。

journald 的 include\_units / exclude\_units


  • journald source 默认要能执行 journalctl,且运行用户通常需要在 systemd-journal 组里。

  • include_units 的规则里,“没带点号的 unit 会自动补 .service”。


labels / stream fields 设计——尤其是 filepath

这里要区分两个概念:


  • Vector 里你随便加字段(比如 filepath),这是为了后续查询过滤更方便。

  • VictoriaLogs 的_stream_fields是“用来分组存储的关键字段”,不能高基数


建议


  • filepath:只做普通字段,不要进_stream_fields(k8s/nomad 场景会爆炸式增长)。

  • 额外做一个低基数的 file_group(或 app/component):

  • 例如把 /var/log/nginx/access.log、/var/log/nginx/error.log 归到 file_group=nginx

  • 把 /var/log/myapp/*.log 归到 file_group=myapp

  • stream_fields 推荐起步:host,service,env,source,file_group(再按场景微调)


PART.06

Vector 部署到 Linux

配置步骤

下面介绍 Vector 部署到 Linux,并发送 journald + file 日志到 VictoriaLogs

前置:确保 Vector 能读 journald

sudo systemctl restart vector

/etc/vector/vector.yaml(journald + file → vlogs)

你只需要改两块: 1)file include 路径 2)VictoriaLogs 地址(endpoints)

      # debug: "1"

这份 sink 的写法是 VictoriaLogs 官方“Vector → VictoriaLogs(Elasticsearch 协议)”推荐配置的同款思路:


  • 写入地址:/insert/elasticsearch/

  • _msg_field=message、_time_field=timestamp、_stream_fields=...


也可以用 HTTP jsonline 的方式写入(/insert/jsonline + newline_delimited),官方也给了模板。

启动与验证

1. 校验配置:

vector validate /etc/vector/vector.yaml

2. 重启 Vector:

journalctl -u vector -f

3. 制造两种日志:


  • journald:


logger -t demo "hello from journald"


  • file:


echo "hello from file" >> /var/log/myapp/app.log

4. 在 VictoriaLogs 查:

  -d 'query=hello _time:1h' -d 'limit=20'

LogsQL 里 _time:1h、limit 这类用法是最常用的排障入口。

常见问题


  • 写入侧出现 “missing _msg field”

  • 先确认 sink 里 _msg_field 指向的字段确实存在(本文用 message)

  • 如果你在 remap 里改过字段名,确保最后还有 message

  • VictoriaLogs 对 _msg/_time/_stream 的概念解释在 Key Concepts 里,值得快速扫一遍。


  • stream 爆炸、写入变慢、查询变慢

  • 99% 是 _stream_fields 里塞了高基数字段(最常见就是 filepath / trace_id / user_id)

  • 回到“低基数、稳定”的原则:host/service/env/source/(container/pod) 这类。



  • VRL 写不动

  • 用 vector vrl REPL / Playground 先把局部片段跑通再粘贴进配置。


如有相关问题,请在文章后面给小编留言,小编安排作者第一时间和您联系,为您答疑解惑。

特别声明:以上内容(如有图片或视频亦包括在内)为自媒体平台“网易号”用户上传并发布,本平台仅提供信息存储服务。

Notice: The content above (including the pictures and videos if any) is uploaded and posted by a user of NetEase Hao, which is a social media platform and only provides information storage services.

相关推荐
热点推荐
欧冠2006冠军名单被提前泄露,12年后全中,欧足联至今没吭声

欧冠2006冠军名单被提前泄露,12年后全中,欧足联至今没吭声

篮坛第一线
2026-04-13 14:48:02
网暴全红婵的网民被抓获,身份曝光令人气愤,警方处罚大快人心!

网暴全红婵的网民被抓获,身份曝光令人气愤,警方处罚大快人心!

古希腊掌管松饼的神
2026-04-10 19:42:22
伊朗伊斯兰革命卫队海军发出警告

伊朗伊斯兰革命卫队海军发出警告

财联社
2026-04-12 22:23:06
马筱梅带娃回京,晒北京美景,穿白色裙子美翻了,张兰力挺儿媳妇

马筱梅带娃回京,晒北京美景,穿白色裙子美翻了,张兰力挺儿媳妇

情感大头说说
2026-04-13 03:03:33
如何优雅地谋杀一座城:陈丽华的推土机与华新民的废纸

如何优雅地谋杀一座城:陈丽华的推土机与华新民的废纸

有戏
2026-04-11 09:21:04
暖心!广州增城蔗农摆23围流水席答谢游客 20余天清空50多亩滞销甘蔗

暖心!广州增城蔗农摆23围流水席答谢游客 20余天清空50多亩滞销甘蔗

朗威谈星座
2026-04-13 14:41:12
昔日“女副部”的黄昏迷局

昔日“女副部”的黄昏迷局

健身狂人
2026-04-13 17:18:40
巴萨官网展望欧冠:挑战与机遇并存,弗里克的巴萨仍缺一场“真正逆转”

巴萨官网展望欧冠:挑战与机遇并存,弗里克的巴萨仍缺一场“真正逆转”

懂球帝
2026-04-13 19:18:04
东施效颦?清湖模仿曼城经营蓝军4年未成功 三关键要素全被忽视

东施效颦?清湖模仿曼城经营蓝军4年未成功 三关键要素全被忽视

雪狼侃体育
2026-04-13 19:40:20
男子取保候审期间为立功,“做局”检举他人酒驾,获轻判次月被发现,最终法院改判,两罪并罚

男子取保候审期间为立功,“做局”检举他人酒驾,获轻判次月被发现,最终法院改判,两罪并罚

极目新闻
2026-04-13 14:33:43
上海市一栋大别墅拍卖,1850万就成交

上海市一栋大别墅拍卖,1850万就成交

天天话事
2026-04-13 16:03:39
美中央司令部:4月13日起封锁伊朗港口海上交通,英国称不参与封锁霍尔木兹海峡

美中央司令部:4月13日起封锁伊朗港口海上交通,英国称不参与封锁霍尔木兹海峡

纵相新闻
2026-04-13 19:00:03
科大讯飞员工买彩票中1500万!知情人士:有中奖但金额不对

科大讯飞员工买彩票中1500万!知情人士:有中奖但金额不对

快科技
2026-04-13 18:24:06
大陆之行结束,郑丽文下飞机后讲出3句话,赖清德终于怕了

大陆之行结束,郑丽文下飞机后讲出3句话,赖清德终于怕了

阿柒的讯
2026-04-13 12:57:04
飞机上,我靠窗的位置被黑人女人占了,她说中国人不配坐靠窗

飞机上,我靠窗的位置被黑人女人占了,她说中国人不配坐靠窗

城事录主
2026-04-13 10:12:00
大陆公布10项对台红利后,蒋万安表态变了,侯友宜应该惭愧了

大陆公布10项对台红利后,蒋万安表态变了,侯友宜应该惭愧了

牛锅巴小钒
2026-04-13 13:30:56
连谈21小时,美伊不欢而散,特朗普:特朗普:中国不许送武器,否则有麻烦

连谈21小时,美伊不欢而散,特朗普:特朗普:中国不许送武器,否则有麻烦

闻识
2026-04-12 13:53:31
德国站队了!正式向世界宣布:以色列若继续打黎巴嫩,会让他好看

德国站队了!正式向世界宣布:以色列若继续打黎巴嫩,会让他好看

Ck的蜜糖
2026-04-13 17:50:08
郑丽文白来了?大陆发布十大惠台措施后,台当局下决心全面封杀

郑丽文白来了?大陆发布十大惠台措施后,台当局下决心全面封杀

一口娱乐
2026-04-13 16:31:55
西安灞河钓鱼爱好者,竟然钓出了巨型大鱼。

西安灞河钓鱼爱好者,竟然钓出了巨型大鱼。

健身狂人
2026-04-13 14:40:54
2026-04-13 19:52:49
新钛云服
新钛云服
云管理服务专家
465文章数 30关注度
往期回顾 全部

科技要闻

"抄作业"近四年,马斯克版微信周五上线

头条要闻

媒体:欧尔班败选不仅是一国之事 牵扯到与中国的关系

头条要闻

媒体:欧尔班败选不仅是一国之事 牵扯到与中国的关系

体育要闻

一支球队不够烂,也是一种悲哀

娱乐要闻

贾玲减重后现身冯巩生日宴 身材未反弹

财经要闻

起底AI"造黄"灰产:19.9元"一键脱衣"

汽车要闻

不止命名更纯粹 领克10/10+要做纯电操控新王

态度原创

艺术
手机
亲子
游戏
军事航空

艺术要闻

22位中国当代名家油画作品

手机要闻

上市一年,华为Pura X阔折叠手机出货量突破150万台

亲子要闻

躺平的孩子迟迟不愿好,是为了满足父母的期待?

索尼重量级大作来了!顽皮狗全新IP首曝 2027年时间定了

军事要闻

特朗普:今晚10点封锁伊朗 对北约非常失望

无障碍浏览 进入关怀版