Speckle is data infrastructure for the AEC industry.
Give Speckle a try in no time by:
This Helm chart bundles all Speckle developed components of the Speckle server deployment. Please note that data storage and persistence requirements of the app are not installed by the chart, as these are external dependencies. The required dependencies are listed in our deployment dependencies page.
A full guide to deploying on Kubernetes can be found in Speckle’s Documentation, we recommend that you follow this guide if you are new to Kubernetes or Helm.
The below are brief notes which will require additional dependencies and configuration.
Helm must be installed to use the charts. Please refer to Helm’s documentation to get started.
Once Helm has been set up correctly, add the repo as follows:
$ helm repo add speckle https://specklesystems.github.io/helm
If you had already added this repo earlier, run helm repo update
to retrieve
the latest versions of the packages.
You can then run helm search repo speckle
to see the charts.
To install the speckle-server chart:
$ helm upgrade --install --create-namespace --namespace speckle-test my-speckle-server speckle/speckle-server
where my-speckle-server
will be the name of the Helm release.
More details about the values to configure for your release can be found in Speckle’s Documentation
By default the chart will install in the speckle-test
namespace, that name can be set in the chart values.
To uninstall the chart:
$ helm uninstall my-speckle-server --namespace speckle-test
Depending on the Infrastructure on which Speckle was released, a load balancer may have been created. This may have to be manually deleted.
Name | Description | Value |
---|---|---|
namespace |
The name of the namespace in which Speckle will be deployed. | speckle-test |
create_namespace |
Enabling this will create a new namespace into which Speckle will be deployed | false |
Name | Description | Value |
---|---|---|
domain |
The DNS host name at which this Speckle deployment will be reachable | localhost |
ssl_canonical_url |
HTTPS protocol will be the preferred protocol for serving this Speckle deployment | true |
tlsRejectUnauthorized |
If ‘1’ (true), Speckle will reject any SSL certificates that are not signed by a trusted Certificate Authority. Should only be disabled in a trusted local development environment. https://nodejs.org/api/cli.html#node_tls_reject_unauthorizedvalue | 1 |
cert_manager_issuer |
The name of the ClusterIssuer kubernetes resource that provides the SSL Certificate | letsencrypt-staging |
This object is a central location to define feature flags for the whole chart.
Name | Description | Value |
---|---|---|
featureFlags.automateModuleEnabled |
High level flag fully toggles the integrated automate module | false |
featureFlags.gendoAIModuleEnabled |
High level flag that toggles the Gendo AI render module | false |
featureFlags.noClosureWrites |
Toggles whether to stop writing to the closure table | false |
featureFlags.workspacesModuleEnabled |
High level flag fully toggles the workspaces module | false |
featureFlags.workspacesSSOEnabled |
High level flag fully toggles the workspaces dynamic sso | false |
featureFlags.multipleEmailsModuleEnabled |
High level flag fully toggles multiple emails | false |
featureFlags.gatekeeperModuleEnabled |
High level flag that enables the gatekeeper module | false |
featureFlags.billingIntegrationEnabled |
High level flag that enables the billing integration | false |
featureFlags.workspacesMultiRegionEnabled |
Toggles whether multi-region is available within workspaces. workspacesModuleEnabled must also be enabled. | false |
featureFlags.fileImportIFCDotNetEnabled |
Toggles whether the experimental .Net IFC importer is used for importing IFC files. | false |
analytics.enabled |
Enable or disable analytics | true |
analytics.mixpanel_token_id |
The Mixpanel token ID used to identify this Speckle deployment in MixPanel | acd87c5a50b56df91a795e999812a3a4 |
analytics.mixpanel_api_host |
The Mixpanel API host to which analytics data will be sent | https://analytics.speckle.systems |
This is used to define the type of network policy that is deployed. Different Kubernetes Network Plugins or Container Network Interfaces (CNIs) can make use of different types of Network Policy. Some of these provide more features than the standard Kubernetes Network Policy.
Name | Description | Value |
---|---|---|
networkPlugin.type |
(Optional) Used to configure which type of NetworkPolicy is deployed. Options are ‘kubernetes’ or ‘cilium’. | kubernetes |
This section is ignored unless networkPolicy is enabled for frontend or server. The NetworkPolicy uses this value to enable connections from the ingress controller pod in this namespace to reach Speckle. ref: https://kubernetes.io/docs/concepts/services-networking/network-policies/
Name | Description | Value |
---|---|---|
ingress.namespace |
The namespace in which the ingress controller is deployed. | ingress-nginx |
ingress.controllerName |
The name of the Kubernetes pod in which the ingress controller is deployed. | ingress-nginx |
Name | Description | Value |
---|---|---|
docker_image_tag |
Speckle is published as a Docker Image. The version of the image which will be deployed is specified by this tag. | 2 |
imagePullPolicy |
Determines the conditions when the Docker Images for Speckle should be pulled from the Image registry. | IfNotPresent |
secretName |
Deprecated, please use individual secret parameters. This is the name of the Kubernetes Secret resource in which secrets for Speckle are stored. Secrets within this Secret resource may include Postgres and Redis connectin strings, S3 secret values, email server passwords, etc.. | server-vars |
file_size_limit_mb |
This maximum size of any single file (unit is Megabytes) that can be uploaded to Speckle | 100 |
This enables metrics generated by Speckle to be ingested by Prometheus: https://prometheus.io/ Enabling this requires Prometheus to have been deployed prior, as this resource expects the Prometheus Customer Resource Definition for the ServiceMonitor to already be existing within the cluster. ref: https://github.com/prometheus-operator/prometheus-operator/blob/main/Documentation/user-guides/getting-started.md#related-resources
Name | Description | Value |
---|---|---|
enable_prometheus_monitoring |
If enabled, Speckle deploys a Prometheus ServiceMonitor resource | false |
prometheusMonitoring.namespace |
If provided, deploys Speckle’s Prometheus resources (e.g. ServiceMonitor) in the given namespace | "" |
prometheusMonitoring.release |
If provided, adds the value to a release label on all the Prometheus resources deployed by Speckle |
"" |
prometheusMonitoring.networkPolicy.inCluster |
Parameters for allowing ingress from the Prometheus pod that will scrape this Speckle release. It is assumed that Prometheus is deployed within the Kubernetes cluster. | |
prometheusMonitoring.networkPolicy.inCluster.kubernetes.podSelector |
(Kubernetes Network Policy only) The pod Selector yaml object used to uniquely select the prometheus pods within the cluster and given namespace | {} |
prometheusMonitoring.networkPolicy.inCluster.kubernetes.namespaceSelector |
(Kubernetes Network Policy only) The namespace selector yaml object used to uniquely select the namespace in which the prometheus pods are deployed | {} |
prometheusMonitoring.networkPolicy.inCluster.cilium.fromEndpoints |
(Cilium Network Policy only) The endpoint selector yaml object used to uniquely select the in-cluster endpoint in which the prometheus pods are deployed | [] |
Defines parameters related to connections to the Postgres database.
Name | Description | Value |
---|---|---|
db.useCertificate |
If enabled, the certificate defined in db.certificate is used to verify TLS connections to the Postgres database | false |
db.maxConnectionsServer |
The number of connections to the Postgres database to provide in the connection pool | 4 |
db.certificate |
The x509 public certificate for SSL connections to the Postgres database. Use of this certificate requires db.useCertificate to be enabled and an appropriate value for db.PGSSLMODE provided. | "" |
db.PGSSLMODE |
This defines the level of security used when connecting to the Postgres database | require |
db.connectionAcquisitionTimeoutMillis |
The maximum time in milliseconds to wait for a connection to be acquired from the connection pool. | 15000 |
db.connectionCreationTimeoutMillis |
The maximum time in milliseconds to wait for a new connection to be created in the connection pool. Should be less than the acquisition timeout, as a new connection may need to be created then acquired. | 5000 |
db.knexAsyncStackTracesEnabled |
If enabled, will provide better stack traces for errors arising out of knex operations | false |
db.databaseName |
(Optional) The name of the Postgres database to which Speckle will connect. Only required for the Database Monitoring utility when the connection string is to a database connection pool and multi-region is disabled, otherwise this value is ignored. | "" |
db.connectionString.secretName |
Required. A secret containing the full connection string to the Postgres database (e.g. in format of protocol://username:password@host:port/database ) stored within the Kubernetes cluster as an opaque Kubernetes Secret. Ref: https://kubernetes.io/docs/concepts/configuration/secret/#opaque-secrets |
"" |
db.connectionString.secretKey |
Required. The key within the Kubernetes Secret holding the connection string. | "" |
db.networkPolicy |
If networkPolicy is enabled for any service, this provides the NetworkPolicy with the necessary details to allow egress connections to the Postgres database | |
db.networkPolicy.externalToCluster |
Only required if the Postgres database is not hosted within the Kubernetes cluster in which Speckle will be deployed. | |
db.networkPolicy.externalToCluster.enabled |
If enabled, indicates that the Postgres database is hosted externally to the Kubernetes cluster | true |
db.networkPolicy.inCluster |
Only required if the Postgres database is hosted within the Kubernetes cluster in which Speckle will be deployed. | |
db.networkPolicy.inCluster.enabled |
If enabled, indicates that the Postgres database is hosted withing the same Kubernetes cluster in which Speckle will be deployed | false |
db.networkPolicy.inCluster.port |
the port on the server providing the Postgres database (default: “5432”) | "" |
db.networkPolicy.inCluster.kubernetes.podSelector |
(Kubernetes Network Policy only) The pod Selector yaml object used to uniquely select the postgres compatible database pods within the cluster and given namespace | {} |
db.networkPolicy.inCluster.kubernetes.namespaceSelector |
(Kubernetes Network Policy only) The namespace selector yaml object used to uniquely select the namespace in which the postgres compatible database pods are deployed | {} |
db.networkPolicy.inCluster.cilium.endpointSelector |
(Cilium Network Policy only) The endpoint selector yaml object used to uniquely select the in-cluster endpoint in which the postgres compatible database pods are deployed | {} |
db.networkPolicy.inCluster.cilium.serviceSelector |
(Cilium Network Policy only) The service selector yaml object used to uniquely select the in-cluster service providing the postgres compatible database service | {} |
Defines parameters related to connecting to the S3 compatible storage.
Name | Description | Value |
---|---|---|
s3.configMap.enabled |
If enabled, the s3.endpoint, s3.bucket, and s3.access_key values will be determined from a configMap and the values provided in this helm release ignored. | false |
s3.configMap.name |
The name of the ConfigMap in which values for the keys (endpoint , bucket , and access_key ) are provided. Expected to be in the namespace defined by the namespace parameter of this Helm Chart. |
"" |
s3.endpoint |
The URL at which the s3 compatible storage is hosted. If s3.configMap.enabled is true, this value is ignored. |
"" |
s3.bucket |
The s3 compatible bucket in which Speckle data will be stored. If s3.configMap.enabled is true, this value is ignored. |
"" |
s3.access_key |
The key of the access key used to authenticate with the s3 compatible storage. If s3.configMap.enabled is true, this value is ignored. |
"" |
s3.secret_key.secretName |
Required. A Kubernetes secret containing the s3 secret_key. This is expected to be the name of an opaque Kubernetes Secret. Ref: https://kubernetes.io/docs/concepts/configuration/secret/#opaque-secrets | "" |
s3.secret_key.secretKey |
Required. The key within the Kubernetes Secret, the value of which is the s3 secret. | "" |
s3.create_bucket |
If enabled, will create a bucket with the given bucket name at this endpoint | false |
s3.region |
The region in which the bucket resides (or will be created in). | "" |
s3.networkPolicy |
If networkPolicy is enabled for any service, this provides the NetworkPolicy with the necessary details to allow egress connections to the s3 compatible storage | |
s3.networkPolicy.port |
the port on the server providing the s3 compatible storage (default: “443”) | "" |
s3.networkPolicy.externalToCluster |
Only required if the s3 compatible storage is not hosted within the Kubernetes cluster in which Speckle will be deployed. | |
s3.networkPolicy.externalToCluster.enabled |
If enabled, indicates that the s3 compatible storage is hosted externally to the Kubernetes cluster | true |
s3.networkPolicy.inCluster |
Only required if the s3 compatible storage is hosted within the Kubernetes cluster in which Speckle will be deployed. | |
s3.networkPolicy.inCluster.enabled |
If enabled, indicates that the s3 compatible storage is hosted withing the same Kubernetes cluster in which Speckle will be deployed | false |
s3.networkPolicy.inCluster.kubernetes.podSelector |
(Kubernetes Network Policy only) The pod Selector yaml object used to uniquely select the s3 compatible storage pods within the cluster and given namespace | {} |
s3.networkPolicy.inCluster.kubernetes.namespaceSelector |
(Kubernetes Network Policy only) The namespace selector yaml object used to uniquely select the namespace in which the s3 compatible storage pods are deployed | {} |
s3.networkPolicy.inCluster.cilium.endpointSelector |
(Cilium Network Policy only) The endpoint selector yaml object used to uniquely select the in-cluster endpoint in which the s3 compatible storage pods are deployed | {} |
s3.networkPolicy.inCluster.cilium.serviceSelector |
(Cilium Network Policy only) The service selector yaml object used to uniquely select the in-cluster service providing the s3 compatible storage service | {} |
Defines parameters related to connecting to the Redis Store.
Name | Description | Value |
---|---|---|
redis.connectionString.secretName |
Required. A secret containing the full connection string to the Redis store (e.g. in format of protocol://username:password@host:port/database ) stored within the Kubernetes cluster as an opaque Kubernetes Secret. Ref: https://kubernetes.io/docs/concepts/configuration/secret/#opaque-secrets |
"" |
redis.connectionString.secretKey |
Required. The key within the Kubernetes Secret holding the Redis connection string. | "" |
redis.networkPolicy |
If networkPolicy is enabled for Speckle server, this provides the NetworkPolicy with the necessary details to allow egress connections to the Redis store | |
redis.networkPolicy.externalToCluster |
Only required if the Redis store is not hosted within the Kubernetes cluster in which Speckle will be deployed. | |
redis.networkPolicy.externalToCluster.enabled |
If enabled, indicates that the Redis store is hosted externally to the Kubernetes cluster | true |
redis.networkPolicy.inCluster |
is only required if the Redis store is hosted within the Kubernetes cluster in which Speckle will be deployed. | |
redis.networkPolicy.inCluster.enabled |
If enabled, indicates that the Redis store is hosted withing the same Kubernetes cluster in which Speckle will be deployed | false |
redis.networkPolicy.inCluster.port |
the port on the server providing the Redis store (default: “6379”) | "" |
redis.networkPolicy.inCluster.kubernetes.podSelector |
(Kubernetes Network Policy only) The pod Selector yaml object used to uniquely select the redis store pods within the cluster and given namespace | {} |
redis.networkPolicy.inCluster.kubernetes.namespaceSelector |
(Kubernetes Network Policy only) The namespace selector yaml object used to uniquely select the namespace in which the redis store pods are deployed | {} |
redis.networkPolicy.inCluster.cilium.endpointSelector |
(Cilium Network Policy only) The endpoint selector yaml object used to uniquely select the in-cluster endpoint in which the redis pods are deployed | {} |
redis.networkPolicy.inCluster.cilium.serviceSelector |
(Cilium Network Policy only) The service selector yaml object used to uniquely select the in-cluster service providing the redis store service | {} |
Defines parameters related to opentelemetry exporting of metrics.
Name | Description | Value |
---|---|---|
openTelemetry.tracing.url |
Required. The URL to which the opentelemetry traces will be exported. | "" |
openTelemetry.tracing.key |
Required. The key to be used when exporting opentelemetry traces. | "" |
openTelemetry.tracing.value |
Required. The value to be used when exporting opentelemetry traces. | "" |
multiRegion.config.secretName |
If workspacesMultiRegionEnabled is enabled, the server will be deployed in a multi-region configuration based on the values in a secret. This allows the default secret name to be overridden. | multi-region-config |
multiRegion.config.secretKey |
If workspacesMultiRegionEnabled is enabled, the server will be deployed in a multi-region configuration based on the values in a secret. This allows the default secret key and filename to be overridden. | multi-region-config.json |
Defines parameters related to the backend server component of Speckle.
Name | Description | Value |
---|---|---|
server.replicas |
The number of instances of the Server pod to be deployed within the cluster. | 1 |
server.logLevel |
The minimum level of logs which will be output. Suitable values are trace, debug, info, warn, error, fatal, or silent | info |
server.logPretty |
If enabled, will output logs in a human-readable format. Otherwise, logs will be output in JSON format. | false |
server.image |
The Docker image to be used for the Speckle Server component. If blank, defaults to speckle/speckle-server:. If provided, this value should be the full path including tag. The docker_image_tag value will be ignored. | "" |
server.enableFe2Messaging |
If enabled, the related FE1 deployment will show banners/messages about the new frontend | false |
server.onboarding.stream_url |
The (cross-server) URL to the project/stream that should be used as the onboarding project base. | https://latest.speckle.systems/projects/843d07eb10 |
server.onboarding.stream_cache_bust_number |
Increase this number to trigger the re-pulling of the base stream | 1 |
server.inspect.enabled |
If enabled, indicates that the Speckle server should be deployed with the nodejs inspect feature enabled | false |
server.inspect.port |
The port on which the nodejs inspect feature should be exposed | 7000 |
server.adminOverrideEnabled |
Enables the server side admin authz override | false |
server.weeklyDigestEnabled |
Enables sending out the serevr weekly digest emails | false |
server.max_object_size_mb |
The maximum size of an individual object which can be uploaded to the server | 100 |
server.max_object_upload_file_size_mb |
Objects are batched together and uploaded to the /objects endpoint as http POST form data. This determines the maximum size of that form data which can be uploaded to the server. It should be greater than or equal to max_object_size_mb. | 100 |
server.max_project_models_per_page |
The maximum number of models that can be returned in a single page of a query for all models of a project | 500 |
server.speckleAutomateUrl |
The url of the Speckle Automate instance | https://automate.speckle.systems |
server.asyncRequestContextEnabled |
If enabled, the server will use the async request context for improved log msg correlation | false |
server.gendoAI.apiUrl |
The url of the Gendo AI application, including protocol. | https://api.gendo.ai/external/generate |
server.gendoAI.creditLimit |
The number of Gendo AI credit a user gets every month. | 40 |
server.gendoAI.key.secretName |
The name of the Kubernetes Secret containing the Gendo AI key. If left blank, will default to the secretName parameter. |
"" |
server.gendoAI.key.secretKey |
The key within the Kubernetes Secret holding the Gendo AI key as its value. | gendoai_key |
server.gendoAI.ratelimiting.renderRequest |
The number of render requests allowed per period | 1 |
server.gendoAI.ratelimiting.renderRequestPeriodSeconds |
The period in seconds for the render request limit | 20 |
server.gendoAI.ratelimiting.burstRenderRequest |
The number of render requests allowed in ‘burst’ mode when the other limit is reached. | 3 |
server.gendoAI.ratelimiting.burstRenderRequestPeriodSeconds |
The period in seconds for the burst render request limit. | 60 |
server.encryptionKeys.path |
The path where the encryption keys should be loaded from | /encryption-keys/keys.json |
server.licenseTokenSecret.secretName |
The name of the Kubernetes Secret containing the Session secret. This is a unique value (can be generated randomly). This is expected to be provided within the Kubernetes cluster as an opaque Kubernetes Secret. Ref: https://kubernetes.io/docs/concepts/configuration/secret/#opaque-secrets | "" |
server.licenseTokenSecret.secretKey |
The key within the Kubernetes Secret holding the Session secret as its value. | "" |
server.billing |
Values to enable billing integration on the server | |
server.billing.secretName |
The name of the Kubernetes Secret containing the Session secret. This is a unique value (can be generated randomly). This is expected to be provided within the Kubernetes cluster as an opaque Kubernetes Secret. Ref: https://kubernetes.io/docs/concepts/configuration/secret/#opaque-secrets | "" |
server.billing.stripeApiKey.secretKey |
The key within the Kubernetes Secret holding the stripeApiKey secret as its value. | stripeApiKey |
server.billing.stripeEndpointSigningKey.secretKey |
The key within the Kubernetes Secret holding the stripeEndpointSigningKey secret as its value. | stripeEndpointSigningKey |
server.billing.workspaceGuestSeatStripeProductId.secretKey |
The key within the Kubernetes Secret holding the workspaceGuestSeatStripeProductId secret as its value. | workspaceGuestSeatStripeProductId |
server.billing.workspaceMonthlyGuestSeatStripePriceId.secretKey |
The key within the Kubernetes Secret holding the workspaceMonthlyGuestSeatStripePriceId secret as its value. | workspaceMonthlyGuestSeatStripePriceId |
server.billing.workspaceYearlyGuestSeatStripePriceId.secretKey |
The key within the Kubernetes Secret holding the workspaceYearlyGuestSeatStripePriceId secret as its value. | workspaceYearlyGuestSeatStripePriceId |
server.billing.workspaceTeamSeatStripeProductId.secretKey |
The key within the Kubernetes Secret holding the workspaceTeamSeatStripeProductId secret as its value. | workspaceTeamSeatStripeProductId |
server.billing.workspaceMonthlyTeamSeatStripePriceId.secretKey |
The key within the Kubernetes Secret holding the workspaceMonthlyTeamSeatStripePriceId secret as its value. | workspaceMonthlyTeamSeatStripePriceId |
server.billing.workspaceYearlyTeamSeatStripePriceId.secretKey |
The key within the Kubernetes Secret holding the workspaceYearlyTeamSeatStripePriceId secret as its value. | workspaceYearlyTeamSeatStripePriceId |
server.billing.workspaceProSeatStripeProductId.secretKey |
The key within the Kubernetes Secret holding the workspaceProSeatStripeProductId secret as its value. | workspaceProSeatStripeProductId |
server.billing.workspaceMonthlyProSeatStripePriceId.secretKey |
The key within the Kubernetes Secret holding the workspaceMonthlyProSeatStripePriceId secret as its value. | workspaceMonthlyProSeatStripePriceId |
server.billing.workspaceYearlyProSeatStripePriceId.secretKey |
The key within the Kubernetes Secret holding the workspaceYearlyProSeatStripePriceId secret as its value. | workspaceYearlyProSeatStripePriceId |
server.billing.workspaceBusinessSeatStripeProductId.secretKey |
The key within the Kubernetes Secret holding the workspaceBusinessSeatStripeProductId secret as its value. | workspaceBusinessSeatStripeProductId |
server.billing.workspaceMonthlyBusinessSeatStripePriceId.secretKey |
The key within the Kubernetes Secret holding the workspaceMonthlyBusinessSeatStripePriceId secret as its value. | workspaceMonthlyBusinessSeatStripePriceId |
server.billing.workspaceYearlyBusinessSeatStripePriceId.secretKey |
The key within the Kubernetes Secret holding the workspaceYearlyBusinessSeatStripePriceId secret as its value. | workspaceYearlyBusinessSeatStripePriceId |
server.sessionSecret.secretName |
The name of the Kubernetes Secret containing the Session secret. This is a unique value (can be generated randomly). This is expected to be provided within the Kubernetes cluster as an opaque Kubernetes Secret. Ref: https://kubernetes.io/docs/concepts/configuration/secret/#opaque-secrets | "" |
server.sessionSecret.secretKey |
The key within the Kubernetes Secret holding the Session secret as its value. | "" |
server.auth |
Speckle provides a number of different mechanisms for authenticating users. Each available option must be configured here. | |
server.auth.local.enabled |
If enabled, users can register and authenticate with an email address and password. | true |
server.auth.google.enabled |
If enabled, users can authenticate via Google with their Google account credentials. If enabling Google, the server.auth.google.client_id parameter is required, and a secret must be provided via the Kubernetes secret referenced in server.auth.google.clientSecret . |
false |
server.auth.google.client_id |
This is the ID for Speckle that you have registered with Google. | "" |
server.auth.google.clientSecret.secretName |
The name of the Kubernetes Secret containing the Google client secret. This is expected to be provided within the Kubernetes cluster as an opaque Kubernetes Secret. Ref: https://kubernetes.io/docs/concepts/configuration/secret/#opaque-secrets | "" |
server.auth.google.clientSecret.secretKey |
The key within the Kubernetes Secret holding the Google client secret as its value. | "" |
server.auth.github.enabled |
If enabled, users can authenticate via Github with their Github account credentials. If enabling Github authentication, the server.auth.github.client_id parameter is required. |
false |
server.auth.github.client_id |
This is the ID for Speckle that you have registered with Github | "" |
server.auth.github.clientSecret.secretName |
The name of the Kubernetes Secret containing the GitHub client secret. This is expected to be provided within the Kubernetes cluster as an opaque Kubernetes Secret. Ref: https://kubernetes.io/docs/concepts/configuration/secret/#opaque-secrets | "" |
server.auth.github.clientSecret.secretKey |
The key within the Kubernetes Secret holding the GitHub client secret as its value. | "" |
server.auth.azure_ad.enabled |
If enabled, users can authenticate via Azure Active Directory. | false |
server.auth.azure_ad.org_name |
This is the Organisation Name that you have registered with Azure | "" |
server.auth.azure_ad.identity_metadata |
This is the identity metadata for Speckle that you have registered with Azure | "" |
server.auth.azure_ad.issuer |
This is the issuer name for Speckle that you have registered with Azure | "" |
server.auth.azure_ad.client_id |
This is the ID for Speckle that you have registered with Azure | "" |
server.auth.azure_ad.clientSecret.secretName |
The name of the Kubernetes Secret containing the Azure AD client secret. This is expected to be provided within the Kubernetes cluster as an opaque Kubernetes Secret. Ref: https://kubernetes.io/docs/concepts/configuration/secret/#opaque-secrets | "" |
server.auth.azure_ad.clientSecret.secretKey |
The key within the Kubernetes Secret holding the Azure AD client secret as its value. | "" |
server.auth.azure_ad.additional_domains |
List of matchName or matchPattern maps for domains that should be allow-listed for egress in Network Policy. https://docs.microsoft.com/en-us/azure/azure-portal/azure-portal-safelist-urls?tabs=public-cloud are enabled by default. |
[] |
server.auth.azure_ad.port |
Port on server to connect to. Used to allow egress in Network Policy. Defaults to 443 | 443 |
server.auth.oidc.enabled |
If enabled, users can authenticate via OpenID Connect identity provider | false |
server.auth.oidc.name |
This is the name that you want displayed on the login button | "" |
server.auth.oidc.discovery_url |
This is the OIDC discovery URL for the identity provider you want to use | "" |
server.auth.oidc.client_id |
This is the ID for Speckle that you have registered with the OIDC identity provider | "" |
server.auth.oidc.clientSecret.secretName |
The name of the Kubernetes Secret containing the OIDC client secret. This is expected to be provided within the Kubernetes cluster as an opaque Kubernetes Secret. Ref: https://kubernetes.io/docs/concepts/configuration/secret/#opaque-secrets | "" |
server.auth.oidc.clientSecret.secretKey |
The key within the Kubernetes Secret holding the OIDC client secret as its value. | "" |
server.auth.oidc.domains |
List of matchName or matchPattern maps for domains that should be allow-listed for egress in Network Policy. |
[] |
server.email |
Speckle can communicate with users via email, providing account verification and notification. | |
server.email.enabled |
If enabled, Speckle can send email to users - for example, email verification for account registration. | false |
server.email.host |
The domain name or IP address of the server hosting the email service. | "" |
server.email.port |
The port on the server for the email service. | "" |
server.email.from |
The email address from which Speckle will send emails. Defaults to ‘no-reply@speckle.systems’ if left blank. | "" |
server.email.username |
The username with which Speckle will authenticate with the email service. | "" |
server.email.password.secretName |
The name of the Kubernetes Secret containing the email password. This is expected to be provided within the Kubernetes cluster as an opaque Kubernetes Secret. Ref: https://kubernetes.io/docs/concepts/configuration/secret/#opaque-secrets | "" |
server.email.password.secretKey |
The key within the Kubernetes Secret holding the email password as its value. | "" |
server.email.networkPolicy |
If networkPolicy is enabled for Speckle server, this provides the Network Policy with the necessary details to allow egress connections to the email server | |
server.email.networkPolicy.externalToCluster |
Only required if the Redis store is not hosted within the Kubernetes cluster in which Speckle will be deployed. | |
server.email.networkPolicy.externalToCluster.enabled |
If enabled, indicates that the email server is hosted externally to the Kubernetes cluster | true |
server.email.networkPolicy.inCluster |
is only required if the email server is hosted within the Kubernetes cluster in which Speckle will be deployed. | |
server.email.networkPolicy.inCluster.enabled |
If enabled, indicates that the email server is hosted withing the same Kubernetes cluster in which Speckle will be deployed | false |
server.email.networkPolicy.inCluster.kubernetes.podSelector |
(Kubernetes Network Policy only) The pod Selector yaml object used to uniquely select the email server pods within the cluster and given namespace | {} |
server.email.networkPolicy.inCluster.kubernetes.namespaceSelector |
(Kubernetes Network Policy only) The namespace selector yaml object used to uniquely select the namespace in which the email server pods are deployed | {} |
server.email.networkPolicy.inCluster.cilium.endpointSelector |
(Cilium Network Policy only) The endpoint selector yaml object used to uniquely select the in-cluster endpoint in which the email server pods are deployed | {} |
server.email.networkPolicy.inCluster.cilium.serviceSelector |
(Cilium Network Policy only) The service selector yaml object used to uniquely select the in-cluster service providing the email server | {} |
server.requests.cpu |
The CPU that should be available on a node when scheduling this pod. | 1000m |
server.requests.memory |
The Memory that should be available on a node when scheduling this pod. | 1Gi |
server.limits.cpu |
The maximum CPU that will be made available to the server Pod in a given period. | 1500m |
server.limits.memory |
The maximum Memory that will be made available to the server Pod. | 3Gi |
server.ratelimiting.enabled |
If enabled, rate limiting will be applied to the Speckle server. | true |
server.ratelimiting.all_requests |
The maximum number of requests that can be made to the Speckle server in a moving one second window. | 500 |
server.ratelimiting.burst_all_requests |
If the regular limit is exceeded, the limit is increased to the burst limit. This is the maximum number of requests that can be made to the Speckle server in a moving one minute window. | 2000 |
server.ratelimiting.user_create |
The maximum number of requests that can be made to the Speckle server to create a new user in a moving one second window. | 6 |
server.ratelimiting.burst_user_create |
If the regular limit is exceeded, the limit is increased to the burst limit. This is the maximum number of requests that can be made to the Speckle server to create a new user in a moving one minute window. | 1000 |
server.ratelimiting.stream_create |
The maximum number of requests that can be made to the Speckle server to create a new stream in a moving one second window. | 1 |
server.ratelimiting.burst_stream_create |
If the regular limit is exceeded, the limit is increased to the burst limit. This is the maximum number of requests that can be made to the Speckle server to create a new stream in a moving one minute window. | 100 |
server.ratelimiting.commit_create |
The maximum number of requests that can be made to the Speckle server to create a new commit in a moving one second window. | 1 |
server.ratelimiting.burst_commit_create |
If the regular limit is exceeded, the limit is increased to the burst limit. This is the maximum number of requests that can be made to the Speckle server to create a new commit in a moving one minute window. | 100 |
server.ratelimiting.post_getobjects_streamid |
The maximum number of requests that can be made to the Speckle server to get a new object in a moving one second window. | 3 |
server.ratelimiting.burst_post_getobjects_streamid |
If the regular limit is exceeded, the limit is increased to the burst limit. This is the maximum number of requests that can be made to the Speckle server to get a new object in a moving one minute window. | 200 |
server.ratelimiting.post_diff_streamid |
The maximum number of requests that can be made to the Speckle server to undertake a diff in a moving one second window. | 10 |
server.ratelimiting.burst_post_diff_streamid |
If the regular limit is exceeded, the limit is increased to the burst limit. This is the maximum number of requests that can be made to the Speckle server to undertake a diff in a moving one minute window. | 1000 |
server.ratelimiting.post_objects_streamid |
The maximum number of requests that can be made to the Speckle server to post a new object in a moving one second window. | 6 |
server.ratelimiting.burst_post_objects_streamid |
If the regular limit is exceeded, the limit is increased to the burst limit. This is the maximum number of requests that can be made to the Speckle server to post a new object in a moving one minute window. | 400 |
server.ratelimiting.get_objects_streamid_objectid |
The maximum number of requests that can be made to the Speckle server to get an object in a moving one second window. | 3 |
server.ratelimiting.burst_get_objects_streamid_objectid |
If the regular limit is exceeded, the limit is increased to the burst limit. This is the maximum number of requests that can be made to the Speckle server to get an object in a moving one minute window. | 200 |
server.ratelimiting.get_objects_streamid_objectid_single |
The maximum number of requests that can be made to the Speckle server to get a single object in a moving one second window. | 3 |
server.ratelimiting.burst_get_objects_streamid_objectid_single |
If the regular limit is exceeded, the limit is increased to the burst limit. This is the maximum number of requests that can be made to the Speckle server to get a single object in a moving one minute window. | 200 |
server.ratelimiting.post_graphql |
The maximum number of requests that can be made to the GraphQL API in a moving one second window. | 50 |
server.ratelimiting.burst_post_graphql |
If the regular limit is exceeded, the limit is increased to the burst limit. This is the maximum number of requests that can be made to the GraphQL API in a moving one minute window. | 200 |
server.ratelimiting.get_auth |
The maximum number of requests that can be made to the Speckle server to authenticate in a moving 10 minute window. | 4 |
server.ratelimiting.burst_get_auth |
If the regular limit is exceeded, the limit is increased to the burst limit. This is the maximum number of requests that can be made to the Speckle server to authenticate in a moving thirty minute window. | 10 |
server.serviceAccount.create |
If enabled, a Kubernetes Service Account will be created for this pod. | true |
server.fileUploads.enabled |
If enabled, file uploads on the server will be flagged as enabled | true |
server.mailchimp.enabled |
Mailchimp integration feature flag | false |
server.mailchimp.apikey.secretName |
The name of the Kubernetes Secret containing the Mailchimp API key. | "" |
server.mailchimp.apikey.secretKey |
The key within the Kubernetes Secret holding the Mailchimp API key as its value. | mailchimp_apikey |
server.mailchimp.serverPrefix |
Mailchimp api server prefix | "" |
server.mailchimp.newsletterListId |
Audience id for the newsletter list | "" |
server.mailchimp.onboardingListId |
Audience id for the onboarding list | "" |
server.mailchimp.onboardingJourneyId |
Id of the onboarding journey | "" |
server.mailchimp.onboardingStepId |
Id of the onboarding journey step we trigger | "" |
server.migration.movedFrom |
Indicate the URL where the server moved from | "" |
server.migration.movedTo |
Indicate the URL where the server moved to | "" |
server.monitoring.apollo.enabled |
(Optional) If enabled, exports metrics from the GraphQL API to Apollo Graphql Studio. | false |
server.monitoring.apollo.graph_id |
The ID for Speckle that you registered in Apollo Graphql Studio. | "" |
server.monitoring.apollo.key.secretName |
The name of the Kubernetes Secret containing the Apollo monitoring key. This is expected to be provided within the Kubernetes cluster as an opaque Kubernetes Secret. Ref: https://kubernetes.io/docs/concepts/configuration/secret/#opaque-secrets | "" |
server.monitoring.apollo.key.secretKey |
The key within the Kubernetes Secret holding the Apollo monitoring key as its value. | "" |
server.monitoring.mp |
(Optional) If server.monitoring.mp.enabled is set to false, metrics will not be collected by the Speckle server. | {} |
server.disable_tracking |
If set to true, will prevent tracking metrics from being collected | false |
server.disable_tracing |
If set to true, will prevent tracing metrics from being collected | false |
server.networkPolicy.enabled |
If enabled, will provide additional security be limiting network traffic into and out of the pod to only the required endpoints and ports. | false |
server.affinity |
Affinity for Speckle server pods scheduling | {} |
server.nodeSelector |
Node labels for Speckle server pods scheduling | {} |
server.tolerations |
Tolerations for Speckle server pods scheduling | [] |
server.topologySpreadConstraints |
Spread Constraints for Speckle server pod scheduling | [] |
Defines parameters related to the backend server component of Speckle.
Name | Description | Value |
---|---|---|
objects.replicas |
The number of instances of the Server pod to be deployed within the cluster. | 1 |
objects.image |
The Docker image to be used for the Speckle Objects component. If blank, defaults to speckle/speckle-server:. If provided, this value should be the full path including tag. The docker_image_tag value will be ignored. | "" |
objects.logLevel |
The minimum level of logs which will be output. Suitable values are trace, debug, info, warn, error, fatal, or silent | info |
objects.logPretty |
If enabled, will output logs in a human-readable format. Otherwise, logs will be output in JSON format. | false |
objects.inspect.enabled |
If enabled, indicates that the Speckle server should be deployed with the nodejs inspect feature enabled | false |
objects.inspect.port |
The port on which the nodejs inspect feature should be exposed | 7000 |
objects.requests.cpu |
The CPU that should be available on a node when scheduling this pod. | 1000m |
objects.requests.memory |
The Memory that should be available on a node when scheduling this pod. | 1Gi |
objects.limits.cpu |
The maximum CPU that will be made available to the server Pod in a given period. | 1500m |
objects.limits.memory |
The maximum Memory that will be made available to the server Pod. | 3Gi |
objects.ratelimiting.post_objects_streamid |
The maximum number of requests that can be made to the Speckle server to post a new object in a moving one second window. | 6 |
objects.ratelimiting.burst_post_objects_streamid |
If the regular limit is exceeded, the limit is increased to the burst limit. This is the maximum number of requests that can be made to the Speckle server to post a new object in a moving one minute window. | 400 |
objects.ratelimiting.get_objects_streamid_objectid |
The maximum number of requests that can be made to the Speckle server to get an object in a moving one second window. | 3 |
objects.ratelimiting.burst_get_objects_streamid_objectid |
If the regular limit is exceeded, the limit is increased to the burst limit. This is the maximum number of requests that can be made to the Speckle server to get an object in a moving one minute window. | 200 |
objects.ratelimiting.get_objects_streamid_objectid_single |
The maximum number of requests that can be made to the Speckle server to get a single object in a moving one second window. | 3 |
objects.ratelimiting.burst_get_objects_streamid_objectid_single |
If the regular limit is exceeded, the limit is increased to the burst limit. This is the maximum number of requests that can be made to the Speckle server to get a single object in a moving one minute window. | 200 |
objects.serviceAccount.create |
If enabled, a Kubernetes Service Account will be created for this pod. | true |
objects.networkPolicy.enabled |
If enabled, will provide additional security be limiting network traffic into and out of the pod to only the required endpoints and ports. | false |
objects.affinity |
Affinity for Speckle server pods scheduling | {} |
objects.nodeSelector |
Node labels for Speckle server pods scheduling | {} |
objects.tolerations |
Tolerations for Speckle server pods scheduling | [] |
objects.topologySpreadConstraints |
Spread Constraints for Speckle server pod scheduling | [] |
Defines parameters related to the frontend server component of Speckle.
Name | Description | Value |
---|---|---|
frontend.replicas |
The number of instances of the Frontend pod to be deployed within the cluster. | 1 |
frontend.logLevel |
The minimum level of logs which will be output. Suitable values are trace, debug, info, warn, error, fatal, or silent | info |
frontend.logPretty |
If enabled, will output logs in a human-readable format. Otherwise, logs will be output in JSON format. | false |
frontend.image |
The Docker image to be used for the Speckle Frontend component. If blank, defaults to speckle/speckle-frontend:. If provided, this value should be the full path including tag. The docker_image_tag value will be ignored. | "" |
frontend.requests.cpu |
The CPU that should be available on a node when scheduling this pod. | 250m |
frontend.requests.memory |
The Memory that should be available on a node when scheduling this pod. | 256Mi |
frontend.limits.cpu |
The maximum CPU that will be made available to the frontend Pod in a given period. | 1000m |
frontend.limits.memory |
The maximum Memory that will be made available to the frontend Pod. | 512Mi |
frontend.networkPolicy.enabled |
If enabled, will provide additional security be limiting network traffic into and out of the pod to only the required endpoints and ports. | false |
frontend.affinity |
Affinity for Speckle frontend pod scheduling | {} |
frontend.nodeSelector |
Node labels for Speckle frontend pods scheduling | {} |
frontend.tolerations |
Tolerations for Speckle frontend pods scheduling | [] |
frontend.topologySpreadConstraints |
Spread Constraints for Speckle frontend pod scheduling | [] |
frontend.serviceAccount.create |
If enabled, a Kubernetes Service Account will be created for this pod. | true |
Defines parameters related to the new web application component of Speckle
Name | Description | Value |
---|---|---|
frontend_2.image |
The Docker image to be used for the Speckle Frontend 2 component. If blank, defaults to speckle/speckle-frontend-2:. If provided, this value should be the full path including tag. The docker_image_tag value will be ignored. | "" |
frontend_2.webflowApiToken |
API Key for Webflow, which provides the blog content for the new web application frontend. | "" |
frontend_2.logClientApiToken |
SEQ API token | "" |
frontend_2.logClientApiEndpoint |
SEQ endpoint URL | "" |
frontend_2.logLevel |
The minimum level of logs which will be output. Suitable values are trace, debug, info, warn, error, fatal, or silent | info |
frontend_2.logPretty |
If enabled, will output logs in a human-readable format. Otherwise, logs will be output in JSON format. | false |
frontend_2.inspect.enabled |
If enabled, indicates that the Speckle FE2 should be deployed with the nodejs inspect feature enabled | false |
frontend_2.inspect.port |
The port on which the nodejs inspect feature should be exposed | 7000 |
frontend_2.enabled |
Feature flag to enable running the new web application frontend. | true |
frontend_2.replicas |
The number of instances of the Frontend 2 server prod to be deployed withing the cluster. | 1 |
frontend_2.requests.cpu |
The CPU that should be available on a node when scheduling this pod. | 250m |
frontend_2.requests.memory |
The Memory that should be available on a node when scheduling this pod. | 256Mi |
frontend_2.limits.cpu |
The maximum CPU that will be made available to the frontend Pod in a given period. | 1000m |
frontend_2.limits.memory |
The maximum Memory that will be made available to the frontend Pod. | 512Mi |
frontend_2.networkPolicy.enabled |
If enabled, will provide additional security be limiting network traffic into and out of the pod to only the required endpoints and ports. | false |
frontend_2.affinity |
Affinity for Speckle frontend pod scheduling | {} |
frontend_2.nodeSelector |
Node labels for Speckle frontend pods scheduling | {} |
frontend_2.tolerations |
Tolerations for Speckle frontend pods scheduling | [] |
frontend_2.topologySpreadConstraints |
Spread Constraints for Speckle frontend pod scheduling | [] |
frontend_2.serviceAccount.create |
If enabled, a Kubernetes Service Account will be created for this pod. | true |
Defines parameters related to the Preview Service component of Speckle.
Name | Description | Value |
---|---|---|
preview_service.replicas |
The number of instances of the Preview Service pod to be deployed within the cluster. | 1 |
preview_service.logLevel |
The minimum level of logs which will be output. Suitable values are trace, debug, info, warn, error, fatal, or silent | info |
preview_service.logPretty |
If enabled, will output logs in a human-readable format. Otherwise, logs will be output in JSON format. | false |
preview_service.image |
The Docker image to be used for the Speckle Preview Service component. If blank, defaults to speckle/speckle-preview-service:. If provided, this value should be the full path including tag. The docker_image_tag value will be ignored. | "" |
preview_service.port |
The port on which the Preview Service will run. This is not exposed, but used within its own local network within the pod. | 3001 |
preview_service.monitoring.metricsPort |
The port on which the metrics server will be exposed. | 9094 |
preview_service.postgresMaxConnections |
The maximum number of connections that the Preview Service postgres client will make to the Postgres database. | 2 |
preview_service.puppeteer.userDataDirectory |
The path to the user data directory. If not set, defaults to ‘/tmp/puppeteer’. This is mounted in the deployment as a volume with read-write access. | "" |
preview_service.puppeteer.timeoutMilliseconds |
The timeout in milliseconds for the Puppeteer service. | 3600000 |
preview_service.requests.cpu |
The CPU that should be available on a node when scheduling this pod. | 500m |
preview_service.requests.memory |
The Memory that should be available on a node when scheduling this pod. | 2Gi |
preview_service.limits.cpu |
The maximum CPU that will be made available to the Preview Service Pod in a given period. | 1000m |
preview_service.limits.memory |
The maximum Memory that will be made available to the Preview Service Pod. | 4Gi |
preview_service.networkPolicy.enabled |
If enabled, will provide additional security be limiting network traffic into and out of the pod to only the required endpoints and ports. | false |
preview_service.affinity |
Affinity for Speckle Preview Service pod scheduling | {} |
preview_service.nodeSelector |
Node labels for Speckle Preview Service pods scheduling | {} |
preview_service.tolerations |
Tolerations for Speckle Preview Service pods scheduling | [] |
preview_service.topologySpreadConstraints |
Spread Constraints for Speckle Preview Service pod scheduling | [] |
preview_service.serviceAccount.create |
If enabled, a Kubernetes Service Account will be created for this pod. | true |
Defines parameters related to the Webhook Service component of Speckle.
Name | Description | Value |
---|---|---|
webhook_service.replicas |
The number of instances of the Webhook Service pod to be deployed within the cluster. | 1 |
webhook_service.logLevel |
The minimum level of logs which will be output. Suitable values are trace, debug, info, warn, error, fatal, or silent | info |
webhook_service.logPretty |
If enabled, will output logs in a human-readable format. Otherwise, logs will be output in JSON format. | false |
webhook_service.image |
The Docker image to be used for the Speckle Webhook Service component. If blank, defaults to speckle/speckle-webhook-service:. If provided, this value should be the full path including tag. The docker_image_tag value will be ignored. | "" |
webhook_service.postgresMaxConnections |
The maximum number of connections that the Webhook Service postgres client will make to the Postgres database. | 1 |
webhook_service.requests.cpu |
The CPU that should be available on a node when scheduling this pod. | 500m |
webhook_service.requests.memory |
The Memory that should be available on a node when scheduling this pod. | 2Gi |
webhook_service.limits.cpu |
The maximum CPU that will be made available to the Webhook Service Pod in a given period. | 1000m |
webhook_service.limits.memory |
The maximum Memory that will be made available to the Webhook Service Pod. | 4Gi |
webhook_service.networkPolicy.enabled |
If enabled, will provide additional security be limiting network traffic into and out of the pod to only the required endpoints and ports. | false |
webhook_service.affinity |
Affinity for Speckle Webhook Service pod scheduling | {} |
webhook_service.nodeSelector |
Node labels for Speckle Webhook Service pods scheduling | {} |
webhook_service.tolerations |
Tolerations for Speckle Webhook Service pods scheduling | [] |
webhook_service.topologySpreadConstraints |
Spread Constraints for Speckle Webhook Service pod scheduling | [] |
webhook_service.serviceAccount.create |
If enabled, a Kubernetes Service Account will be created for this pod. | true |
Defines parameters related to the File Import Service component of Speckle.
Name | Description | Value |
---|---|---|
fileimport_service.replicas |
The number of instances of the FileImport Service pod to be deployed within the cluster. | 1 |
fileimport_service.logLevel |
The minimum level of logs which will be output. Suitable values are trace, debug, info, warn, error, fatal, or silent | info |
fileimport_service.logPretty |
If enabled, will output logs in a human-readable format. Otherwise, logs will be output in JSON format. | false |
fileimport_service.image |
The Docker image to be used for the Speckle FileImport Service component. If blank, defaults to speckle/speckle-fileimport-service:. If provided, this value should be the full path including tag. The docker_image_tag value will be ignored. | "" |
fileimport_service.postgresMaxConnections |
The maximum number of connections that the File Import Service postgres client will make to the Postgres database. | 1 |
fileimport_service.requests.cpu |
The CPU that should be available on a node when scheduling this pod. | 100m |
fileimport_service.requests.memory |
The Memory that should be available on a node when scheduling this pod. | 512Mi |
fileimport_service.limits.cpu |
The maximum CPU that will be made available to the FileImport Service Pod in a given period. | 1000m |
fileimport_service.limits.memory |
The maximum Memory that will be made available to the FileImport Service Pod. | 2Gi |
fileimport_service.networkPolicy.enabled |
If enabled, will provide additional security be limiting network traffic into and out of the pod to only the required endpoints and ports. | false |
fileimport_service.affinity |
Affinity for Speckle FileImport Service pod scheduling | {} |
fileimport_service.nodeSelector |
Node labels for Speckle FileImport Service pods scheduling | {} |
fileimport_service.tolerations |
Tolerations for Speckle FileImport Service pods scheduling | [] |
fileimport_service.topologySpreadConstraints |
Spread Constraints for Speckle FileImport Service pod scheduling | [] |
fileimport_service.serviceAccount.create |
If enabled, a Kubernetes Service Account will be created for this pod. | true |
fileimport_service.time_limit_min |
The maximum time that a file can take to be processed by the FileImport Service. | 10 |
Provides Speckle with metrics related to the Postgres database.
Name | Description | Value |
---|---|---|
monitoring.replicas |
The number of instances of the Monitoring pod to be deployed within the cluster. | 1 |
monitoring.logLevel |
The minimum level of logs which will be output. Suitable values are trace, debug, info, warn, error, fatal, or silent | info |
monitoring.logPretty |
If enabled, will output logs in a human-readable format. Otherwise, logs will be output in JSON format. | false |
monitoring.port |
The port on which the Monitoring Service will run. | 9092 |
monitoring.maximumPostgresConnections |
The maximum number of connections that the Monitoring Service will allow to the Postgres database. A connection pool exists to manage access to the connections. | 2 |
monitoring.metricsCollectionPeriodSeconds |
The period in seconds at which the Monitoring Service will query the Postgres database for metrics. Unlike typical Prometheus metrics, the data from the database is not collected in real-time when /metrics is accessed, and is instead done out-of-band on a timed interval. | 120 |
monitoring.image |
The Docker image to be used for the Speckle Monitoring component. If blank, defaults to speckle/speckle-monitoring-deployment:. If provided, this value should be the full path including tag. The docker_image_tag value will be ignored. | "" |
monitoring.requests.cpu |
The CPU that should be available on a node when scheduling this pod. | 100m |
monitoring.requests.memory |
The Memory that should be available on a node when scheduling this pod. | 64Mi |
monitoring.limits.cpu |
The maximum CPU that will be made available to the Monitoring Pod in a given period. | 200m |
monitoring.limits.memory |
The maximum Memory that will be made available to the Monitoring Pod. | 512Mi |
monitoring.networkPolicy.enabled |
If enabled, will provide additional security be limiting network traffic into and out of the pod to only the required endpoints and ports. | false |
monitoring.affinity |
Affinity for Speckle Monitoring pod scheduling | {} |
monitoring.nodeSelector |
Node labels for Speckle Monitoring pods scheduling | {} |
monitoring.tolerations |
Tolerations for Speckle Monitoring pods scheduling | [] |
monitoring.topologySpreadConstraints |
Spread Constraints for Speckle Monitoring pod scheduling | [] |
monitoring.serviceAccount.create |
If enabled, a Kubernetes Service Account will be created for this pod. | true |
Defines parameters related to testing that the deployment of Speckle has been successful.
Name | Description | Value |
---|---|---|
helm_test_enabled |
If enabled, an additional pod is deployed which verifies some functionality of Speckle to determine if it is deployed correctly | true |
test.logLevel |
The minimum level of logs which will be output. Suitable values are trace, debug, info, warn, error, fatal, or silent | info |
test.logPretty |
If enabled, will output logs in a human-readable format. Otherwise, logs will be output in JSON format. | false |
test.image |
The Docker image to be used for the Speckle Test component. If blank, defaults to speckle/speckle-test-deployment:. If provided, this value should be the full path including tag. The docker_image_tag value will be ignored. | "" |
test.requests.cpu |
The CPU that should be available on a node when scheduling this pod. | 100m |
test.requests.memory |
The Memory that should be available on a node when scheduling this pod. | 64Mi |
test.limits.cpu |
The maximum CPU that will be made available to the Test Pod in a given period. | 200m |
test.limits.memory |
The maximum Memory that will be made available to the Test Pod. | 512Mi |
test.networkPolicy.enabled |
If enabled, will provide additional security be limiting network traffic into and out of the pod to only the required endpoints and ports. | false |
test.serviceAccount.create |
If enabled, a Kubernetes Service Account will be created for this pod. | true |
Make sure to also check and ⭐️ these other Speckle repositories:
speckle-server
: Speckle Serverspeckle-sharp
: .NET tooling, connectors and interoperabilityspecklepy
: Python SDK 🐍speckle-excel
: Excel connectorspeckle-unity
: Unity 3D connectorspeckle-blender
: Blender connectorspeckle-unreal
: Unreal Engine Connectorspeckle-qgis
: QGIS connectodspeckle-powerbi
: PowerBi connectorThis repository is a clone of the Helm chart in the Speckle Server repository.
⚠️ Pull requests are not accepted to this repository ⚠️. Instead, please contribute to the Helm chart within the Speckle Server repository.
For any security vulnerabilities or concerns, please contact us directly at security[at]speckle.systems.
Unless otherwise described, the code in this repository is licensed under the Apache-2.0 License. Please note that some modules, extensions or code herein might be otherwise licensed. This is indicated either in the root of the containing folder under a different license file, or in the respective file’s header. If you have any questions, don’t hesitate to get in touch with us via email.