-
-
Notifications
You must be signed in to change notification settings - Fork 231
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Helm Chart broken #334
Comments
@SebUndefined Thanks. The Helm chart seems to work for me. Can you make extra sure that there are no faulty values injected into the 👉 Thank you for supporting VerneMQ: https://github.com/sponsors/vernemq |
hi @ioolkos , sorry for the late answer. Please find below the ...
additionalEnv:
- name: DOCKER_VERNEMQ_ACCEPT_EULA
value: "yes"
- name: DOCKER_VERNEMQ_ALLOW_REGISTER_DURING_NETSPLIT
value: "on"
- name: DOCKER_VERNEMQ_ALLOW_PUBLISH_DURING_NETSPLIT
value: "on"
- name: DOCKER_VERNEMQ_ALLOW_SUBSCRIBE_DURING_NETSPLIT
value: "on"
- name: DOCKER_VERNEMQ_ALLOW_UNSUBSCRIBE_DURING_NETSPLIT
value: "on"
- name: DOCKER_VERNEMQ_ALLOW_ANONYMOUS
value: "off"
- name: DOCKER_VERNEMQ_PLUGINS.vmq_passwd
value: "off"
- name: DOCKER_VERNEMQ_PLUGINS.vmq_acl
value: "off"
- name: DOCKER_VERNEMQ_PLUGINS.vmq_webhooks
value: "on"
# Session lifecycle
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS.auth_on_register.hook
value: "auth_on_register"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS.auth_on_register.endpoint
value: "http://my_service:3000/v1/session-lifecycle/auth-on-register"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS.on_client_wakeup.hook
value: "on_client_wakeup"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS.on_client_wakeup.endpoint
value: "http://my_service:3000/v1/session-lifecycle/on-client-wakeup"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS.on_register.hook
value: "on_register"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS.on_register.endpoint
value: "http://my_service:3000/v1/session-lifecycle/on-register"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS.on_client_offline.hook
value: "on_client_offline"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS.on_client_offline.endpoint
value: "http://my_service:3000/v1/session-lifecycle/on-client-offline"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS.on_client_gone.hook
value: "on_client_gone"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS.on_client_gone.endpoint
value: "http://my_service:3000/v1/session-lifecycle/on-client-gone"
# Publish Flow
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS.auth_on_publish.hook
value: "auth_on_publish"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS.auth_on_publish.endpoint
value: "http://my_service:3000/v1/publish-flow/auth-on-publish"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS.on_publish.hook
value: "on_publish"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS.on_publish.endpoint
value: "http://my_service:3000/v1/publish-flow/on-publish"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS.on_offline_message.hook
value: "on_offline_message"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS.on_offline_message.endpoint
value: "http://my_service:3000/v1/publish-flow/on-offline-message"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS.on_deliver.hook
value: "on_deliver"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS.on_deliver.endpoint
value: "http://my_service:3000/v1/publish-flow/on-deliver" |
@SebUndefined can you check you do not run into this?: https://github.com/vernemq/docker-vernemq#remarks 👉 Thank you for supporting VerneMQ: https://github.com/sponsors/vernemq |
Thanks @ioolkos . I have followed the remark section but it still does not work. What I have tried:
I still get the same message... |
For infos, I have tried as mentionned in the error message to run the command Probably because vernemq is not already started... Any idea @ioolkos ? |
@SebUndefined what are your exact commands? 👉 Thank you for supporting VerneMQ: https://github.com/sponsors/vernemq |
It is as simple as It is a test file where the only thing I modified is |
@SebUndefined Thanks, jep, looks right. Ponder whether I'm missing something simple here. Did you run 👉 Thank you for supporting VerneMQ: https://github.com/sponsors/vernemq |
Yes, i did it again just for to be sure:
Install:
Logs:
|
The value.yaml file just in case: # Default values for vernemq.
# This is a YAML-formatted file.
# Declare variables to be passed into your templates.
replicaCount: 1
image:
repository: vernemq/vernemq
tag: 1.12.6.2-alpine
pullPolicy: IfNotPresent
nameOverride: ""
fullnameOverride: ""
serviceMonitor:
create: false
labels: {}
service:
# Can be disabled if more advanced use cases require more complex setups, e.g., combining LoadBalancer and ClusterIP for internal and external access. See also issue #274.
enabled: true
# NodePort - Listen to a port on nodes and forward to the service.
# ClusterIP - Listen on the service internal to the cluster only.
# LoadBalancer - Create a LoadBalancer in the cloud provider and forward to the service.
type: ClusterIP
# clusterIP: 10.1.2.4
# externalIPs: []
# loadBalancerIP: 10.1.2.4
# loadBalancerSourceRanges: []
# externalTrafficPolicy: Local
# sessionAffinity: None
# sessionAffinityConfig: {}
mqtt:
enabled: true
port: 1883
# This is the port used by nodes to expose the service
nodePort: 1883
mqtts:
enabled: false
port: 8883
# This is the port used by nodes to expose the service
nodePort: 8883
ws:
enabled: false
port: 8080
# This is the port used by nodes to expose the service
nodePort: 8080
wss:
enabled: false
port: 8443
# This is the port used by nodes to expose the service
nodePort: 8443
api:
enabled: false
port: 8888
nodePort: 38888
annotations: {}
labels: {}
## Ingress can optionally be applied when enabling the MQTT websocket service
## This allows for an ingress controller to route web ports and arbitrary hostnames
## and paths to the websocket service as well as allow the controller to handle TLS
## termination for the websocket traffic. Ingress is only possible for traffic exchanged
## over HTTP, so ONLY the websocket service take advantage of ingress.
ingress:
className: ""
enabled: false
labels: {}
annotations: {}
## Hosts must be provided if ingress is enabled.
##
hosts: []
# - vernemq.domain.com
## Paths to use for ingress rules.
##
paths:
- path: /
pathType: ImplementationSpecific
## TLS configuration for ingress
## Secret must be manually created in the namespace
##
tls: []
# - secretName: vernemq-tls
# hosts:
# - vernemq.domain.com
## VerneMQ resources requests and limits
## Ref: http://kubernetes.io/docs/user-guide/compute-resources
resources: {}
## We usually recommend not to specify default resources and to leave this as a conscious
## choice for the user. This also increases chances charts run on environments with little
## resources, such as Minikube. If you do want to specify resources, uncomment the following
## lines, adjust them as necessary, and remove the curly braces after 'resources:'.
# limits:
# cpu: 1
# memory: 256Mi
# requests:
# cpu: 1
# memory: 256Mi
## Node labels for pod assignment
## Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/#nodeselector
nodeSelector: {}
## Node tolerations for pod assignment
## Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/#taints-and-tolerations-beta-feature
tolerations: []
## Pod affinity
## Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/#affinity-and-anti-affinity
podAntiAffinity: soft
securityContext:
runAsUser: 10000
runAsGroup: 10000
fsGroup: 10000
## If RBAC is enabled on the cluster,VerneMQ needs a service account
## with permissisions sufficient to list pods
rbac:
create: true
serviceAccount:
create: true
## Service account name to be used.
## If not set and serviceAccount.create is true a name is generated using the fullname template.
# name:
persistentVolume:
## If true, VerneMQ will create/use a Persistent Volume Claim
## If false, use local directory
enabled: false
## VerneMQ data Persistent Volume access modes
## Must match those of existing PV or dynamic provisioner
## Ref: http://kubernetes.io/docs/user-guide/persistent-volumes/
accessModes:
- ReadWriteOnce
## VerneMQ data Persistent Volume size
size: 5Gi
## VerneMQ data Persistent Volume Storage Class
## If defined, storageClassName: <storageClass>
## If set to "-", storageClassName: "", which disables dynamic provisioning
## If undefined (the default) or set to null, no storageClassName spec is
## set, choosing the default provisioner. (gp2 on AWS, standard on
## GKE, AWS & OpenStack)
# storageClass: ""
## Annotations for Persistent Volume Claim
annotations: {}
extraVolumeMounts: []
## Additional volumeMounts to the pod.
# - name: additional-volume-mount
# mountPath: /var/additional-volume-path
extraVolumes: []
## Additional volumes to the pod.
# - name: additional-volume
# emptyDir: {}
# A list of secrets and their paths to mount inside the pod
# This is useful for mounting certificates for security (tls)
secretMounts: []
# - name: vernemq-certificates
# secretName: vernemq-certificates-secret
# path: /etc/ssl/vernemq
statefulset:
## Start and stop pods in Parallel or OrderedReady (one-by-one.) Note - Can not change after first release.
## Ref: https://kubernetes.io/docs/tutorials/stateful-application/basic-stateful-set/#pod-management-policy
podManagementPolicy: OrderedReady
## Statefulsets rolling update update strategy
## Ref: https://kubernetes.io/docs/tutorials/stateful-application/basic-stateful-set/#rolling-update
updateStrategy: RollingUpdate
## Configure how much time VerneMQ takes to move offline queues to other nodes
## Ref: https://vernemq.com/docs/clustering/#detailed-cluster-leave-case-a-make-a-live-node-leave
terminationGracePeriodSeconds: 60
## Liveness and Readiness probe values
## Ref: https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-probes
livenessProbe:
initialDelaySeconds: 90
periodSeconds: 10
timeoutSeconds: 5
successThreshold: 1
failureThreshold: 3
readinessProbe:
initialDelaySeconds: 90
periodSeconds: 10
timeoutSeconds: 5
successThreshold: 1
failureThreshold: 3
podAnnotations: {}
# prometheus.io/scrape: "true"
# prometheus.io/port: "8888"
annotations: {}
labels: {}
podLabels: {}
lifecycle: {}
pdb:
enabled: false
minAvailable: 1
# maxUnavailable: 1
## VerneMQ settings
additionalEnv:
- name: DOCKER_VERNEMQ_ACCEPT_EULA
value: "yes"
- name: DOCKER_VERNEMQ_LOG__console__level
value: "debug"
- name: DOCKER_VERNEMQ_ALLOW_REGISTER_DURING_NETSPLIT
value: "on"
- name: DOCKER_VERNEMQ_ALLOW_PUBLISH_DURING_NETSPLIT
value: "on"
- name: DOCKER_VERNEMQ_ALLOW_SUBSCRIBE_DURING_NETSPLIT
value: "on"
- name: DOCKER_VERNEMQ_ALLOW_UNSUBSCRIBE_DURING_NETSPLIT
value: "on"
- name: DOCKER_VERNEMQ_ALLOW_ANONYMOUS
value: "off"
- name: DOCKER_VERNEMQ_PLUGINS__vmq_passwd
value: "off"
- name: DOCKER_VERNEMQ_PLUGINS__vmq_acl
value: "off"
- name: DOCKER_VERNEMQ_PLUGINS__vmq_webhooks
value: "on"
# Session lifecycle
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS__auth_on_register__hook
value: "auth_on_register"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS__auth_on_register__endpoint
value: "http://service:3000/v1/session-lifecycle/auth-on-register"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS__on_client_wakeup__hook
value: "on_client_wakeup"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS__on_client_wakeup__endpoint
value: "http://service:3000/v1/session-lifecycle/on-client-wakeup"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS__on_register__hook
value: "on_register"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS__on_register__endpoint
value: "http://service:3000/v1/session-lifecycle/on-register"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS__on_client_offline__hook
value: "on_client_offline"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS__on_client_offline__endpoint
value: "http://service:3000/v1/session-lifecycle/on-client-offline"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS__on_client_gone__hook
value: "on_client_gone"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS__on_client_gone__endpoint
value: "http://service:3000/v1/session-lifecycle/on-client-gone"
# Publish Flow
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS__auth_on_publish__hook
value: "auth_on_publish"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS__auth_on_publish__endpoint
value: "http://service:3000/v1/publish-flow/auth-on-publish"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS__on_publish__hook
value: "on_publish"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS__on_publish__endpoint
value: "http://service:3000/v1/publish-flow/on-publish"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS__on_offline_message__hook
value: "on_offline_message"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS__on_offline_message__endpoint
value: "http://service:3000/v1/publish-flow/on-offline-message"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS__on_deliver__hook
value: "on_deliver"
- name: DOCKER_VERNEMQ_VMQ_WEBHOOKS__on_deliver__endpoint
value: "http://service:3000/v1/publish-flow/on-deliver"
# - name: DOCKER_VERNEMQ_MAX_CLIENT_ID_SIZE
# value: "100"
# - name: DOCKER_VERNEMQ_MAX_ONLINE_MESSAGES
# value: "10000"
# - name: DOCKER_VERNEMQ_MAX_OFFLINE_MESSAGES
# value: "-1"
# - name: DOCKER_VERNEMQ_LISTENER__SSL__CAFILE
# value: "/etc/ssl/vernemq/tls.crt"
# - name: DOCKER_VERNEMQ_LISTENER__SSL__CERTFILE
# value: "/etc/ssl/vernemq/tls.crt"
# - name: DOCKER_VERNEMQ_LISTENER__SSL__KEYFILE
# value: "/etc/ssl/vernemq/tls.key"
envFrom: []
# add additional environment variables e.g. from a configmap or secret
# can be usefull if you wanna use authentication via files
# - secretRef:
# name: vernemq-users |
Your 👉 Thank you for supporting VerneMQ: https://github.com/sponsors/vernemq |
@ioolkos can you confirm that the names of the webhook based env variables above are correct? I tried using them and deployed the cluster, but the webhooks do not fire at all. So i am wondering if these are correct names. |
@mojoscale the webhook ENV variables seem to look allright, yes. Maybe confusing because of the given names.
Docs are here: https://docs.vernemq.com/plugin-development/webhookplugins The ENV variables get injected into the 👉 Thank you for supporting VerneMQ: https://github.com/sponsors/vernemq |
I edited k8s sts, set
Removed this setting and everythink started fine |
Deployment helm chart is broken with the version 1.8.0. Pods logs:
Back with previous version (1.6.12) everything works perfectly.
VerneMQ value file:
The text was updated successfully, but these errors were encountered: