## Description See https://github.com/appsmithorg/appsmith/issues/36761 I've been tested this with ee Helm chart. Imho tcp/8080 should be the default port but to avoid breaking change, tcp/80 remains the default port if the new variable is not specified. Fixes #36761 ## Automation /ok-to-test tags="" ### 🔍 Cypress test results <!-- This is an auto-generated comment: Cypress test results --> > [!CAUTION] > If you modify the content in this section, you are likely to disrupt the CI result for your PR. <!-- end of auto-generated comment: Cypress test results --> ## Communication Should the DevRel and Marketing teams inform users about this change? - [ ] Yes - [X] No <!-- This is an auto-generated comment: release notes by coderabbit.ai --> ## Summary by CodeRabbit - **New Features** - Enhanced configurability of the HTTP container port through the introduction of a new variable (commented out). - Updated the Helm chart version from 2.1.0 to 2.2.0. - **Bug Fixes** - Improved indentation and formatting for better readability. - **Documentation** - Commented-out configuration for `HTTPContainerPort` included for future reference. <!-- end of auto-generated comment: release notes by coderabbit.ai --> --------- Co-authored-by: Damien LEGER <damien.leger@cure51.com> Co-authored-by: coderabbitai[bot] <136622811+coderabbitai[bot]@users.noreply.github.com> Co-authored-by: Goutham Pratapa <pratapagoutham@gmail.com> Co-authored-by: Goutham Pratapa <goutham@appsmith.com> |
||
|---|---|---|
| .. | ||
| images | ||
| templates | ||
| .helmignore | ||
| Chart.lock | ||
| Chart.yaml | ||
| Publish-helm-chart.md | ||
| README.md | ||
| Setup-https.md | ||
| values.yaml | ||
Appsmith
Appsmith is a JS-based internal tool development platform. Internal tools take a lot of time to build even though they involve the same UI components, data integrations, and user access management. Developers love Appsmith because it saves them hundreds of hours.
Build interactive web apps by using UI components like a table, form components, button, charts, rich text editor, map, tabs, modal, and many more.
API Support: CURL importer for REST APIs Database Support: PostgreSQL, MongoDB, MySQL, Redshift, Elastic Search, DynamoDB, Redis, & MSFT SQL Server.
TL;DR
helm repo add stable-appsmith http://helm.appsmith.com
helm repo update
helm install stable-appsmith/appsmith --generate-name
Introduction
This chart bootstrap an Appsmith deployment on a Kubernetes cluster using Helm package manager.
Prerequisites
- Install Helm package manager: https://helm.sh/docs/intro/install/
- Ensure
kubectlis installed and configured to connect to your cluster-
Install kubectl: kubernetes.io/vi/docs/tasks/tools/install-kubectl/
-
Minikube: Setup Kubectl
-
Google Cloud Kubernetes: Configuring cluster access for kubectl
-
Aws EKS: Create a kubeconfig for Amazon EKS
-
Microk8s: Working with kubectl
-
- Ensure you have a default storage class running on your cluster. Please follow one of below guideline to enable your default storage class in case of no existing one
- Minikube: Enable addon default-storageclass
- Google Cloud Kubernetes: Setting up default storage class on GKE
- AWS EKS: Create default storage class
- Microk8s: Enable storage
- Kubernetes NGINX Ingress Controller should be enable on your cluster by default. Please make sure that you install the right version for your cluster
- Minikube: Set up Ingress on Minikube with the NGINX Ingress Controller
- Google Cloud Kubernetes: Ingress with NGINX controller on Google Kubernetes Engine
- AWS EKS: Install NGINX Controller for AWS EKS
- Microk8s: Add on: Ingress
Installing the Chart
To install the chart with the release appsmith
helm install stable-appsmith/appsmith --generate-name
The command deploys Appsmith application on Kubernetes cluster in the default configuration. The Parameters section lists the parameters that can be configured during installation.
Uninstalling the Chart
To uninstall the appsmith release:
helm list
NAME NAMESPACE REVISION UPDATED STATUS CHART APP VERSION
appsmith-1631069261 default 1 2021-09-09 11:24:40.152766 +0700 +07 deployed appsmith-1.3.0 1.16.0
helm uninstall appsmith-1631069261
The command uninstalls the release and removes all Kubernetes resources associated with the chart
Parameters
Global parameters
| Name | Description | Value |
|---|---|---|
global.namespaceOverride |
Override the namespace for resource deployed by the chart | "" |
global.storageClass |
Global StorageClass for Persistent Volume(s) | "" |
Common parameters
| Name | Description | Value |
|---|---|---|
fullnameOverride |
String to fully override appsmith.name template |
"" |
containerName |
Specify container's name running in the pods | "appsmith" |
commonLabels |
Labels to add to all deployed objects | {} |
commonAnnotations |
Annotations to add to all deployed objects | {} |
Appsmith Image parameters
| Name | Description | Value |
|---|---|---|
image.registry |
Appsmith image registry | index.docker.io |
image.repository |
Appsmith image repository | appsmith/appsmith-ce |
image.tag |
Appsmith image tag | latest |
image.pullPolicy |
Appsmith image pull policy | IfNotPresent |
Appsmith deployment parameters
| Name | Description | Value |
|---|---|---|
strategyType |
Appsmith deployment strategy type | RollingUpdate |
schedulerName |
Alternate scheduler | "" |
podAnnotations |
Annotations for Appsmith pods | {} |
podLabels |
Labels for Appsmith pods | {} |
podSecurityContext |
Appsmith pods security context | {} |
securityContext |
Set security context | {} |
resources.limit |
The resources limits for the Appsmith container | {} |
resources.requests |
The requested resources for the Appsmith container | {} |
nodeSelector |
Node labels for pod assignment | {} |
tolerations |
Tolerations for pod assignment | [] |
affinity |
Affinity fod pod assignment | {} |
Appsmith service account parameters
| Name | Description | Value |
|---|---|---|
serviceAccount.create |
Enable creation of ServiceAccount for Appsmith pods |
true |
serviceAccount.name |
Name of the created ServiceAccount . If not set, a name is generated using the appsmith.fullname template |
"" |
serviceAccount.annotations |
Additional service account annotations | {} |
Traffic Exposure Parameters
| Name | Description | Value |
|---|---|---|
service.type |
Appsmith service type | ClusterIP |
service.port |
Appsmith service port | 80 |
service.portName |
Appsmith service port name | appsmith |
service.nodePort |
Appsmith service node port to expose to expose | 8000 |
service.clusterIP |
Appsmith service Cluster | "" |
service.loadBalancerIP |
Appsmith service Load Balancer IP | "" |
service.loadBalancerSourceRanges |
Appsmith service Load Balancer sources | [] |
service.annotations |
Additional custom annotations for Appsmith service | {} |
ingress.enabled |
Enable ingress record generation for Appsmith | false |
ingress.annotations |
Additional custom annotations for Ingress | {} |
ingress.hosts |
An array of hosts to be covered with the ingress record | [] |
ingress.tls |
Enable TLS configuration for the hosts defined at ingress.hosts parameter |
false |
ingress.secrets |
Custom TLS certificates as secrets | [] |
ingress.certManager |
Enable ingress to use TLS certificates provided by Cert Manager | false |
ingress.certManagerTls |
Specify TLS secret resources created by Cert Manager | [] |
ingress.className |
Configure Ingress class that being used in ingress resource | "" |
Persistence parameters
| Name | Description | Value |
|---|---|---|
persistence.enabled |
Enable persistence using Persistent Volume Claims | true |
persistence.storageClass |
Persistent Volume storage class | "" |
persistence.annotations |
Additional custom annotations for the PVC | {} |
persistence.localStorage |
Enable persistent volume using local storage | false |
persistence.storagePath |
Local storage path | /tmp/hostpath_pv |
persistence.localCluster |
Local running cluster to provide storage space | [minikube] |
persistence.accessModes |
Persistent Volume access modes | [ReadWriteOnce] |
persistence.size |
Persistent Volume size | 10Gi |
storageClass.enabled |
Enable Storage Class configuration | false |
storageClass.defaultClass |
Create default Storage Class | false |
storageClass.bindingMode |
Binding mode for Persistent Volume Claims using Storage Class | Immediate |
storageClass.allowVolumeExpansion |
Allow expansion of Persistent Volume Claims using Storage Class | true |
storageClass.reclaimPolicy |
Configure the retention of the dynamically created Persistent Volume | Delete |
storageClass.provisioner |
Storage Class provisioner | "" |
storageClass.annotations |
Additional storage class annotations | {} |
storageClass.mountOptions |
Mount options used by Persistent Volumes | {} |
storageClass.parameters |
Storage Class parameters | {} |
Auto update chart's image
| Name | Description | Value |
|---|---|---|
autoupdate.enabled |
Enable auto update Helm chart's image | true |
autoupdate.scheduler |
Schedule time to run cron job to update image | "0 * * * *" |
Specify each parameter using --set key=value[,key=value] argument to helm install. For example:
helm install \
--set persistence.storageClass=appsmith-pv \
stable-appsmith/appsmith --generate-name
The above command deploys Appsmith application and configure application to use storage class name appsmith-pv
Alternatively, a YAML file that specifies the values for the parameters can be provided while installing the chart. For example:
helm install -f values.yaml stable-appsmith/appsmith --generate-name
Tip: You can use the default values.yaml
Appsmith configuration
To change Appsmith configurations, you can use configuration UI in application or update value in values.yaml(The available configurations is listed below).
| Name | Value |
|---|---|
applicationConfig.APPSMITH_OAUTH2_GOOGLE_CLIENT_ID |
"" |
applicationConfig.APPSMITH_OAUTH2_GOOGLE_CLIENT_SECRET |
"" |
applicationConfig.APPSMITH_OAUTH2_GITHUB_CLIENT_ID |
"" |
applicationConfig.APPSMITH_OAUTH2_GITHUB_CLIENT_SECRET |
"" |
applicationConfig.APPSMITH_CLIENT_LOG_LEVEL |
"" |
applicationConfig.APPSMITH_MAIL_ENABLED |
"" |
applicationConfig.APPSMITH_MAIL_HOST |
"" |
applicationConfig.APPSMITH_MAIL_PORT |
"" |
applicationConfig.APPSMITH_MAIL_USERNAME |
"" |
applicationConfig.APPSMITH_MAIL_PASSWORD |
"" |
applicationConfig.APPSMITH_MAIL_FROM |
"" |
applicationConfig.APPSMITH_REPLY_TO |
"" |
applicationConfig.APPSMITH_MAIL_SMTP_AUTH |
"" |
applicationConfig.APPSMITH_MAIL_SMTP_TLS_ENABLED |
"" |
applicationConfig.APPSMITH_DISABLE_TELEMETRY |
"" |
applicationConfig.APPSMITH_RECAPTCHA_SITE_KEY |
"" |
applicationConfig.APPSMITH_RECAPTCHA_SECRET_KEY |
"" |
applicationConfig.APPSMITH_RECAPTCHA_ENABLED |
"" |
applicationConfig.APPSMITH_MONGODB_URI |
"" |
applicationConfig.APPSMITH_REDIS_URL |
"" |
applicationConfig.APPSMITH_ENCRYPTION_PASSWORD |
"" |
applicationConfig.APPSMITH_ENCRYPTION_SALT |
"" |
applicationConfig.APPSMITH_CUSTOM_DOMAIN |
"" |
applicationConfig.APPSMITH_FORM_LOGIN_DISABLED |
"" |
applicationConfig.APPSMITH_SIGNUP_DISABLED |
"" |
For example, to change the encryption salt configuration, you can run the following command:
helm install \
--set applicationConfig.APPSMITH_ENCRYPTION_SALT=123 \
stable-appsmith/appsmith --generate-name
Expose Appsmith
- If you wish to publish your Appsmith to the world through the Internet, you will need to setup the Ingress controller firstly. Please refer to the section Kubernetes NGINX Ingress Controller in the Prerequisites
- In case of you have not install the Helm chart yet, you can run the below command to install it with exposing Appsmith
helm install stable-appsmith/appsmith --generate-name \
--set ingress.enabled=true \
--set ingress.annotations."kubernetes\.io/ingress\.class"=nginx \
--set service.type=ClusterIP
- If you have installed Appsmith Helm chart, please run the
helm upgradecommand to upgrade the existing installation
helm upgrade stable-appsmith/appsmith appsmith \
--set ingress.enabled=true \
--set ingress.annotations."kubernetes\.io/ingress\.class"=nginx \
--set service.type=ClusterIP
# Or this command if you are using values.yaml file
helm upgrade --values values.yaml stable-appsmith/appsmith appsmith
Troubleshooting
If at any time you encounter an error during the installation process, reach out to support@appsmith.com or join our Discord Server
If you know the error and would like to reinstall Appsmith, simply delete the installation folder and the templates folder and execute the script again