From b423c03937ec686efff83a3cd340010672ac53ff Mon Sep 17 00:00:00 2001 From: Matt Ulmer <25484774+Ulminator@users.noreply.github.com> Date: Sat, 23 Nov 2024 12:35:55 -0800 Subject: [PATCH] feat: nsq scaler docs (#1485) * feat: nsq scaler docs Signed-off-by: Matt Ulmer <25484774+Ulminator@users.noreply.github.com> * fix: add useHttps/unsafeSsl to nsq scaler docs Signed-off-by: Matt Ulmer <25484774+Ulminator@users.noreply.github.com> * fix: change idleReplicaCount -> minReplicaCount Signed-off-by: Matt Ulmer <25484774+Ulminator@users.noreply.github.com> * fix: move nsq docs from 2.16 to 2.17 Signed-off-by: Matt Ulmer <25484774+Ulminator@users.noreply.github.com> --------- Signed-off-by: Matt Ulmer <25484774+Ulminator@users.noreply.github.com> --- .htmltest.yml | 7 ++-- content/docs/2.17/scalers/nsq.md | 60 ++++++++++++++++++++++++++++++++ 2 files changed, 62 insertions(+), 5 deletions(-) create mode 100644 content/docs/2.17/scalers/nsq.md diff --git a/.htmltest.yml b/.htmltest.yml index 5e0cbb021..f2d4bcff5 100644 --- a/.htmltest.yml +++ b/.htmltest.yml @@ -5,10 +5,7 @@ IgnoreAltMissing: true IgnoreEmptyHref: true IgnoreInternalURLs: # Temporal ignores - - /docs/2.15/scalers/beanstalkd/ + - /docs/2.16/scalers/nsq/ # Deprecated and removed resources - - /docs/2.15/authentication-providers/azure-ad-pod-identity/ - - /docs/2.15/authentication-providers/aws-kiam/ + # Renamed pages - - /docs/2.15/operate/events/ - - /docs/2.15/faq/ diff --git a/content/docs/2.17/scalers/nsq.md b/content/docs/2.17/scalers/nsq.md new file mode 100644 index 000000000..083dcbcb8 --- /dev/null +++ b/content/docs/2.17/scalers/nsq.md @@ -0,0 +1,60 @@ ++++ +title = "NSQ" +availability = "v2.17+" +maintainer = "Community" +category = "Messaging" +description = "Scale applications based on NSQ topic/channel depth." +go_file = "nsq_scaler" ++++ + +### Trigger Specification + +This specification describes the `nsq` trigger that scales based on [NSQ](https://github.com/nsqio/nsq) topic/channel depth. + +```yaml +triggers: +- type: nsq + metadata: + nsqLookupdHTTPAddresses: "nsq-nsqlookupd.nsq:4161" + topic: "example_topic" + channel: "example_channel" + depthThreshold: "10" + activationDepthThreshold: "0" + useHttps: "false" + unsafeSsl: "false" +``` + +**Parameter list:** + +- `nsqLookupdHTTPAddresses` - Comma separated list of [nsqlookupd](https://nsq.io/components/nsqlookupd.html) HTTP addresses in the form `:`. +- `topic` - Name of the NSQ datastream that the `channel` relates to. +- `channel` - Name of the channel used to calculate depth. +- `depthThreshold` - Target value for depth to trigger scaling actions. (Default `10`, Optional) +- `activationDepthThreshold` - Target value for depth to activate the scaler. (Default `0`, Optional) +- `useHttps` - Use HTTPS instead of HTTP when communicating with NSQ. (Values: `true`, `false`, Default: `false`, Optional) +- `unsafeSsl` - Skip certificate validation when connecting over HTTPS. (Values: `true`, `false`, Default: `false`, Optional) + + +> **Notice:** +> - Since ["channels are created on first use by subscribing to the named channel"](https://nsq.io/overview/design.html#simplifying-configuration-and-administration), the topic depth is used instead of the channel depth when the channel does not yet exist on an [nsqd](https://nsq.io/components/nsqd.html) instance. This allows KEDA to effectively bootstrap new channels when the `minReplicaCount` is 0. +> - If the message flow for a channel is paused, KEDA will not scale up consumers of the channel, regardless of the depth. + +### Example + +```yaml +apiVersion: keda.sh/v1alpha1 +kind: ScaledObject +metadata: + name: nsq-scaledobject +spec: + scaleTargetRef: + name: nsq-consumer-deployment + triggers: + - type: nsq + metadata: + nsqLookupdHTTPAddresses: "nsq-nsqlookupd.nsq:4161" + topic: "example_topic" + channel: "example_channel" + depthThreshold: "10" + activationDepthThreshold: "0" +```