VLogs
represents database for storing logs.
The VLogs
CRD declaratively defines a single-node VictoriaLogs
installation to run in a Kubernetes cluster.
For each VLogs
resource, the Operator deploys a properly configured Deployment
in the same namespace.
The VLogs Pod
s are configured to mount an empty dir or PersistentVolumeClaimSpec
for storing data.
Deployment update strategy set to recreate
.
No more than one replica allowed.
For each VLogs
resource, the Operator adds Service
and VMServiceScrape
in the same namespace prefixed with name from VLogs.metadata.name
.
Specification #
You can see the full actual specification of the VLogs
resource in the API docs -> VLogs
.
If you can’t find necessary field in the specification of the custom resource, see Extra arguments section .
Also, you can check out the examples section.
High availability #
VLogs
doesn’t support high availability. Consider using victorialogs-single chart
, where it’s possible to configure replica count in statefulset mode for such purpose.
Version management #
To set VLogs
version add spec.image.tag
name from releases
apiVersion: operator.victoriametrics.com/v1beta1
kind: VLogs
metadata:
name: example-vlogs
spec:
image:
repository: victoriametrics/victoria-logs
tag: v1.4.0
pullPolicy: Always
# ...
Also, you can specify imagePullSecrets
if you are pulling images from private repo:
apiVersion: operator.victoriametrics.com/v1beta1
kind: VLogs
metadata:
name: example-vlogs
spec:
image:
repository: victoriametrics/victoria-logs
tag: v1.4.0
pullPolicy: Always
imagePullSecrets:
- name: my-repo-secret
# ...
Resource management #
You can specify resources for each VLogs
resource in the spec
section of the VLogs
CRD.
apiVersion: operator.victoriametrics.com/v1beta1
kind: VLogs
metadata:
name: resources-example
spec:
# ...
resources:
requests:
memory: "64Mi"
cpu: "250m"
limits:
memory: "128Mi"
cpu: "500m"
# ...
If these parameters are not specified, then,
by default all VLogs
pods have resource requests and limits from the default values of the following operator parameters
:
VM_VLOGSDEFAULT_RESOURCE_LIMIT_MEM
- default memory limit forVLogs
pods,VM_VLOGSDEFAULT_RESOURCE_LIMIT_CPU
- default memory limit forVLogs
pods,VM_VLOGSDEFAULT_RESOURCE_REQUEST_MEM
- default memory limit forVLogs
pods,VM_VLOGSDEFAULT_RESOURCE_REQUEST_CPU
- default memory limit forVLogs
pods.
These default parameters will be used if:
VM_VLOGSDEFAULT_USEDEFAULTRESOURCES
is set totrue
(default value),VLogs
CR doesn’t haveresources
field inspec
section.
Field resources
in VLogs
spec have higher priority than operator parameters.
If you set VM_VLOGSDEFAULT_USEDEFAULTRESOURCES
to false
and don’t specify resources
in VLogs
CRD,
then VLogs
pods will be created without resource requests and limits.
Also, you can specify requests without limits - in this case default values for limits will not be used.
Examples #
apiVersion: operator.victoriametrics.com/v1beta1
kind: VLogs
metadata:
name: example
spec:
retentionPeriod: "12"
removePvcAfterDelete: true
storage:
accessModes:
- ReadWriteOnce
resources:
requests:
storage: 50Gi
resources:
requests:
memory: 500Mi
cpu: 500m
limits:
memory: 10Gi
cpu: 5