Jan is a self-hosted, AI Inference Platform that scales from personal use to production deployments.
Run an entire AI stack locally, from the inference engine to a shareable web application.
Jan is free, source-available, and fair-code licensed.
👋 Access a live demo at https://cloud.jan.ai.
- Run ChatGPT and Midjourney alternatives on-prem and on your private data
- Self-host AI models for your friends or for a team
- GPU support with Nvidia hardware acceleration
- CPU support with optimizations via llama.cpp
- Llama 7Bn
- Web app and APIs (OpenAI compatible REST & GRPC)
- Supports Apple Silicon/CPU & GPU architectures
- Load balancing via Traefik
- Login and authz via Keycloak
- Data storage via Postgres, MinIO
- Support more models, with acceleration (WIP)
- C++ inference backend w/ CUDA & dynamic batching (WIP)
- Universal model installer & compiler, targeting Nvidia GPU acceleration
- Mobile UI with a swappable backend URL
- Admin dashboards for user management and audit
So far, this setup is tested and supported for Docker on Linux, Mac, and Windows Subsystem for Linux (WSL).
-
Install Docker: Install Docker here.
-
Install Docker Compose: Install Docker Compose here.
-
Clone the Repository: Clone this repository and pull in the latest git submodules.
git clone https://github.com/janhq/jan.git cd jan # Pull latest submodules git submodule update --init --recursive
-
Export Environment Variables
export DOCKER_DEFAULT_PLATFORM=linux/$(uname -m)
-
Set a .env: You will need to set up several environment variables for services such as Keycloak and Postgres. You can place them in
.env
files in the respective folders as shown in thedocker-compose.yml
.cp sample.env .env
Service (Docker) env file Global env .env
, just runcp sample.env .env
Keycloak .env
presented in global env and initiate realm inconf/keycloak_conf/example-realm.json
Keycloak PostgresDB .env
presented in global envjan-inference .env
presented in global envapp-backend (hasura) conf/sample.env_app-backend
refer from hereapp-backend PostgresDB conf/sample.env_app-backend-postgres
web-client conf/sample.env_web-client
- Download Runway SD 1.5 from HuggingFace
wget https://huggingface.co/runwayml/stable-diffusion-v1-5/resolve/main/v1-5-pruned-emaonly.safetensors -P jan-inference/sd/models
- Download Llama 7Bn ggml from HuggingFace
wget https://huggingface.co/TheBloke/Llama-2-7B-Chat-GGML/resolve/main/llama-2-7b-chat.ggmlv3.q4_1.bin -P jan-inference/llm/models
Jan uses an opinionated, but modular, open-source stack that comes with many services out of the box, e.g. multiple clients, autoscaling, auth and more.
You can opt out of such services or swap in your own integrations via Configurations.
- Run the following command to start all the services defined in the
docker-compose.yml
# Docker Compose up
docker compose up
# Docker Compose up detached mode
docker compose up -d
- This step takes 5-15 minutes and the following services will be provisioned:
Service | URL | Credentials |
---|---|---|
Web App | http://localhost:3000 | Users are signed up to keycloak, default created user is set via conf/keycloak_conf/example-realm.json on keycloak with username: username , password: password |
Keycloak Admin | http://localhost:8088 | Admin credentials are set via the environment variables KEYCLOAK_ADMIN and KEYCLOAK_ADMIN_PASSWORD |
Hasura App Backend | http://localhost:8080 | Admin credentials are set via the environment variables HASURA_GRAPHQL_ADMIN_SECRET in file conf/sample.env_app-backend |
LLM Service | http://localhost:8000 | |
Stable Diffusion Service | http://localhost:8001 |
- Launch the web application via
http://localhost:3000
. - Login with default user (username:
username
, password:password
)
TODO
TODO
- Keycloak Community (Apache-2.0)
- Hasura Community Edition (Apache-2.0)
Jan is a monorepo that pulls in the following submodules
├── docker-compose.yml
├── mobile-client # Mobile app
├── web-client # Web app
├── app-backend # Web & mobile app backend
├── inference-backend # Inference server
├── docs # Developer Docs
├── adrs # Architecture Decision Records
Contributions are welcome! Please read the CONTRIBUTING.md file for guidelines on how to contribute to this project.
This project is licensed under the Fair Code License. See LICENSE.md for more details.
Created by Jan. Thanks to all contributors who have helped to improve this project.
For support: please file a Github ticket For questions: join our Discord here For long form inquiries: please email [email protected]