This topic describes the development process of KubeSphere extensions.
Before developing KubeSphere extensions, create a Kubernetes (K8s) cluster and deploy KubeSphere Luban to provide the basic runtime environment for the extensions. Additionally, you need to install essential development tools such as Node.js, Yarn, create-ks-project, Helm, kubectl, ksbuilder. For more information about setting up the development environment, please refer to Build a Development Environment.
After you have finished configuring the development environment, make sure that the KubeSphere Console is accessible and that necessary ports (kube-apiserver 6443, ks-console 30880, ks-apiserver 30881) have been opened for local debugging.
If your extensions will extend KubeSphere’s frontend UI, please use create-ks-project
to create the frontend project directory for your extensions.
Before development, initialize the extension development project as follows:
Initialize the frontend project directory for the extension using yarn create ks-project <NAME>
. With this frontend project, you can locally run the KubeSphere Console and load the developing extensions.
Use yarn create:extensions
to initialize the source code directory for the frontend of the extension.
The directory structure will be as the following:
kubesphere-extensions
└── ks-console # Extension frontend development directory
├── babel.config.js
├── configs
│ ├── config.yaml
│ ├── local_config.yaml # Configuration file of the KubeSphere web console
│ ├── webpack.config.js # Scaffold Webpack configuration file
│ └── webpack.extensions.config.js # Webpack configuration file for packaging extension frontend
├── extensions # Source code directory for the extension
│ └── hello-world # Source code directory for the Hello World extension
│ ├── package.json
│ └── src
│ ├── App.jsx # Extension core logic
│ ├── index.js # Extension entry file
│ ├── locales # Extension internationalization
│ └── routes # Extension route configuration
├── package.json
├── tsconfig.base.json
├── tsconfig.json
└── yarn.lock
If your extension does not include frontend extensions, you can skip this step.
After completing the creation of the extension’s source code directory, you can begin writing the core logic for the extension. KubeSphere provides a rich set of APIs and component libraries; please refer to Custom Features for more information.
During the development, configure the KubeSphere console, and then use the yarn dev
command to run the KubeSphere web console locally to debug the extension.
Once the extension has been developed, use Helm and ksbuilder to orchestrate, package, and publish the extension.
KubeSphere uses Helm as the orchestration specification for extensions, please refer to Helm Docs for more information. Based on Helm, KubeSphere extensions provide richer metadata definition capabilities, as described in Packaging Extensions.
The ksbuilder tool allows you to submit your orchestrated extensions to the development environment for testing and deployment. View Testing Extensions for details.
Once your extension has passed the test, submit it to the KubeSphere Marketplace using the ksbuilder tool.
Before submitting your extension to the KubeSphere Marketplace, please carefully read the relevant agreements, guidelines, and terms.