Skip to content

karnatisrinivas/otomi-core

Β 
Β 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation


Self-hosted PaaS for Kubernetes

Deploy your apps fast and safe on any Kubernetes cluster in any cloud.

Releases Docker pulls Build status Last commit License Contributions Website otomi.io Join Slack channel Follow us on Twitter Join Facebook group YouTube Channel Subscribers GitHub User's stars

πŸš€ Start using Otomi on Digital Ocean πŸš€

Otomi brings a full platform experience to Kubernetes without the constraints and abstractions. No more reinventing the wheel when building and maintaining your own K8s based (developer) platform.

Otomi features

πŸš€ Getting started

Helm

To install Otomi using Helm, make sure to have a K8s cluster running with at least:

  • Version 1.18 up to 1.23
  • A node pool with 6 vCPU and 8GB+ RAM (more is advised!)
  • Calico CNI installed (or any other CNI that supports K8s network policies)
  • When installing using the custom provider, make sure the K8s LoadBalancer Service created by Otomi can obtain an external accessible IP (using a cloud load balancer or MetalLB)

Add the Helm repository:

helm repo add otomi https://otomi.io/otomi-core \
helm repo update

and then install the Helm chart:

helm install otomi otomi/otomi \
--set cluster.k8sVersion=$VERSION \ # 1.19, 1.20, 1.21, 1.22 and 1.23 are supported
--set cluster.name=$CLUSTERNAME \
--set cluster.provider=$PROVIDER # use azure, aws, google, digitalocean or custom for any other cloud or onprem K8s

When the installer job is completed, follow the activation steps.

K8s quick starts

Use the quickstarts for Azure, GCP, AWS, Linode, Digital Ocean and Minikube to provision a Kubernetes cluster. Then use the helm chart to install Otomi.

Workshops

In our workshops repository, we have prepared a comprehensive set of hands-on labs to get a good understanding/overview of everything Otomi has to offer.

πŸŽ‰ Otomi Features

  • Drag and Drop apps to create your own preferred suite
  • GitOps with Argo CD out-of-the-box
  • Container image scanning
  • Advanced ingress architecture
  • Generate validated configuration code
  • Configure network policies for internal ingress and external egress
  • Deploy Knative serverless workloads without writing any YAML
  • Create and manage secrets in HashiCorp Vault and use them in your workloads
  • Create Kubernetes Jobs and Cron Jobs without writing any YAML
  • Role-based access to all integrated applications based on group membership
  • Enforce Pod security policies
  • Onboard teams or projects within minutes in a comprehensive multi-tenant setup
  • Predefined automation tasks
  • Bring your favorite IdP, DNS and/or CA

And much more...

πŸ§‘β€πŸ’» Integrated technologies

Otomi installs, configures, integrates and automates all of your favorite technologies:

Integrated technologies

Learn more about all the integrated technologies:

  • Istio: The service mesh framework with end-to-end transit encryption
  • Argo CD: Declarative continuous deployment
  • KubeClarity: Detect vulnerabilities of container images
  • Knative: Deploy and manage serverless workloads
  • Prometheus: Collecting container application metrics
  • Loki: Collecting container application logs
  • Harbor: Container image registry with role-based access control, image scanning, and image signing
  • HashiCorp Vault: Manage Secrets and Protect Sensitive Data
  • Kubeapps: Launching and managing applications on Kubernetes
  • Keycloak: Identity and access management for modern applications and services
  • OPA: Policy-based control for cloud-native environments
  • Let's Encrypt: A nonprofit Certificate Authority providing industry-recognized TLS certificates
  • Jaeger: End-to-end distributed tracing and monitor for complex distributed systems
  • Kiali: Observe Istio service mesh relations and connections
  • External DNS: Synchronize exposed ingresses with DNS providers
  • Drone: Continuous integration platform built on Docker
  • Gitea: Self-hosted Git service
  • Nginx Ingress Controller: Ingress controller for Kubernetes

πŸ’ͺ Otomi Projects

Otomi consists out of the following projects:

  • Otomi Core (this project): The heart of Otomi
  • Otomi Tasks: Autonomous jobs orchestrated by Otomi Core
  • Otomi API: The brain of Otomi, handling console input and talking to Otomi Core
  • Otomi Console: The UI of Otomi for admins and teams, talking to Otomi API
  • Otomi Clients: Factory to build and publish openapi clients used in the redkubes/otomi-tasks repo

πŸ“– Documentation

Check out the dev docs index for developer documentation or go to otomi.io for more detailed documentation.

🀝 Contribution

If you wish to contribute please read our Contributor Code of Conduct and Contribution Guidelines.

If you want to say thank you or/and support the active development of Otomi:

  • Add a GitHub Star to the project
  • Feel free to write articles about the project on dev.to, medium or on your personal blog as we are curious to see how you use Otomi

This project exists thanks to all the people who contribute and have contributed.

πŸ”– License

Otomi is free and open-source software licensed under the Apache 2.0 License.

About

Self-hosted PaaS for Kubernetes

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Mustache 70.4%
  • TypeScript 15.3%
  • Smarty 5.1%
  • Open Policy Agent 4.2%
  • Shell 3.7%
  • Dockerfile 0.6%
  • Other 0.7%