ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
Genie.jl の概要
Genie は Julia で書かれた高生産性 Web フレームワーク。Ruby on Rails / Laravel と同じ MVC + ORM + ジェネレータ思想で、データサイエンス用途と Web アプリ用途を Julia 1 言語で完結できるのが強みです。
2026 年時点の主な構成:
- Genie — ルーティング / コントローラ / ミドルウェア / HTTP サーバ
- SearchLight — ORM (PostgreSQL / MySQL / SQLite)
- Stipple — Vue.js + WebSocket ベースのリアクティブ UI
- GenieFramework — 上記をまとめたメタパッケージ
1. Genie のインストール
# Julia REPL を起動
julia
# パッケージモード (] キー)
] add Genie
# または通常モードで
using Pkg
Pkg.add("Genie")
# 開発に便利なものまとめて
Pkg.add(["Genie", "Revise", "Stipple"])
# バージョン確認
Pkg.status("Genie")
2. 最小構成でサーバ起動
# server.jl
using Genie
using Genie.Router
route("/") do
"Hello from Genie!"
end
route("/hello/:name") do
"Hello, $(params(:name))!"
end
# サーバ起動 (デフォルト port 8000)
up()
# 別ポートを指定
up(8080)
# ホストも指定
up(8080, "0.0.0.0")
# 非同期起動 (REPL を解放)
up(async = true)# 実行
julia --project=. server.jl
# 別ターミナルで動作確認
curl http://localhost:8000
# Hello from Genie!
curl http://localhost:8000/hello/Alice
# Hello, Alice!
3. 自動リロード (Revise.jl)
Julia は起動時間が長いため、コード修正のたびに REPL を再起動するのは非効率。Revise.jl を使うと保存時に再評価されます。
# Revise を Genie より先に読み込む (必須順)
using Revise
using Genie
includet("routes.jl") # ★ includet (Revise 版 include)
up(async = true)
# routes.jl を保存すると自動で反映される
シェルから直接起動する場合は環境変数で有効化:
# REPL を起動して Revise 経由
JULIA_REVISE=on julia --project=. -e 'using Revise; using Genie; Genie.up()'
# bin/repl で起動 (newapp で生成される)
bin/repl
4. Genie アプリのフォルダ構成
後述の Genie.Generator.newapp() でスキャフォールドした場合、以下の構成になります:
MyApp/
├── bin/ # 起動スクリプト (repl, server)
├── bootstrap.jl # 起動ブートストラップ
├── config/
│ ├── env/ # 環境別設定 (dev.jl, prod.jl)
│ ├── initializers/ # 起動時に走らせる
│ ├── secrets.jl
│ └── routes.jl # ★ ルーティング
├── app/
│ ├── controllers/
│ ├── models/
│ └── views/
├── public/ # 静的ファイル
├── db/
│ ├── migrations/ # SearchLight マイグレーション
│ └── seeds/
├── Project.toml # 依存
└── Manifest.toml # ロックファイル
5. 設定 (Genie.config)
using Genie
# 主要な設定値
Genie.config.server_port = 8000
Genie.config.server_host = "0.0.0.0"
Genie.config.run_as_server = true # ブロッキング起動
Genie.config.log_level = :info # :debug / :info / :warn / :error
Genie.config.log_to_file = true
Genie.config.cache_duration = 0
Genie.config.session_auto_start = true
Genie.config.websockets_server = true # Stipple 用
# CORS 設定
Genie.config.cors_headers["Access-Control-Allow-Origin"] = "*"
Genie.config.cors_allowed_origins = ["http://localhost:3000"]
6. 本番デプロイ
systemd ユニット
# /etc/systemd/system/myapp.service
[Unit]
Description=My Genie App
After=network.target
[Service]
Type=simple
User=app
WorkingDirectory=/opt/myapp
Environment=GENIE_ENV=prod
Environment=JULIA_DEPOT_PATH=/opt/myapp/.julia
ExecStart=/usr/local/bin/julia --project=. bin/server
Restart=always
RestartSec=5
[Install]
WantedBy=multi-user.targetsudo systemctl daemon-reload
sudo systemctl enable --now myapp
sudo journalctl -fu myapp
Docker
FROM julia:1.10-slim
WORKDIR /app
COPY Project.toml Manifest.toml ./
RUN julia --project=. -e 'using Pkg; Pkg.instantiate(); Pkg.precompile()'
COPY . .
ENV GENIE_ENV=prod \
PORT=8000 \
HOST=0.0.0.0
EXPOSE 8000
CMD ["julia", "--project=.", "bin/server"]
7. Stipple でリアクティブ UI
Genie 単体は SSR ですが、Stipple を組み合わせると Vue.js 互換のリアクティブ SPA に。
using Stipple, Stipple.ReactiveTools
using StippleUI
@app begin
@in n = 0
@out doubled = 0
@onchange n begin
doubled = n * 2
end
end
@page("/", "view.html.jl")
up()
Julia エコシステムでの位置づけ
| フレームワーク | 特徴 |
|---|---|
| Genie | Rails ライクなフルスタック。最も成熟 |
| Stipple | Genie ベースのリアクティブ UI |
| Oxygen | マイクロフレームワーク (FastAPI 風) |
| HTTP.jl | 低レベル HTTP サーバ / クライアント |
| Pluto.jl | ノートブック (Web アプリではない) |
FAQ
Q: 初回起動が遅い
A: Julia の JIT 特性。PackageCompiler.jl でシステムイメージを焼くと数秒で起動可能になります。
Q: ポートが既に使われている
A: lsof -i :8000 で確認し、別ポートで起動。up(9000)。
Q: Genie は Python の Flask / Django とどう違う?
A: 性能 (Julia の JIT) と数値計算ライブラリ親和性。データサイエンスの結果をそのまま Web 化するときに強い。
Q: Production で本当に使える?
A: GenieFramework 社が商用サポート提供。中小規模なら十分実用、大規模事例はまだ少ない。
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページはありません
- インストール (Genie.jl)
- アプリケーションの作成
- エラー一覧
- ローカルのウェブアプリケーションサーバーの起動方法
- アプリケーションのロード
- コントローラーの作成と基本
人気ページ
- 1 Eclipseで「サーバーに追加または除去できるリソースがありません。」の原因と対処法
- 2 tomcat の起動 / 停止ログと catalina.log・catalina.out の違い
- 3 JavaScript base URL 取得方法|window.location.origin と SSR/Node.js 対応
- 4 YouTube Data API v3 エラー一覧|403/400/404 の主要原因と切り分け
- 5 Spring Frameworkのアノテーション一覧
- 6 Laravel エラー一覧|500/Blade/DB 接続/ルーティングの代表エラー
- 7 3Dグラフィックスとは|モデリング/レンダリング/主要ソフトウェア (Blender / Maya)
- 8 【Spring】@Valueアノテーションとは
- 9 CATALINA_HOME の確認方法 (Linux / Mac)
- 10 【Spring】@Autowiredアノテーションとは
最近更新/作成されたページ
- IPv6とは|128bitアドレス・コロン16進表記/::省略・リンクローカル・SLAAC・デュアルスタック NEW 2026-06-22 12:34:44
- VPNとは|暗号トンネル・サイト間/リモートアクセス・IPsec/SSL-VPN/WireGuardを解説 NEW 2026-06-22 12:19:10
- MAC アドレスフィルタリングの仕組みと限界 | ネットワーク入門 NEW 2026-06-22 12:19:10
- WebRTC とは ブラウザ間 P2P の音声・映像・データ通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- gRPC とは HTTP/2 + Protocol Buffers の高速 RPC | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/3 (QUIC) とは UDP ベースの低遅延 Web 通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/2 とは 多重化・HPACK・バイナリフレーム | ネットワーク入門 NEW 2026-06-22 12:17:25
- Web通信プロトコル入門 HTTP/2・HTTP/3・WebSocket・gRPC・WebRTC | ネットワーク入門 NEW 2026-06-22 12:17:25
- WebSocket とは 全二重リアルタイム通信 ws/wss | ネットワーク入門 NEW 2026-06-22 12:17:25
- ファイアウォールとは|パケットフィルタ・ステートフル・DMZ・次世代FW(L4/L7)を解説 NEW 2026-06-22 12:17:24
- iptables/nftablesとは|テーブル・チェーン・ルール例・永続化をLinux視点で解説 NEW 2026-06-22 12:17:24
- HAProxy とは frontend/backend と設定例 | ネットワーク入門 NEW 2026-06-22 12:17:24
- 証明書と認証局(CA)とは|X.509・信頼チェーン・DV/OV/EV・失効(CRL/OCSP)を解説 NEW 2026-06-22 12:17:24
- CDN とは エッジキャッシュ・TTL・Cloudflare/CloudFront | ネットワーク入門 NEW 2026-06-22 12:17:24
- TLS/SSLの仕組み|ハンドシェイク・暗号スイート・前方秘匿性・証明書検証をわかりやすく解説 NEW 2026-06-22 12:17:24
コメントを削除してもよろしいでしょうか?