Filebeat 接收 Syslog ,并进行日志分段,VictoriaLogs 持久化存储日志 ,Grafana 可视化、数据查询、告警、数据导出。
与 Elasticsearch /Grafana Loki 相比几十倍的 CPU/内存/存储资源占用的差距,能极大的节省硬件资源。
VGF 可以实现 ELK 的 Web 查询、日志压缩存储、syslog 日志接收。
VictoriaLogs 兼容支持多种数据输入软件,Filebeat 也支持多种数据输入。
VictoriaLogs 的 Web UI 很简陋,所以要用 Grafana 。
VictoriaLogs 是 HTTP 访问是无认证的,需要套其他软件来实现。(默认端口 9428 )
VictoriaLogs 的数据过期时间是全局的,所以如果有需求,只能部署多个实例。
Filebeat 相对 Logstash 性能更好,也比 VictoriaLogs 自带的 Syslog 输入功能更多。
https://mirror.nju.edu.cn/mirrorz-help/docker-ce/?mirror=NJU
sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
"registry-mirrors": [
"https://dockerproxy.com",
"https://docker.mirrors.ustc.edu.cn",
"https://docker.nju.edu.cn"
]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker
创建 victoria-logs-data 文件夹
docker run -d --restart always \
-p 9428:9428 \
-v ./victoria-logs-data:/victoria-logs-data \
--name victoria-logs-syslog-songxwn.com \
docker.io/victoriametrics/victoria-logs:latest \
--retentionPeriod=365d
# by songxwn.com
9428/tcp 对外 HTTP 访问
数据保留 365 天
./victoria-logs-data 为存储目录
docker run -d --name=grafana -p 3000:3000 \
-e GF_INSTALL_PLUGINS=victoriametrics-logs-datasource \
--name Grafana \
grafana/grafana-enterprise
插件已默认安装,添加对应数据源即可,目标为 http://192.168.1.1:9428
filebeat.inputs:
- type: udp
enabled: true
max_message_size: 10KiB
host: "0.0.0.0:514"
fields:
type: udp
output.elasticsearch:
hosts: ["http://127.0.0.1:9428/insert/elasticsearch/"]
parameters:
_msg_field: "message"
_time_field: "@timestamp"
_stream_fields: "host.hostname"
allow_older_versions: true
PS:注意 127.0.0.1 替换为宿主机 IP.
docker run -d \
--name Filebeat \
--user=root \
--volume="$(pwd)/filebeat.docker.yml:/usr/share/filebeat/filebeat.yml:ro" \
-p 514:514/udp \
docker.elastic.co/beats/filebeat:8.17.2
创建并进入 /opt/VFG 文件夹
mkdir /opt/VFG
cd /opt/VFG
http:
enabled: true
host: "http://0.0.0.0:5066"
filebeat.inputs:
- type: udp
enabled: true
max_message_size: 10KiB
host: "0.0.0.0:514"
fields:
type: udp
output.elasticsearch:
hosts: ["http://syslog-victoria-logs:9428/insert/elasticsearch/"]
parameters:
_msg_field: "message"
_time_field: "@timestamp"
_stream_fields: "host.hostname"
allow_older_versions: true
PS:如果需要字段分割,可以参考如下。增加到输入输出中间即可。
processors:
- dissect:
tokenizer: "<%{syslog_pri}>%{timestamp} %{hostname} %%{log_level}/%{log_code}/%{log_action}(l):IPVer=%{ipver},Protocol=%{protocol},SourceIP=%{source_ip},DestinationIP=%{destination_ip},SourcePort=%{source_port},DestinationPort=%{destination_port},SourceNatIP=%{source_nat_ip},SourceNatPort=%{source_nat_port},BeginTime=%{begin_time},EndTime=%{end_time},S>
field: "message"
target_prefix: "parsed"
mkdir victoria-logs-data
chown -R 472:472 victoria-logs-data
mkdir grafana-data
chown -R 472:472 grafana-data
mkdir -p ./provisioning/datasources
vim ./provisioning/datasources/vm.yml
apiVersion: 1
datasources:
# <string, required> Name of the VictoriaLogs datasource
# displayed in Grafana panels and queries.
- name: VictoriaLogs-songxwn.com
# <string, required> Sets the data source type.
type: victoriametrics-logs-datasource
# <string, required> Sets the access mode, either
# proxy or direct (Server or Browser in the UI).
access: proxy
# <string> Sets URL for sending queries to VictoriaLogs server.
# see https://docs.victoriametrics.com/victorialogs/querying/
url: http://syslog-victoria-logs:9428
# <string> Sets the pre-selected datasource for new panels.
# You can set only one default data source per organization.
isDefault: true
services:
victoria-logs:
image: victoriametrics/victoria-logs:latest
container_name: syslog-victoria-logs
volumes:
- ./victoria-logs-data:/victoria-logs-data
restart: always
command: [
"--retentionPeriod=365d"
]
environment:
- TZ=Asia/Shanghai
healthcheck:
test: ["CMD", "wget", "-q", "--spider", "http://127.0.0.1:9428/health"]
interval: 1m30s
timeout: 10s
retries: 3
grafana:
image: grafana/grafana-enterprise
container_name: syslog-grafana
ports:
- "3000:3000"
environment:
- GF_INSTALL_PLUGINS=victoriametrics-logs-datasource
- GF_SECURITY_ADMIN_PASSWORD=Songxwn.com
- TZ=Asia/Shanghai
volumes:
- ./grafana-data:/var/lib/grafana
- ./provisioning:/etc/grafana/provisioning
restart: always
healthcheck:
test: ["CMD", "curl", "-f", "http://localhost:3000/api/health"]
interval: 1m30s
timeout: 10s
retries: 3
filebeat:
image: docker.elastic.co/beats/filebeat:8.17.2
container_name: syslog-filebeat
ports:
- "514:514/udp"
volumes:
- ./filebeat.docker.yml:/usr/share/filebeat/filebeat.yml:ro
restart: always
environment:
- TZ=Asia/Shanghai
healthcheck:
test: ["CMD", "curl", "-f", "http://localhost:5066"]
interval: 60s
timeout: 10s
retries: 3
docker compose up -d
docker compose down
dcker compose pull
docker compose up -d
victoria-logs
victoriametrics/victoria-logs:latest
镜像。syslog-victoria-logs
./victoria-logs-data
到容器内的 /victoria-logs-data
,用于持久化存储。always
,确保容器在运行失败后自动重启。--retentionPeriod=365d
,表示日志保留期为 365 天。Asia/Shanghai
。wget -q --spider http://127.0.0.1:9428/health
检查服务的健康状态。1 分 30 秒
执行一次检查。10 秒
后超时。3 次
失败后标记为非健康。grafana/grafana-enterprise
镜像。syslog-grafana
3000
端口映射到容器的 3000
端口,供外部访问 Grafana 。victoriametrics-logs-datasource
。Songxwn.com
。Asia/Shanghai
。./grafana-data
到容器中的 /var/lib/grafana
,用于持久化 Grafana 的数据。./provisioning
到 /etc/grafana/provisioning
,用于配置预置的数据源和仪表盘。always
。curl -f http://localhost:3000/api/health
检查服务的健康状态。1 分 30 秒
执行一次检查。10 秒
后超时。3 次
失败后标记为非健康。docker.elastic.co/beats/filebeat:8.17.2
镜像。syslog-filebeat
514/udp
端口映射到容器的 514/udp
端口,用于接收 Syslog 。filebeat.docker.yml
配置文件挂载到容器内的 /usr/share/filebeat/filebeat.yml
,且为只读。always
。Asia/Shanghai
。curl -f http://localhost:5066
检查服务的健康状态。60 秒
执行一次检查。10 秒
后超时。3 次
失败后标记为非健康。这些配置用来部署和管理 Victoria-Logs 、Grafana 和 Filebeat 服务,确保它们处于良好运行状态,且在故障发生时可以自动恢复。各自的健康检查提供了针对服务运行状态的简易确认方式,进一步提高系统的稳定性和可靠性。
发送日志到 udp/514 端口,即可存储到数据库。 echo "songxwn.com\!" | nc -4u 202.182.109.11 514
命令用来测试发送
访问到 Grafana Web 3000 端口,使用 admin/Songxwn.com 登录。
可以通过已经预先创建的数据源 VictoriaLogs-songxwn.com ,通过 Explore 查询日志( LogsQL 语法,*
匹配所有 )和导出为 CSV 文件。
Grafana 也可以进行日志告警和构建可视化仪表盘。
CONTAINER ID NAME CPU % MEM USAGE / LIMIT MEM % NET I/O BLOCK I/O PIDS
1c7fe73fc896 syslog-filebeat 0.52% 63.14MiB / 3.822GiB 1.61% 14.1MB / 5.38MB 0B / 8.19kB 15
4a6ee8b19475 syslog-grafana 0.61% 147.3MiB / 3.822GiB 3.76% 9.85MB / 12.8MB 299kB / 305MB 33
a80d91af294c syslog-victoria-logs 0.04% 195.7MiB / 3.822GiB 5.00% 5.4MB / 604kB 520kB / 6.86MB 14
git clone https://github.com/Songxwn/VGF-Docker-compose.git
cd VGF-Docker-compose
chown -R 472:472 grafana-data
chown -R 472:472 victoria-logs-data
docker compose up -d
docker ps
# 查看状态,两分钟之后应该都是 healthy
发送邮件到 ➡️ [email protected]
或者关注 WX 公众号:网工格物
![]() |
1
RedisMasterNode 1 天前
VL 没有集群版本的就是玩具
|
2
spritecn 21 小时 53 分钟前
强烈推荐 openObserve,原生支持 Filebeat,自带的查询和面板也够用
https://github.com/openobserve/openobserve 下面是我搭的时候的一些备忘 https://blog.jascript.cn/posts/OpenObserve 日志方案.html |
3
spritecn 21 小时 49 分钟前
话说怎么把下面这个连接连到一起
https://blog.jascript.cn/posts/OpenObserve 日志方案.html 只能这样,看到以后写博客标题不能带空格 https%3A%2F%2Fblog.jascript.cn%2Fposts%2FOpenObserve%20%E6%97%A5%E5%BF%97%E6%96%B9%E6%A1%88.html |
![]() |
5
defunct9 21 小时 13 分钟前
不错不错
|
6
spritecn 20 小时 47 分钟前
@wei2629 iot 场景,一天 2500 万左右日志,根据设备号做了 8 个分区,根据设备号查一天日志数据在 2371ms,我是 ecs+oss,同区域走内网流量的,网络不是问题,我用的是是 ecs 2c2g 的经济型实例,瓶颈在 SSD 的 IOPS 和内存缓存上
|
![]() |
7
tcpdump 17 小时 8 分钟前
检索能力很差的 尤其是全文,如果日志格式不规范,更是灾难
|
![]() |
8
ericFork 16 小时 29 分钟前
用来替代了 graylog ,搭配 vector ,还是轻量高效不少的
|