Add your description here
Project description
fujin
[!IMPORTANT] This package currently contains minimal features and is a work-in-progress
fujin
is a simple deployment tool that helps you get your project up and running on a VPS in a few minutes. It manages your app processes using systemd
and runs your apps behind caddy. For Python projects,
it expects your app to be a packaged Python application ideally with a CLI entry point defined. For other languages, you need to provide a self-contained single executable file with all necessary dependencies.
The main job of fujin
is to bootstrap your server (installing caddy, etc.), copy the files onto the server with a structure that supports rollback, and automatically generate configs for systemd and caddy that you can manually edit if needed.
Check out the documentation📚 for installation, features, and usage guides.
Why?
I wanted kamal but without Docker, and I thought the idea was fun. At its core, this project automates versions of this tutorial. If you've been a Django beginner trying to get your app in production, you probably went through this. I'm using caddy instead of nginx because the configuration file simpler and it's is a no-brainer for SSL certificates. Systemd is the default on most Linux distributions and does a good enough job.
Fujin was initially planned to be a Python-only project, but the core concepts can be applied to any language that can produce a single distributable file (e.g., Go, Rust). I wanted to recreate kamal's nice local-to-remote app management API, but I'm skipping Docker to keep things simple. I'm currently rocking SQLite in production for my side projects and ths setup is enough for my use case.
The goal is to automate deployment while leaving you in full control of your Linux box. It's not a CLI PaaS - it's simple and expects you to be able to SSH into your server and troubleshoot if necessary. For beginners, it makes the initial deployment easier while you get your hands dirty with Linux. If you need a never-break, worry-free, set-it-and-forget-it setup that auto-scales and does all the magic, fujin probably isn't for you.
Inspiration and alternatives
Fujin draws inspiration from the following tools for their developer experience. These are better alternatives if you need a more robust, set-and-forget solution
License
fujin
is distributed under the terms of the MIT license.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file fujin_cli-0.3.0.tar.gz
.
File metadata
- Download URL: fujin_cli-0.3.0.tar.gz
- Upload date:
- Size: 128.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: python-httpx/0.27.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 59566d9f370d111183d8347f3805bdab83e22cc511f4af0a69a532d89243cc7d |
|
MD5 | c026fd887fb4b98021f72606a03214d1 |
|
BLAKE2b-256 | f0864166912cd731e01d9440a8f9a6b44369a2b40585abe716c13634105fb530 |
File details
Details for the file fujin_cli-0.3.0-py3-none-any.whl
.
File metadata
- Download URL: fujin_cli-0.3.0-py3-none-any.whl
- Upload date:
- Size: 30.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: python-httpx/0.27.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 37bb6f6de1c5f1b4ded9d3c5f120fb586cfe9effb73aef4148e86c1206c69b75 |
|
MD5 | 0c50fd20c49c62daed0ca6edc1325ee8 |
|
BLAKE2b-256 | f4eab0bf21fe7bad933a1583c77e1fe3295a9ae646c007d06807b8e46ce9431d |