Home

Awesome

<img src="docs/static/media/logos/devspace-logo-primary.svg" width="600">

WebsiteQuickstartDocumentationBlogTwitter

Build Status Passing Latest Release License: Apache-2.0 Total Downloads (GitHub Releases) NPM Installs per Month OpenSSF Best Practices

Join us on Slack!

Client-Only Developer Tool for Cloud-Native Development with Kubernetes

<br>

DevSpace Compatibility

<br> <p align="center"> ⭐️ <strong>Do you like DevSpace? Support the project with a star</strong> ⭐️ </p> <br>

DevSpace was created by Loft Labs and is a Cloud Native Computing Foundation (CNCF) sandbox project.

<br>

Contents

<br>

Why DevSpace?

Building modern, distributed and highly scalable microservices with Kubernetes is hard - and it is even harder for large teams of developers. DevSpace is the next-generation tool for fast cloud-native software development.

<details> <summary><b>Standardize & Version Your Workflows</b></summary> <br>

DevSpace allows you to store all your workflows in one declarative config file: devspace.yaml

<br> </details> <details> <summary><b>Let Everyone on Your Team Deploy to Kubernetes</b></summary> <br>

DevSpace helps your team to standardize deployment and development workflows without requiring everyone on your team to become a Kubernetes expert.

Giving everyone on your team on-demand access to a Kubernetes cluster is a challenging problem for system administrators and infrastructure managers. If you want to efficiently share dev clusters for your engineering team, take a look at www.loft.sh.

<br> </details> <details> <summary><b>Speed Up Cloud-Native Development</b></summary> <br>

Instead of rebuilding images and redeploying containers, DevSpace allows you to hot reload running containers while you are coding:

<br> </details> <details> <summary><b>Automate Repetitive Tasks</b></summary> <br>

Deploying and debugging services with Kubernetes requires a lot of knowledge and forces you to repeatedly run commands like kubectl get pod and copy pod ids back and forth. Stop wasting time and let DevSpace automate the tedious parts of working with Kubernetes:

<br> </details> <details> <summary><b>Works with Any Kubernetes Clusters</b></summary> <br>

DevSpace is battle tested with many Kubernetes distributions including:

DevSpace also lets you switch seamlessly between clusters and namespaces. You can work with a local cluster as long as that is sufficient. If things get more advanced, you need cloud power like GPUs or you simply want to share a complex system such as Kafka with your team, simply tell DevSpace to use a remote cluster by switching your kube-context and continue working.

<br> </details> <br>

Quickstart

Please take a look at our getting started guide.

<br>

Architecture & Workflow

DevSpace Workflow

DevSpace runs as a single binary CLI tool directly on your computer and ideally, you use it straight from the terminal within your IDE. DevSpace does not require a server-side component as it communicates directly to your Kubernetes cluster using your kube-context, just like kubectl.

<br>

Contributing

Help us make DevSpace the best tool for developing, deploying and debugging Kubernetes apps.

Join us on Slack!

Reporting Issues

If you find a bug while working with the DevSpace, please open an issue on GitHub and let us know what went wrong. We will try to fix it as quickly as we can.

Feedback & Feature Requests

You are more than welcome to open issues in this project to:

Contributing Code

This project is mainly written in Golang. If you want to contribute code:

  1. Ensure you are running golang version 1.11.4 or greater for go module support
  2. Set the following environment variables:
    GO111MODULE=on
    GOFLAGS=-mod=vendor
    
  3. Check-out the project: git clone https://github.com/loft-sh/devspace && cd devspace
  4. Make changes to the code
  5. Build the project, e.g. via go build -o devspace[.exe]
  6. Evaluate and test your changes ./devspace [SOME_COMMAND]

See Contributing Guidelines for more information.

The DevSpace project follows the CNCF Code of Conduct.

<br>

FAQ

<details> <summary>What is DevSpace?</summary>

DevSpace is an open-source command-line tool that provides everything you need to develop, deploy and debug applications with Docker and Kubernetes. It lets you streamline deployment workflows and share them with your colleagues through a declarative configuration file devspace.yaml.

</details> <details> <summary>Is DevSpace free?</summary>

YES. DevSpace is open-source and you can use it for free for any private projects and even for commercial projects.

</details> <details> <summary>Do I need a Kubernetes cluster to use DevSpace?</summary>

Yes. You can either use a local cluster such as Docker Desktop Kubernetes, minikube, or Kind, but you can also use a remote cluster such as GKE, EKS, AKS, RKE (Rancher), or DOKS.

</details> <details> <summary>Can I use DevSpace with my existing Kubernetes clusters?</summary>

Yes. DevSpace is using your regular kube-context. As long as you can run kubectl commands with a cluster, you can use this cluster with DevSpace as well.

</details> <details> <summary>What is a Helm chart?</summary>

Helm is the package manager for Kubernetes. Packages in Helm are called Helm charts.

</details> <br> <br>

License

DevSpace is released under the Apache 2.0 license. See the LICENSE file for details.

DevSpace is a Cloud Native Computing Foundation (CNCF) sandbox project and was contributed by Loft Labs.

<div align="center"> <img src="https://raw.githubusercontent.com/cncf/artwork/master/other/cncf-sandbox/horizontal/color/cncf-sandbox-horizontal-color.svg" width="300" alt="CNCF Sandbox Project"> </div>