Lightweight Python Web Framework (WSGI)
Project description
Nexom
Lightweight Python Web Framework (WSGI)
Nexomは短いコードで最低限動作し、シンプルで理解のしやすい設計・構造を目指しています。 また細かい仕様も変更でき、多様な処理に対応します。
はじめる
最初のサーバーを起動するには、3つの手順が必要です。
- ディレクトリを作成
- nexomをpipでインストール、サーバーのビルド
- 起動
1.ディレクトリの作成
準備 用意していない場合はディレクトリを作成し、仮想環境も準備てください
mkdir sample
cd sample
python -m venv venv
source venv/bin/activate
2.npipでインストール、サーバーのビルド
インストール nexomをインストールします。 ※まだベータ版のため、最新のバージョンを確認してください。
pip install nexom==0.1.4
テンプレートサーバーのビルド サーバーを置きたいディレクトリ上で、以下のコマンドを実行してください(sampleは自由)
python -m nexom build-server sample
3.起動
以下のコマンドを起動します。
gunicorn wsgi:app
ブラウザからアクセスできるようになります。
デフォルトのポートは8080です。
httpls://localhost:8080
ポートなどの設定は config.py から変更してください。
Nginx等使用して外部公開する
config.py で指定したポートにプロキシしてください。
server {
listen 443 ssl;
server_name nexom.ceez7.com;
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
location / {
proxy_pass http://localhost:8080;
}
}
Systemdに登録して自動起動する
Ubuntuの場合
/etc/systemd/systemに、your_server_name.serviceを作成します。your_server_name.serviceに以下を書き込みます。(これは一例です。環境に合わせて設定してください。)
サーバーのディレクトリが /home/ubuntu/nexom にある場合
[Unit]
Description=Nexom Web Freamework
After=network.target
[Service]
User=www-data
Group=www-data
WorkingDirectory=/home/ubuntu/nexom
Environment="/home/ubuntu/nexom/venv/bin"
ExecStart=/home/ubuntu/nexom/venv/bin/gunicorn wsgi:app
[Install]
WantedBy=multi-user.target
以下のコマンドを実行します
sudo systemd daemon-reload
sudo systemd enable your_server_name
sudo systemd start your_server_name
テンプレートユニットを活用して複数のサーバーを効率的に管理
以下の構成でサーバーが建てられていたとします。
/home/ubuntu/BananaProject/
└─ web/
├─ banana1 (Nexomサーバー)/
│ └─ wsgi.py
├─ banana2 (Nexomサーバー)/
│ └─ wsgi.py
└─ banana3 (Nexomサーバー)/
└─ wsgi.py
この構成の場合、テンプレートユニットを活用し .service ファイルを一枚にまとめられます。
/etc/systemd/system/banana-project@.service
[Unit]
Description=Nexom Web Server (%i)
After=network.target
[Service]
User=www-data
Group=www-data
WorkingDirectory=/home/ubuntu/BananaProject/web/%i
Environment="/home/ubuntu/BananaProject/web/%i/venv/bin"
ExecStart=/home/ubuntu/BananaProject/web/%i/venv/bin/gunicorn wsgi:app
[Install]
WantedBy=multi-user.target
sudo systemd daemon-reload
sudo systemd enable banana-project@banana1
sudo systemd enable banana-project@banana2
sudo systemd enable banana-project@banana3
sudo systemd start banana-project@banana1
sudo systemd start banana-project@banana2
sudo systemd start banana-project@banana3
2026 1/24
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file nexom-0.1.4.tar.gz.
File metadata
- Download URL: nexom-0.1.4.tar.gz
- Upload date:
- Size: 31.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2b815569ec3936a24435ddfb6f3658eaeabcfe54bd2520028243c9e2a8476b96
|
|
| MD5 |
5a88982f54b868cff6a7234b0a789608
|
|
| BLAKE2b-256 |
815ff1a1c497fca071257afb968450ec9fa66dd7b6e2b1b5917d121b3cf4e7cf
|
File details
Details for the file nexom-0.1.4-py3-none-any.whl.
File metadata
- Download URL: nexom-0.1.4-py3-none-any.whl
- Upload date:
- Size: 34.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ddef0b95b224f3c261e5411b63fe66e2dc2aafc0846ae8241f10e0916be9b720
|
|
| MD5 |
cbfdbbf37fc2d31701bf04d099c47caf
|
|
| BLAKE2b-256 |
2c026c3a010a6fcafa65f602698bbe38644b549ee7cc0b1751d59a0cd4debb38
|