VLSingle represents database for storing logs.
The VLSingle CRD declaratively defines a
single-node VictoriaLogs
installation to run in a Kubernetes cluster.
For each VLSingle resource, the Operator deploys a properly configured Deployment in the same namespace.
The VLSingle Pods 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 VLSingle resource, the Operator adds Service and VMServiceScrape in the same namespace prefixed with name from VLSingle.metadata.name.
Specification #
You can see the full actual specification of the VLSingle resource in the API docs -> VLSingle
.
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 #
VLSingle doesn’t support high availability. Consider using
VLCluster
or multiple VLSingle resources.
Version management #
To set VLSingle version add spec.image.tag name from releases
      apiVersion: operator.victoriametrics.com/v1
kind: VLSingle
metadata:
  name: example
spec:
  image:
    repository: victoriametrics/victoria-logs
    tag: v1.26.0
    pullPolicy: Always
  # ...
    Also, you can specify imagePullSecrets if you are pulling images from private repo:
      apiVersion: operator.victoriametrics.com/v1
kind: VLSingle
metadata:
  name: example
spec:
  image:
    repository: victoriametrics/victoria-logs
    tag: v1.26.0
    pullPolicy: Always
  imagePullSecrets:
    - name: my-repo-secret
# ...
    Resource management #
You can specify resources for each VLSingle resource in the spec section of the VLSingle CRD.
      apiVersion: operator.victoriametrics.com/v1
kind: VLSingle
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 VLSingle pods have resource requests and limits from the default values of the following
operator parameters
:
- VM_VLSINGLEDEFAULT_RESOURCE_LIMIT_MEM- default memory limit for- VLSinglepods,
- VM_VLSINGLEDEFAULT_RESOURCE_LIMIT_CPU- default memory limit for- VLSinglepods,
- VM_VLSINGLEDEFAULT_RESOURCE_REQUEST_MEM- default memory limit for- VLSinglepods,
- VM_VLSINGLEDEFAULT_RESOURCE_REQUEST_CPU- default memory limit for- VLSinglepods.
These default parameters will be used if:
- VM_VLSINGLEDEFAULT_USEDEFAULTRESOURCESis set to- true(default value),
- VLSingleCR doesn’t have- resourcesfield in- specsection.
Field resources in VLSingle spec have higher priority than operator parameters.
If you set VM_VLSINGLEDEFAULT_USEDEFAULTRESOURCES to false and don’t specify resources in VLSingle CRD,
then VLSingle 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 #
VLSingle with resources set #
      apiVersion: operator.victoriametrics.com/v1
kind: VLSingle
metadata:
  name: example
spec:
  retentionPeriod: "12"
  storage:
    resources:
      requests:
        storage: 50Gi
  resources:
    requests:
      memory: 500Mi
      cpu: 500m
    limits:
      memory: 10Gi
      cpu: 5
    VLSingle with existing volume #
create PVC and bind it to existing PV existing-pv-name
spec.storageClassName should match a storage class name of PersistentVolume
      apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: example-pvc
spec:
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 10Gi
  storageClassName: standard
  volumeName: existing-pv-name
    create VLSingle with PVC example-pvc mounted
spec.replicaCount should be set to 1 since existing volume can only be mounted once
      apiVersion: operator.victoriametrics.com/v1
kind: VLSingle
metadata:
  name: example
spec:
  replicaCount: 1
  retentionPeriod: "12"
  extraArgs:
    storageDataPath: /vl-data
  volumes:
    - name: vlstorage
      persistentVolumeClaim:
        claimName: example-pvc
  volumeMounts:
    - name: vlstorage
      mountPath: /vl-data
  resources:
    requests:
      memory: 500Mi
      cpu: 500m
    limits:
      memory: 10Gi
      cpu: 5
    Migration from VLogs #
At first, create a new VLSingle resource, point clients to the new resource. Use
backup-restore
procedure for historical data migration.