Check out the main KubeStellar project
Welcome to KubestellarUI! This guide will help you set up the KubestellarUI application on your local machine after cloning the repository for development. The application consists of two main parts:
- Frontend: Built with React and TypeScript
- Backend: Built with Golang using the Gin framework.
Before you begin, ensure that your system meets the following requirements:
- Version: 1.23.4
- Download Link: Golang Downloads
- Node.js Version: ≥ 16.x.x
- npm Version: Comes bundled with Node.js
- Download Link: Node.js Downloads
Note
You can use nvm to manage multiple Node.js versions.
- Ensure Git is installed to clone the repository
- Download Link: Git Downloads
- 
Ensure you have access to a Kubernetes clusters setup with Kubestellar Getting Started Guide & Kubestellar prerequisites installed 
- 
Kubestellar guide: Guide 
- Make sure you have "make" installed to directly execute the backend script via makefile
- Air helps in hot reloading of the backend
- Air guide: Guide
Clone the Repository
git clone https://github.com/your-github-username/ui.git
cd uiThen go through one of the setup options below:
To configure the frontend, copy the .env.example file to a .env file in the project root directory (where package.json is located).
cp .env.example .envExample .env file:
VITE_BASE_URL=http://localhost:4000
VITE_APP_VERSION=0.1.0
VITE_GIT_COMMIT_HASH=$GIT_COMMIT_HASH
Note
This is because .env files are intended to be a personal environment configuration file. The included .env.example in the repo is a standard that most other node projects include for the same purpose. You rename the file to .env and then change its contents to align with your system and personal needs.
KubestellarUI uses environment variables to track the app version and the current Git commit hash.
Environment Variables
| Variable | Purpose | Example | 
|---|---|---|
| VITE_BASE_URL | Defines the base URL for API calls | http://localhost:4000 | 
| VITE_APP_VERSION | Defines the current application version | 0.1.0 | 
| VITE_GIT_COMMIT_HASH | Captures the current Git commit hash | (Set during build) | 
KubestellarUI uses Redis for caching real-time WebSocket updates to prevent excessive Kubernetes API calls.
Run Redis using Docker:
docker run --name redis -d -p 6379:6379 redisVerify Redis is running:
docker ps | grep redisMake sure you are in the root directory of the project
cd backend
go mod download
# Option 1 : Start backend with hot reloading (recommended)
make dev
# Option 2 : Start backend without hot reloading
go run main.goYou should see output indicating the server is running on port 4000.
Open another terminal and make sure you are in the root directory of the project.
npm install
npm run devYou should see output indicating the server is running on port 5173.
If you prefer to run the application using Docker Compose, follow these steps:
- Download Link: Docker Downloads
Note
If you are using Docker Desktop, please enable host networking. To do so navigate to Settings > Resources > Network, and check the "Enable host networking" option. Finally, apply the changes and restart Docker Desktop.
Note
If you are using Compose V1, change the docker compose command to docker-compose in the following steps.
Checkout Migrating to Compose V2 for more info.
From the project root directory
docker compose up --buildYou should see output indicating the services are running.
To stop the application
docker compose down- Backend API: http://localhost:4000
- Frontend UI: http://localhost:5173
- Username: admin
- Password: admin