summaryrefslogtreecommitdiff
path: root/Deploy.md
blob: be729d1a9db87c35f5a63e1131076b2fe6531f7e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
# Deploy

Hetzner Cloud + Docker + Caddy (HTTPS) の共有インフラ。
複数アプリを同一ホストで運用し、Caddy がホスト名でルーティングする。

## 構成

```
git push hetzner master  (各リポジトリ)
  └→ /var/git/<repo>.git/hooks/post-receive
       └→ git checkout -f → /app/<name>/
       └→ docker compose up -d (--build)

Docker network: web  (external, 全アプリ共有)
  ├── infra-caddy-1   (80/443, HTTPS 自動証明書)
  ├── tokyo-app       (golive.yyamashita.com → :3000)
  └── whois-app       (whois.band → :3000)
```

- **サーバー**: Hetzner CX22 (Helsinki, Ubuntu 24.04)
- **SSH**: `ssh golive`

## リポジトリとデプロイ先

| リポジトリ | bare repo | work tree |
|---|---|---|
| hetzner-infra | /var/git/hetzner-infra.git | /app/infra |
| tokyo-livehouse-events | /var/git/tokyo-livehouse-events.git | /app/tokyo-livehouse-events |
| whois-band | /var/git/whois-band.git | /app/whois-band |

## デプロイ

```bash
git push hetzner master
```

Caddyfile 変更時も同様(push 後に自動 reload)。

## サーバー操作

```bash
# 全コンテナ確認
ssh golive 'docker ps'

# Caddy ログ
ssh golive 'docker logs infra-caddy-1 -f'

# tokyo ログ
ssh golive 'docker logs tokyo-app -f'

# whois ログ
ssh golive 'docker logs whois-app -f'
```

## サーバー構成管理

ベアリポジトリ・ワークツリー・フックはすべてこのリポジトリで一元管理する。
git push では**自動展開しない**(セキュリティ上の理由)。変更後は手動で `install.sh` を実行する。

| ファイル | 役割 |
|---|---|
| `repos.txt` | 全リポジトリの定義(`name:work-tree` 形式) |
| `server-hooks/<repo>/post-receive` | 各リポジトリのフック内容 |
| `scripts/install.sh` | ベアリポジトリ作成 + フック展開(要 root) |
| `scripts/server-setup.sh` | 初回のみ: Docker + hetzner-infra ブートストラップ |

```bash
# 変更を反映する場合
git push origin master
ssh root@localhost 'bash /app/infra/scripts/install.sh'
```

## 新アプリ追加手順

1. `repos.txt` に `<name>:<work-tree>` を追記
2. `server-hooks/<name>/post-receive` を作成
3. `Caddyfile` にホスト追加
4. `git push origin master` → `ssh root@localhost 'bash /app/infra/scripts/install.sh'`
5. 新アプリ側: `git remote add hetzner root@localhost:/var/git/<name>.git` → `git push hetzner master`

## Claude Code セッション管理

`git push` 時に post-receive フック(root)が `yyamashita` ユーザーの systemd user service を自動同期する。

| ファイル | 役割 |
|---|---|
| `systemd/user/claude-code@.service` | サービステンプレート |
| `claude-code-sessions.txt` | 有効にするセッション一覧(`user:repo` 形式) |
| `scripts/sync-claude-services.sh` | root が user service を同期するスクリプト |

### セッション追加・削除

`claude-code-sessions.txt` を編集して `git push hetzner master`:

```
# 形式: user:repo
yyamashita:hetzner-infra
yyamashita:new-repo
```

### 手動同期(サーバー上で)

```bash
ssh root@localhost 'bash /app/infra/scripts/sync-claude-services.sh'
```

### サービス確認

```bash
systemctl --user status 'claude-code@*.service'
tmux ls
```

## 初回サーバーセットアップ(再構築時)

```bash
# 1. hetzner-infra を最初にセットアップ(Docker + web network 作成)
scp scripts/server-setup.sh golive:~/
ssh golive 'bash server-setup.sh'
git push hetzner master

# 2. 各アプリをセットアップ
# (各リポジトリの scripts/server-setup.sh を参照)
```