Skip to content

Latest commit

 

History

History
344 lines (248 loc) · 13.4 KB

README.md

File metadata and controls

344 lines (248 loc) · 13.4 KB

oneuptime logo

OneUptime Helm Chart

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.

Overview of OneUptime

Yotube Tutorial

https://youtu.be/Ho5WyPHExTU

Install Helm Chart

Create values.yaml file.

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 

Pick a Storage Class

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

Upgrade Helm Chart

# Update the chart repo 
helm repo update

# Upgrade the helm chart
helm upgrade my-oneuptime oneuptime/oneuptime -f values.yaml

Uninstall OneUptime

To uninstall/delete the my-oneuptime deployment:

helm uninstall my-oneuptime

Configuration

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

Setting up TLS/SSL Certificates

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:

  1. Use a reverse proxy like Nginx or Caddy.
  2. Use Let's Encrypt to provision the certificates.
  3. Point the reverse proxy to the OneUptime server.
  4. Update the following settings:
    • Set HTTP_PROTOCOL env var to https.
    • Change HOST env var to the domain name of the server where the reverse proxy is hosted.

Using External Databases

Postgres

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:

Redis

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:

Clickhouse

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:

If you would like to use a custom domain for your status page, please add these env vars

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 `` 🚨

Adding a Custom Domain to your Status Page

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.

Production Readiness Checklist

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 and encryptionSecret (or setup in externalSecrets 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.

Releases

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.

Chart Dependencies

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

Uninstalling OneUptime

To uninstall/delete the my-oneuptime deployment:

helm uninstall my-oneuptime

Contributing

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