After reading this topic, you will get:
how to initialize a project for extension development.
how to launch the KubeSphere web console in your local environment.
how to debug an extension.
A development environment is ready. For more information, view Build a Development Environment.
KubeSphere adopts React for the frontend development of extensions. For more information, visit React official website.
Initialize a project for extension development:
mkdir -p ~/kubesphere-extensions
cd ~/kubesphere-extensions
yarn add global create-ks-project
yarn create ks-project ks-console
The project contains a KubeSphere web console that can run locally.
Create a Hello World extension:
cd ks-console
yarn create:ext
Configure basic information, for example, the extension name, alias, description, author, and language.
Extension Name hello-world
Display Name Hello World
Description Hello World!
Author demo
Language JavaScript
Create extension [hello-world]? Yes
The following directory is generated:
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
│ ├── Dockerfile
│ ├── README.md
│ ├── package.json
│ └── src
│ ├── App.jsx
│ ├── index.js
│ ├── locales
│ └── routes
├── package.json
├── tsconfig.base.json
├── tsconfig.json
└── yarn.lock
To make the KubeSphere web console run locally, you need to Build a Development Environment, and get the address of the KubeSphere API server.
If you are using a cluster created on KubeSphere Cloud, get the API Server’s access address by creating an external service as shown in the following images:
Then, make configurations in the local_config.yaml
file as below.
server:
apiServer:
url: http://172.31.73.3:30881 # IP and port of `ks-apiserver`
wsUrl: ws://172.31.73.3:30881 # IP and port of `ks-apiserver`
Launch the KubeSphere web console in your local environment:
yarn dev
Open a browser, visit http://localhost:880
, and use the default username admin
and password P@88w0rd
to log in to the KubeSphere web console.
The entry of Hello World
appears on the top navigation bar. Click Hello World
to open the page.
The source code of the Hello World extension is stored in ~/kubesphere-extensions/ks-console/extensions/hello-word/src
.
You can change the string displayed on the page to Test!
, as shown in the following figures:
The demo extension only contains the frontend part, showing the basic features of extensions. For more development examples, please refer to Development Examples.