OneUptime is a comprehensive solution for monitoring and managing your online services. Whether you need to check the availability of your website, dashboard, API, or any other online resource, OneUptime can alert your team when downtime happens and keep your customers informed with a status page. OneUptime also helps you handle incidents, set up on-call rotations, run tests, secure your services, analyze logs, track performance, and debug errors.
Create a values.yaml file and change the host.
host: <ip-address-or-domain-of-server>
# If hosted on non-ssl server then change this to http
httpProtocol: https
Storage class are different for different cloud environemtns. Please pick the right one for your cloud environment.
To get a list of storage classes, run the following command:
kubectl get storageclass
and add this to your values.yaml file
global:
storageClass: "your-storage-class"
helm repo add oneuptime https://helm-chart.oneuptime.com/
helm install my-oneuptime oneuptime/oneuptime -f values.yaml
# Update the chart repo
helm repo update
# Upgrade the helm chart
helm upgrade my-oneuptime oneuptime/oneuptime -f values.yaml
To uninstall/delete the my-oneuptime
deployment:
helm uninstall my-oneuptime
The following table lists the configurable parameters of the OneUptime chart and their default values.
Parameter | Description | Default | Change Required |
---|---|---|---|
global.storageClass |
Storage class to be used for all persistent volumes | nil |
🚨 |
host |
Hostname for the ingress | localhost |
🚨 |
httpProtocol |
If the server is hosted with SSL/TLS cert then change this value to https | http |
🚨 |
oneuptimeSecret |
Value used to define ONEUPTIME_SECRET | nil |
|
encryptionSecret |
Value used to define ENCRYPTION_SECRET | nil |
|
global.clusterDomain |
Kubernetes Cluster Domain | cluster.local |
|
image.registry |
Docker image registry | docker.io |
|
image.repository |
Docker image repository | oneuptime |
|
image.tag |
Docker image tag | release |
|
image.pullPolicy |
Docker image pull policy | IfNotPresent |
|
image.restartPolicy |
Docker image restart policy | Always |
|
autoScaling.enabled |
Enable autoscaling | false |
|
autoScaling.minReplicas |
Minimum number of replicas | 1 |
|
autoScaling.maxReplicas |
Maximum number of replicas | 100 |
|
autoScaling.targetCPUUtilizationPercentage |
Target CPU utilization percentage | 80 |
|
autoScaling.targetMemoryUtilizationPercentage |
Target memory utilization percentage | 80 |
|
nodeEnvironment |
Node environment (please dont change this unless you're doing local development) | production |
|
nginx.service.type |
nginx service type | LoadBalancer |
|
nginx.service.loadBalancerIP |
nginx service load balancer IP | nil |
|
deployment.replicaCount |
Number of replicas | 1 |
|
probes.<key>.name |
Probe name | <key> |
|
probes.<key>.description |
Probe description | nil |
|
probes.<key>.key |
Probe key. Please set this to long random string to secure your probes. | nil |
|
probes.<key>.monitoringWorkers |
Number of threads / parallel processes you need to monitor your resources | 3 |
|
probes.<key>.monitorFetchLimit |
Number of resources to be monitored in parallel | 10 |
|
probes.<key>.syntheticMonitorScriptTimeoutInMs |
Timeout for synthetic monitor script | 60000 |
|
probes.<key>.customCodeMonitorScriptTimeoutInMs |
Timeout for custom code monitor script | 60000 |
|
statusPage.cnameRecord |
CNAME record for the status page | nil |
|
internalSmtp.sendingDomain |
Domain to send emails from | nil |
|
internalSmtp.dkimPrivateKey |
DKIM Private Key that is set for sending domain | nil |
|
internalSmtp.dkimPublicKey |
DKIM Public Key that is set for sending domain | nil |
|
internalSmtp.email |
Email address to send emails from | nil |
|
internalSmtp.name |
Name to send emails from | nil |
|
logLevel |
Can be one of the following - INFO, WARN, ERROR, DEBUG | INFO |
|
incidents.disableAutomaticCreation |
Disable incident creation (use this when your team is overloaded with incidents or in emergencies) | false |
|
alerts.disableAutomaticCreation |
Disable alert creation (use this when your team is overloaded with alerts or in emergencies) | false |
|
podSecurityContext |
Pod Security Context. Please refer to Kubernetes docuemntation to set these. This chart depends on other bitnami charts. You will have to set security context for those as well | {} |
|
conatinerSecurityContext |
Container Security Context. Please refer to kubernetes documentation to set these. This chart depends on other bitnami charts. You will have to set security context for those as well | {} |
|
nodeSelector |
Node Selector. Please refer to Kubernetes documentation on how to use them. | {} |
|
tolerations |
Tolerations. Please refer to Kubernetes documentation on how to use them. | [] |
|
affinity |
Affinity. Please refer to Kubernetes documentation on how to use them. | {} |
|
extraTemplates |
Extra templates to be added to the deployment | [] |
|
oneuptimeIngress.enabled |
Enable ingress | true |
|
oneuptimeIngress.annotations |
Ingress annotations | {} |
|
oneuptimeIngress.hosts |
Ingress hosts | [] |
|
oneuptimeIngress.tls |
Ingress TLS. Please refer to values.yaml to set these | [] |
|
oneuptimeIngress.className |
Ingress class name. Change this to your cloud providers ingress class | nginx |
|
script.workflowScriptTimeoutInMs |
Timeout for workflow script | 5000 |
OneUptime does not support setting up SSL/TLS certificates. You need to set up SSL/TLS certificates on your own.
If you need to use SSL/TLS certificates, follow these steps:
- Use a reverse proxy like Nginx or Caddy.
- Use Let's Encrypt to provision the certificates.
- Point the reverse proxy to the OneUptime server.
- Update the following settings:
- Set
HTTP_PROTOCOL
env var tohttps
. - Change
HOST
env var to the domain name of the server where the reverse proxy is hosted.
- Set
If you would like to use an external postgres database, please add these env vars to your values.yaml file.
postgresql:
# Set Internal Postgres enabled to false, so we dont install the postgres database in your cluster
enabled: false
# External Postgres Configuration
# You need to set postgresql.enabled to false if you're using an external postgres database.
externalPostgres:
host:
port:
username:
password:
# If you're using an existing secret for the password, please use this instead of password.
existingSecret:
name:
# This is the key in the secret where the password is stored.
passwordKey:
database:
ssl:
enabled: false
# If this is enabled, please set either "ca"
ca:
# Optional
cert:
key:
If you would like to use an external redis database, please add these env vars to your values.yaml file.
redis:
# Set Internal Redis enabled to false, so we dont install the redis database in your cluster
enabled: false
externalRedis:
host:
port:
password:
# If you're using an existing secret for the password, please use this instead of password.
existingSecret:
name:
# This is the key in the secret where the password is stored.
passwordKey:
database:
tls:
enabled: false
# If this is enabled, please set "ca" certificate.
ca:
# (optional)
cert:
key:
If you would like to use an external clickhouse database, please add these env vars to your values.yaml file.
clickhouse:
# Set Internal Clickhouse enabled to false, so we dont install the clickhouse database in your cluster
enabled: false
externalClickhouse:
host:
# if you host is https then set this to true
isHostHttps:
port:
username:
password:
# If you're using an existing secret for the password, please use this instead of password.
existingSecret:
name:
# This is the key in the secret where the password is stored.
passwordKey:
database:
tls:
enabled: false
# If this is enabled, please set either "ca"
ca:
# Optional
cert:
key:
Parameter | Description | Default | Change Required |
---|---|---|---|
letsEncrypt.accountKey |
Generate a private key via openssl, encode it to base64 | `` | 🚨 |
letsEncrypt.email |
Email address to register with letsencrypt for notifications | `` | 🚨 |
Step 1: Add a CNAME record to your DNS settings
If you would like to add a custom domain to your status page (something like status.yourcompany.com), you can do so by adding a CNAME record to your DNS settings.
DNS Record Type: CNAME
Host: status.yourcomapny.com
Value: <your-oneuptime-host>
Please make sure oneuptime is hosted on a server which is publicly accessible.
Step 2: Add Custom Domain to your Project
Please go to your project settings and add the custom domain to your project. You can find the project settings by clicking "More" in the nav bar and by clicking "Project Settings". Please go to "Custom Domain" page and add your custom domain there. You will need to verify the domain. You can find the verification code in the "Custom Domain" page in your project settings.
Step 3: Add custom domain to your status page.
Please go to your status page settings and add the custom domain to your status page. You can find the status page settings by clicking on "View Status Page" in "Status Pages" page. You can add the custom domain in the "Custom Domain" page in your status page settings.
Once you have added the custom domain, you can access your status page using the custom domain.
Please go through the following checklist to make sure your OneUptime installation is production ready.
- Please pin OneUptime version to a specific version. This will prevent any breaking changes from affecting your installation.
When you install, you can check the latest version from the github releases page https://github.com/OneUptime/oneuptime/releases. You can pin the version in your values.yaml file.
image:
tag: <specific-version>
- Please pin Postgresql, Redis and Clickhouse versions to a specific version. This will prevent any breaking changes from affecting your installation.
When you install, you can check the version installed by describing the pods.
kubectl describe pod <pod-name>
For example:
kubectl describe pod my-oneuptime-postgresql-0
Once you have the version, you can pin the version in your values.yaml file.
postgresql:
image:
tag: <specific-version>
Please do the same for Redis and Clickhouse.
- Please make sure you have a backups enabled for your PVCs. This is outside the scope of this chart. Please refer to your cloud provider's documentation on how to enable backups for PVCs.
- Please make sure you have static passwords for your database passswords (for redis, clickhouse and postgres). You can refer to Bitnami documentation on how to set static passwords for these databases.
- Please set
oneuptimeSecret
andencryptionSecret
(or setup inexternalSecrets
section) to a long random string. You can use a password generator to generate these strings. - Please set
probes.<key>.key
to a long random string. This is used to secure your probes. - Please regularly update OneUptime. We release updates every day. We recommend you to update the software aleast once a week if you're running OneUptime production.
We release frequently, sometimes multiple times a day. It's usually safe to upgrade to the latest version. Any breaking changes will be documented in the release notes. Please make sure you read the release notes before upgrading.
We use these charts as dependencies. You dont need to install them separately. Please read the readme for these individual charts to understand the configuration options.
Chart | Description | Repository |
---|---|---|
postgresql |
PostgreSQL database | https://charts.bitnami.com/bitnami |
redis |
Redis database | https://charts.bitnami.com/bitnami |
clickhouse |
Clickhouse database | https://charts.bitnami.com/bitnami |
To uninstall/delete the my-oneuptime
deployment:
helm uninstall my-oneuptime
We <3 contributions big and small. https://github.com/OneUptime/helm-chart is the read only release repository. Please direct your contributions here: https://github.com/OneUptime/oneuptime