JetKVM is a high-performance, open-source KVM over IP (Keyboard, Video, Mouse) solution designed for efficient remote management of computers, servers, and workstations. Whether you're dealing with boot failures, installing a new operating system, adjusting BIOS settings, or simply taking control of a machine from afar, JetKVM provides the tools to get it done effectively.
We welcome contributions from the community! Whether it's improving the firmware, adding new features, or enhancing documentation, your input is valuable. We also have some rules and taboos here, so please read this page and our Code of Conduct carefully.
The best place to search for answers is our Documentation. If you can't find the answer there, check our Discord Server.
If you've found an issue and want to report it, please check our Issues page. Make sure the description contains information about the firmware version you're using, your platform, and a clear explanation of the steps to reproduce the issue.
This project is built on Node.JS using Prisma and Express.
To start the development server, run:
# For local development, you can use the following command to start a postgres instanc
# Don't use in production
docker run --name jetkvm-cloud-db \
-e POSTGRES_USER=jetkvm \
-e POSTGRES_PASSWORD=mysecretpassword \
-e POSTGRES_DB=jetkvm \
-d postgres
# Copy the .env.example file to .env and populate it with the correct values
cp .env.example .env
# Install dependencies
npm install
# Deploy the existing database migrations
npx prisma migrate deploy
# Start the production server on port 3000
npm run dev
# Copy the .env.example file to .env and populate it with the correct values
cp .env.example .env
# Install dependencies
npm install
# Deploy the existing database migrations
# Needs to run on new release
npx prisma migrate deploy
# Start the production server on port 3000
npm run start