@k2works/claude-code-booster 1.12.0 → 2.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bin/claude-code-booster +5 -7
- package/lib/assets/.claude/README.md +73 -19
- package/lib/assets/.claude/agents/xp-architect.md +250 -0
- package/lib/assets/.claude/agents/xp-executive.md +207 -0
- package/lib/assets/.claude/agents/xp-interaction-designer.md +239 -0
- package/lib/assets/.claude/agents/xp-product-manager.md +245 -0
- package/lib/assets/.claude/agents/xp-programmer.md +268 -0
- package/lib/assets/.claude/agents/xp-project-manager.md +229 -0
- package/lib/assets/.claude/agents/xp-technical-writer.md +224 -0
- package/lib/assets/.claude/agents/xp-tester.md +265 -0
- package/lib/assets/.claude/agents/xp-user-representative.md +204 -0
- package/lib/assets/.claude/skills/ai-agent-guidelines/SKILL.md +49 -57
- package/lib/assets/.claude/skills/analyzing-architecture/SKILL.md +54 -58
- package/lib/assets/.claude/skills/analyzing-business/SKILL.md +52 -74
- package/lib/assets/.claude/skills/analyzing-data-model/SKILL.md +50 -53
- package/lib/assets/.claude/skills/analyzing-domain-model/SKILL.md +56 -56
- package/lib/assets/.claude/skills/analyzing-inception-deck/SKILL.md +56 -109
- package/lib/assets/.claude/skills/analyzing-non-functional/SKILL.md +61 -57
- package/lib/assets/.claude/skills/analyzing-operation/SKILL.md +61 -57
- package/lib/assets/.claude/skills/analyzing-requirements/SKILL.md +57 -55
- package/lib/assets/.claude/skills/analyzing-tech-stack/SKILL.md +66 -67
- package/lib/assets/.claude/skills/analyzing-test-strategy/SKILL.md +58 -56
- package/lib/assets/.claude/skills/analyzing-ui-design/SKILL.md +51 -57
- package/lib/assets/.claude/skills/analyzing-usecases/SKILL.md +45 -60
- package/lib/assets/.claude/skills/creating-adr/SKILL.md +38 -40
- package/lib/assets/.claude/skills/developing-backend/SKILL.md +49 -55
- package/lib/assets/.claude/skills/developing-frontend/SKILL.md +47 -50
- package/lib/assets/.claude/skills/developing-release/SKILL.md +60 -95
- package/lib/assets/.claude/skills/generating-slides/SKILL.md +58 -100
- package/lib/assets/.claude/skills/git-commit/SKILL.md +27 -52
- package/lib/assets/.claude/skills/killing-processes/SKILL.md +16 -70
- package/lib/assets/.claude/skills/operating-backup/SKILL.md +59 -0
- package/lib/assets/.claude/skills/operating-cicd/SKILL.md +54 -0
- package/lib/assets/.claude/skills/operating-deploy/SKILL.md +67 -0
- package/lib/assets/.claude/skills/{managing-docs → operating-docs}/SKILL.md +1 -1
- package/lib/assets/.claude/skills/operating-provision/SKILL.md +77 -0
- package/lib/assets/.claude/skills/operating-setup/SKILL.md +63 -0
- package/lib/assets/.claude/skills/orchestrating-analysis/SKILL.md +65 -95
- package/lib/assets/.claude/skills/orchestrating-development/SKILL.md +60 -155
- package/lib/assets/.claude/skills/orchestrating-operation/SKILL.md +158 -0
- package/lib/assets/.claude/skills/orchestrating-project/SKILL.md +60 -119
- package/lib/assets/.claude/skills/planning-releases/SKILL.md +63 -168
- package/lib/assets/.claude/skills/syncing-github-project/SKILL.md +62 -266
- package/lib/assets/.claude/skills/tracking-progress/SKILL.md +49 -122
- package/lib/assets/CLAUDE.md +7 -2
- package/lib/assets/README.md +3 -34
- package/lib/assets/docs/development/index.md +14 -8
- package/lib/assets/docs/index.md +1 -0
- package/lib/assets/docs/reference/SonarQube/343/203/255/343/203/274/343/202/253/343/203/253/347/222/260/345/242/203/343/202/273/343/203/203/343/203/210/343/202/242/343/203/203/343/203/227/346/211/213/351/240/206/346/233/270.md +640 -0
- package/lib/assets/docs/reference/index.md +1 -0
- package/lib/assets/docs/reference//351/201/213/347/224/250/343/202/271/343/202/257/343/203/252/343/203/227/343/203/210/344/275/234/346/210/220/343/202/254/343/202/244/343/203/211.md +421 -0
- package/lib/assets/docs/reference//351/226/213/347/231/272/343/202/254/343/202/244/343/203/211.md +69 -5
- package/lib/assets/docs/template/AWS/343/202/271/343/203/206/343/203/274/343/202/270/343/203/263/343/202/260/347/222/260/345/242/203/343/202/273/343/203/203/343/203/210/343/202/242/343/203/203/343/203/227/346/211/213/351/240/206/346/233/270.md +1366 -0
- package/lib/assets/docs/template/AWS/343/203/227/343/203/255/343/203/200/343/202/257/343/202/267/343/203/247/343/203/263/347/222/260/345/242/203/343/202/273/343/203/203/343/203/210/343/202/242/343/203/203/343/203/227/346/211/213/351/240/206/346/233/270.md +634 -0
- package/lib/assets/docs/template//343/202/242/343/203/227/343/203/252/343/202/261/343/203/274/343/202/267/343/203/247/343/203/263/351/226/213/347/231/272/347/222/260/345/242/203/343/202/273/343/203/203/343/203/210/343/202/242/343/203/203/343/203/227/346/211/213/351/240/206/346/233/270.md +547 -0
- package/lib/assets/docs/template//343/202/244/343/203/206/343/203/254/343/203/274/343/202/267/343/203/247/343/203/263/350/250/210/347/224/273.md +123 -1
- package/lib/assets/docs/template//350/250/255/350/250/210.md +12 -2
- package/lib/assets/docs/template//351/226/213/347/231/272/347/222/260/345/242/203/343/202/273/343/203/203/343/203/210/343/202/242/343/203/203/343/203/227/346/211/213/351/240/206/346/233/270.md +688 -0
- package/lib/assets/gulpfile.js +2 -0
- package/lib/assets/mkdocs.yml +1 -0
- package/lib/assets/ops/docker/sonarqube-local/docker-compose.yml +57 -0
- package/lib/assets/ops/scripts/sonar_local.js +726 -0
- package/package.json +1 -1
- package/lib/assets/.claude/SKILLS_TEMPLATE.md +0 -100
- package/lib/assets/.claude/agents/roles/.gitkeep +0 -0
- package/lib/assets/.claude/skills/managing-operations/DEPLOY.md +0 -77
- package/lib/assets/.claude/skills/managing-operations/SETUP_CSHARP.md +0 -80
- package/lib/assets/.claude/skills/managing-operations/SETUP_FRONTEND.md +0 -84
- package/lib/assets/.claude/skills/managing-operations/SETUP_JAVA.md +0 -75
- package/lib/assets/.claude/skills/managing-operations/SKILL.md +0 -156
|
@@ -0,0 +1,640 @@
|
|
|
1
|
+
# SonarQube ローカル開発環境セットアップ手順書
|
|
2
|
+
|
|
3
|
+
## 概要
|
|
4
|
+
|
|
5
|
+
ローカル開発 PC 上に SonarQube(Community Build)を Docker ベースで構築し、プロジェクトの静的コード解析環境を提供するための手順を説明します。
|
|
6
|
+
|
|
7
|
+
SonarQube は PostgreSQL をバックエンドデータベースとして使用し、Docker Compose で管理します。
|
|
8
|
+
|
|
9
|
+
| コンポーネント | コンテナ名 | ポート | イメージ |
|
|
10
|
+
| :--- | :--- | :--- | :--- |
|
|
11
|
+
| SonarQube | sonarqube | 9000 | `sonarqube:community` |
|
|
12
|
+
| PostgreSQL | sonarqube-db | — (内部) | `postgres:16-alpine` |
|
|
13
|
+
|
|
14
|
+
```plantuml
|
|
15
|
+
@startuml
|
|
16
|
+
|
|
17
|
+
title SonarQube on Local PC 構成図
|
|
18
|
+
|
|
19
|
+
node "開発 PC (localhost)" {
|
|
20
|
+
component "スキャナー\n(sonar-scanner / sbt / maven / gradle)" as scanner
|
|
21
|
+
|
|
22
|
+
package "Docker Desktop" {
|
|
23
|
+
component "SonarQube\n(Community Build)\nport: 9000" as sonar
|
|
24
|
+
database "PostgreSQL 16" as pg
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
component "ブラウザ" as browser
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
scanner --> sonar : HTTP (localhost:9000)\nスキャン結果送信
|
|
31
|
+
browser --> sonar : HTTP (localhost:9000)\nダッシュボード
|
|
32
|
+
sonar --> pg : JDBC (5432)\n内部ネットワーク
|
|
33
|
+
|
|
34
|
+
@enduml
|
|
35
|
+
```
|
|
36
|
+
|
|
37
|
+
## 前提条件
|
|
38
|
+
|
|
39
|
+
| 項目 | 要件 |
|
|
40
|
+
| :--- | :--- |
|
|
41
|
+
| OS | macOS / Windows / Linux |
|
|
42
|
+
| RAM | 最低 4GB(推奨 6GB 以上を Docker Desktop に割り当て) |
|
|
43
|
+
| ストレージ | 10GB 以上の空き容量 |
|
|
44
|
+
| Docker Desktop | インストール済み(Docker Compose 同梱) |
|
|
45
|
+
|
|
46
|
+
### Docker Desktop のリソース設定(推奨)
|
|
47
|
+
|
|
48
|
+
Docker Desktop > **Settings** > **Resources** で以下を設定します。
|
|
49
|
+
|
|
50
|
+
| 項目 | 最小 | 推奨 |
|
|
51
|
+
| :--- | :--- | :--- |
|
|
52
|
+
| Memory | 4GB | 6GB 以上 |
|
|
53
|
+
| CPUs | 2 | 4 |
|
|
54
|
+
| Disk | 20GB | 40GB |
|
|
55
|
+
|
|
56
|
+
### クロスプラットフォーム対応
|
|
57
|
+
|
|
58
|
+
| 機能 | macOS | Windows | Linux |
|
|
59
|
+
| :--- | :--- | :--- | :--- |
|
|
60
|
+
| ブラウザを開く | `open` | `start` | `xdg-open` |
|
|
61
|
+
| null デバイス | `/dev/null` | `NUL` | `/dev/null` |
|
|
62
|
+
| Docker Compose | `docker compose` | `docker compose` | `docker compose` |
|
|
63
|
+
|
|
64
|
+
---
|
|
65
|
+
|
|
66
|
+
## セットアップ手順
|
|
67
|
+
|
|
68
|
+
### 1. カーネルパラメータの設定
|
|
69
|
+
|
|
70
|
+
SonarQube 内部の Elasticsearch が `vm.max_map_count` の引き上げを要求します。
|
|
71
|
+
|
|
72
|
+
#### macOS
|
|
73
|
+
|
|
74
|
+
Docker Desktop for Mac は Linux VM 上で動作します。通常は Docker Desktop が適切な値を設定しますが、不足している場合は以下で引き上げます。
|
|
75
|
+
|
|
76
|
+
```bash
|
|
77
|
+
# 現在値を確認
|
|
78
|
+
docker run --rm --privileged alpine sysctl vm.max_map_count
|
|
79
|
+
|
|
80
|
+
# 524288 未満の場合は引き上げ(Docker Desktop 再起動まで有効)
|
|
81
|
+
docker run --rm --privileged alpine sysctl -w vm.max_map_count=524288
|
|
82
|
+
```
|
|
83
|
+
|
|
84
|
+
> **注意**: Docker Desktop を再起動すると値がリセットされます。SonarQube 起動前に毎回確認してください。
|
|
85
|
+
|
|
86
|
+
#### Windows(WSL2)
|
|
87
|
+
|
|
88
|
+
```powershell
|
|
89
|
+
# PowerShell(管理者)で WSL2 の設定を変更
|
|
90
|
+
wsl -d docker-desktop sysctl -w vm.max_map_count=524288
|
|
91
|
+
```
|
|
92
|
+
|
|
93
|
+
永続化するには `%USERPROFILE%\.wslconfig` に以下を追加します。
|
|
94
|
+
|
|
95
|
+
```ini
|
|
96
|
+
[wsl2]
|
|
97
|
+
kernelCommandLine = "sysctl.vm.max_map_count=524288"
|
|
98
|
+
```
|
|
99
|
+
|
|
100
|
+
#### Linux
|
|
101
|
+
|
|
102
|
+
```bash
|
|
103
|
+
# 一時的な設定(即時反映)
|
|
104
|
+
sudo sysctl -w vm.max_map_count=524288
|
|
105
|
+
|
|
106
|
+
# 永続化
|
|
107
|
+
echo "vm.max_map_count=524288" | sudo tee -a /etc/sysctl.d/99-sonarqube.conf
|
|
108
|
+
sudo sysctl --system
|
|
109
|
+
```
|
|
110
|
+
|
|
111
|
+
---
|
|
112
|
+
|
|
113
|
+
### 2. プロジェクト設定(任意)
|
|
114
|
+
|
|
115
|
+
プロジェクトルートに `sonarqube.config.json` を作成し、スキャン対象プロジェクトを定義します。設定ファイルがない場合、環境変数 `SONAR_PROJECT_KEY` の値(デフォルト: `my-project`)で単一プロジェクトとして動作します。
|
|
116
|
+
|
|
117
|
+
```json
|
|
118
|
+
{
|
|
119
|
+
"projects": [
|
|
120
|
+
{
|
|
121
|
+
"name": "backend",
|
|
122
|
+
"label": "Backend",
|
|
123
|
+
"projectKey": "my-backend",
|
|
124
|
+
"scanType": "sonar-scanner",
|
|
125
|
+
"srcDir": "apps/backend"
|
|
126
|
+
},
|
|
127
|
+
{
|
|
128
|
+
"name": "frontend",
|
|
129
|
+
"label": "Frontend",
|
|
130
|
+
"projectKey": "my-frontend",
|
|
131
|
+
"scanType": "sonar-scanner",
|
|
132
|
+
"srcDir": "apps/frontend"
|
|
133
|
+
}
|
|
134
|
+
]
|
|
135
|
+
}
|
|
136
|
+
```
|
|
137
|
+
|
|
138
|
+
#### scanType 一覧
|
|
139
|
+
|
|
140
|
+
| scanType | 説明 | 用途 |
|
|
141
|
+
| :--- | :--- | :--- |
|
|
142
|
+
| `sonar-scanner` | `npx sonarqube-scanner` で実行 | TypeScript / JavaScript / 汎用 |
|
|
143
|
+
| `sbt` | `sbt sonarScan` で実行 | Scala(sbt-sonar プラグイン) |
|
|
144
|
+
| `maven` | `mvn sonar:sonar` で実行 | Java / Kotlin(Maven) |
|
|
145
|
+
| `gradle` | `gradle sonar` で実行 | Java / Kotlin(Gradle) |
|
|
146
|
+
|
|
147
|
+
---
|
|
148
|
+
|
|
149
|
+
### 3. ディレクトリの作成
|
|
150
|
+
|
|
151
|
+
プロジェクトルートの `ops/docker/sonarqube-local/` に Docker Compose ファイルを配置します。データは Docker の名前付きボリュームで管理します。
|
|
152
|
+
|
|
153
|
+
```bash
|
|
154
|
+
mkdir -p ops/docker/sonarqube-local
|
|
155
|
+
```
|
|
156
|
+
|
|
157
|
+
#### ディレクトリ構造
|
|
158
|
+
|
|
159
|
+
```text
|
|
160
|
+
ops/docker/sonarqube-local/
|
|
161
|
+
└── docker-compose.yml # Docker Compose 設定
|
|
162
|
+
|
|
163
|
+
Docker ボリューム(自動作成):
|
|
164
|
+
sonarqube_data # SonarQube データ
|
|
165
|
+
sonarqube_logs # SonarQube ログ
|
|
166
|
+
sonarqube_extensions # SonarQube プラグイン
|
|
167
|
+
sonarqube_postgresql # PostgreSQL データ
|
|
168
|
+
```
|
|
169
|
+
|
|
170
|
+
---
|
|
171
|
+
|
|
172
|
+
### 4. Docker Compose の配置
|
|
173
|
+
|
|
174
|
+
`ops/docker/sonarqube-local/docker-compose.yml` を以下の内容で作成します。`npx gulp sonar-local:setup` を使用する場合は自動生成されます。
|
|
175
|
+
|
|
176
|
+
```yaml
|
|
177
|
+
services:
|
|
178
|
+
sonarqube:
|
|
179
|
+
image: sonarqube:community
|
|
180
|
+
container_name: sonarqube
|
|
181
|
+
restart: unless-stopped
|
|
182
|
+
depends_on:
|
|
183
|
+
sonarqube-db:
|
|
184
|
+
condition: service_healthy
|
|
185
|
+
ports:
|
|
186
|
+
- "9000:9000"
|
|
187
|
+
environment:
|
|
188
|
+
# --- DB 接続 ---
|
|
189
|
+
SONAR_JDBC_URL: jdbc:postgresql://sonarqube-db:5432/sonarqube
|
|
190
|
+
SONAR_JDBC_USERNAME: sonarqube
|
|
191
|
+
SONAR_JDBC_PASSWORD: sonarqube_password # 変更推奨
|
|
192
|
+
# --- JVM メモリ (ローカル環境向け) ---
|
|
193
|
+
SONAR_CE_JAVAOPTS: "-Xmx512m -Xms512m"
|
|
194
|
+
SONAR_WEB_JAVAOPTS: "-Xmx256m -Xms256m"
|
|
195
|
+
SONAR_SEARCH_JAVAOPTS: "-Xmx512m -Xms512m"
|
|
196
|
+
volumes:
|
|
197
|
+
- sonarqube_data:/opt/sonarqube/data
|
|
198
|
+
- sonarqube_logs:/opt/sonarqube/logs
|
|
199
|
+
- sonarqube_extensions:/opt/sonarqube/extensions
|
|
200
|
+
networks:
|
|
201
|
+
- sonarqube-net
|
|
202
|
+
healthcheck:
|
|
203
|
+
test: ["CMD-SHELL", "curl -f http://localhost:9000/api/system/status || exit 1"]
|
|
204
|
+
interval: 30s
|
|
205
|
+
timeout: 10s
|
|
206
|
+
retries: 5
|
|
207
|
+
start_period: 300s
|
|
208
|
+
|
|
209
|
+
sonarqube-db:
|
|
210
|
+
image: postgres:16-alpine
|
|
211
|
+
container_name: sonarqube-db
|
|
212
|
+
restart: unless-stopped
|
|
213
|
+
environment:
|
|
214
|
+
POSTGRES_DB: sonarqube
|
|
215
|
+
POSTGRES_USER: sonarqube
|
|
216
|
+
POSTGRES_PASSWORD: sonarqube_password # 上と同じに変更
|
|
217
|
+
volumes:
|
|
218
|
+
- sonarqube_postgresql:/var/lib/postgresql/data
|
|
219
|
+
networks:
|
|
220
|
+
- sonarqube-net
|
|
221
|
+
healthcheck:
|
|
222
|
+
test: ["CMD-SHELL", "pg_isready -U sonarqube"]
|
|
223
|
+
interval: 10s
|
|
224
|
+
timeout: 5s
|
|
225
|
+
retries: 5
|
|
226
|
+
|
|
227
|
+
networks:
|
|
228
|
+
sonarqube-net:
|
|
229
|
+
driver: bridge
|
|
230
|
+
|
|
231
|
+
volumes:
|
|
232
|
+
sonarqube_data:
|
|
233
|
+
sonarqube_logs:
|
|
234
|
+
sonarqube_extensions:
|
|
235
|
+
sonarqube_postgresql:
|
|
236
|
+
```
|
|
237
|
+
|
|
238
|
+
> **重要**: `SONAR_JDBC_PASSWORD` と `POSTGRES_PASSWORD` は同じ値に変更してください。
|
|
239
|
+
|
|
240
|
+
#### JVM メモリ設定の目安
|
|
241
|
+
|
|
242
|
+
| Docker 割り当て RAM | WEB | CE | SEARCH |
|
|
243
|
+
| :--- | :--- | :--- | :--- |
|
|
244
|
+
| 4GB | `-Xmx256m -Xms256m` | `-Xmx512m -Xms512m` | `-Xmx512m -Xms512m` |
|
|
245
|
+
| 6GB | `-Xmx512m -Xms512m` | `-Xmx1g -Xms1g` | `-Xmx512m -Xms512m` |
|
|
246
|
+
| 8GB 以上 | `-Xmx512m -Xms512m` | `-Xmx1g -Xms1g` | `-Xmx1g -Xms1g` |
|
|
247
|
+
|
|
248
|
+
> **重要**: ES 8.x は初期ヒープサイズ(`-Xms`)と最大ヒープサイズ(`-Xmx`)が一致している必要があります。不一致の場合、bootstrap check failure(exit code 78)で起動に失敗します。
|
|
249
|
+
|
|
250
|
+
---
|
|
251
|
+
|
|
252
|
+
### 5. コンテナの起動
|
|
253
|
+
|
|
254
|
+
```bash
|
|
255
|
+
cd ops/docker/sonarqube-local
|
|
256
|
+
|
|
257
|
+
# コンテナを起動
|
|
258
|
+
docker compose up -d
|
|
259
|
+
|
|
260
|
+
# 起動状態を確認
|
|
261
|
+
docker compose ps
|
|
262
|
+
|
|
263
|
+
# ヘルスチェック待ち(初回は数分かかる)
|
|
264
|
+
docker compose logs -f sonarqube
|
|
265
|
+
```
|
|
266
|
+
|
|
267
|
+
---
|
|
268
|
+
|
|
269
|
+
### 6. 初期設定
|
|
270
|
+
|
|
271
|
+
#### 6.1 ログイン
|
|
272
|
+
|
|
273
|
+
ブラウザで `http://localhost:9000` にアクセスします。
|
|
274
|
+
|
|
275
|
+
| 項目 | 初期値 |
|
|
276
|
+
| :--- | :--- |
|
|
277
|
+
| ユーザー ID | `admin` |
|
|
278
|
+
| パスワード | `admin` |
|
|
279
|
+
|
|
280
|
+
初回ログイン時にパスワード変更を求められるので、新しいパスワードを設定します。
|
|
281
|
+
|
|
282
|
+
#### 6.2 トークンの生成
|
|
283
|
+
|
|
284
|
+
プロジェクトスキャンに使用する認証トークンを生成します。
|
|
285
|
+
|
|
286
|
+
1. 右上の **A**(admin アイコン)> **My Account** をクリック
|
|
287
|
+
2. **Security** タブを選択
|
|
288
|
+
3. **Tokens** セクションの **Generate** 欄にトークン名(例: `local-dev`)を入力
|
|
289
|
+
4. **Generate** をクリック
|
|
290
|
+
5. 表示されたトークンをコピーしてプロジェクトルートの `.env` に設定
|
|
291
|
+
|
|
292
|
+
```bash
|
|
293
|
+
# .env に追加
|
|
294
|
+
SONAR_HOST_URL=http://localhost:9000
|
|
295
|
+
SONAR_TOKEN=<YOUR_TOKEN>
|
|
296
|
+
```
|
|
297
|
+
|
|
298
|
+
> **重要**: トークンは一度しか表示されません。紛失した場合は再発行が必要です。
|
|
299
|
+
|
|
300
|
+
#### 6.3 日本語プラグインのインストール(任意)
|
|
301
|
+
|
|
302
|
+
1. **Administration** > **Marketplace** を開く
|
|
303
|
+
2. 「Japanese」で検索
|
|
304
|
+
3. **Install** をクリック
|
|
305
|
+
4. SonarQube を再起動
|
|
306
|
+
|
|
307
|
+
---
|
|
308
|
+
|
|
309
|
+
## プロジェクトのスキャン
|
|
310
|
+
|
|
311
|
+
### 事前準備: プロジェクト作成と権限付与
|
|
312
|
+
|
|
313
|
+
1. SonarQube でプロジェクトを作成してください。Project Key が `sonarqube.config.json` の `projectKey` と一致しているか確認してください。
|
|
314
|
+
2. 次のどちらかで権限を付与してください。
|
|
315
|
+
- 付与方法 A: 管理者でログイン > Administration > Security > Users で対象ユーザーに `Execute Analysis` を付与
|
|
316
|
+
- 付与方法 B: プロジェクト画面 > Project Settings > Permissions で `Execute Analysis` を付与
|
|
317
|
+
|
|
318
|
+
### スキャンツール別の設定
|
|
319
|
+
|
|
320
|
+
#### sonar-scanner(TypeScript / JavaScript / 汎用)
|
|
321
|
+
|
|
322
|
+
```bash
|
|
323
|
+
cd <project-dir>
|
|
324
|
+
npm install --save-dev sonarqube-scanner
|
|
325
|
+
```
|
|
326
|
+
|
|
327
|
+
`sonar-project.properties` を作成します。
|
|
328
|
+
|
|
329
|
+
```properties
|
|
330
|
+
sonar.projectKey=<YOUR_PROJECT_KEY>
|
|
331
|
+
sonar.projectName=<YOUR_PROJECT_NAME>
|
|
332
|
+
sonar.sources=src
|
|
333
|
+
sonar.tests=src
|
|
334
|
+
sonar.test.inclusions=**/*.test.ts,**/*.test.tsx,**/*.spec.ts,**/*.spec.tsx
|
|
335
|
+
sonar.exclusions=**/node_modules/**,**/generated/**,**/dist/**
|
|
336
|
+
sonar.typescript.lcov.reportPaths=coverage/lcov.info
|
|
337
|
+
sonar.sourceEncoding=UTF-8
|
|
338
|
+
```
|
|
339
|
+
|
|
340
|
+
```bash
|
|
341
|
+
# テスト実行(カバレッジデータ生成)
|
|
342
|
+
npm run test:coverage
|
|
343
|
+
|
|
344
|
+
# SonarQube スキャン
|
|
345
|
+
npx sonarqube-scanner \
|
|
346
|
+
-Dsonar.host.url=http://localhost:9000 \
|
|
347
|
+
-Dsonar.token=<YOUR_TOKEN>
|
|
348
|
+
```
|
|
349
|
+
|
|
350
|
+
#### sbt(Scala)
|
|
351
|
+
|
|
352
|
+
`project/plugins.sbt` に SonarScanner プラグインを追加します。
|
|
353
|
+
|
|
354
|
+
```scala
|
|
355
|
+
addSbtPlugin("com.sonar-scala" % "sbt-sonar" % "2.3.0")
|
|
356
|
+
```
|
|
357
|
+
|
|
358
|
+
`build.sbt` に SonarQube 設定を追加します。
|
|
359
|
+
|
|
360
|
+
```scala
|
|
361
|
+
sonarProperties := Map(
|
|
362
|
+
"sonar.projectKey" -> "<YOUR_PROJECT_KEY>",
|
|
363
|
+
"sonar.projectName" -> "<YOUR_PROJECT_NAME>",
|
|
364
|
+
"sonar.sources" -> "src/main/scala",
|
|
365
|
+
"sonar.tests" -> "src/test/scala",
|
|
366
|
+
"sonar.sourceEncoding" -> "UTF-8",
|
|
367
|
+
"sonar.scala.coverage.reportPaths" ->
|
|
368
|
+
"target/scala-3.6.2/scoverage-report/scoverage.xml"
|
|
369
|
+
)
|
|
370
|
+
```
|
|
371
|
+
|
|
372
|
+
```bash
|
|
373
|
+
# テスト実行(カバレッジデータ生成)
|
|
374
|
+
sbt coverage test coverageReport
|
|
375
|
+
|
|
376
|
+
# SonarQube スキャン
|
|
377
|
+
sbt sonarScan \
|
|
378
|
+
-Dsonar.host.url=http://localhost:9000 \
|
|
379
|
+
-Dsonar.token=<YOUR_TOKEN>
|
|
380
|
+
```
|
|
381
|
+
|
|
382
|
+
#### Maven(Java / Kotlin)
|
|
383
|
+
|
|
384
|
+
```bash
|
|
385
|
+
mvn sonar:sonar \
|
|
386
|
+
-Dsonar.projectKey=<YOUR_PROJECT_KEY> \
|
|
387
|
+
-Dsonar.host.url=http://localhost:9000 \
|
|
388
|
+
-Dsonar.token=<YOUR_TOKEN>
|
|
389
|
+
```
|
|
390
|
+
|
|
391
|
+
#### Gradle(Java / Kotlin)
|
|
392
|
+
|
|
393
|
+
`build.gradle` にプラグインを追加します。
|
|
394
|
+
|
|
395
|
+
```groovy
|
|
396
|
+
plugins {
|
|
397
|
+
id "org.sonarqube" version "5.1.0.4882"
|
|
398
|
+
}
|
|
399
|
+
```
|
|
400
|
+
|
|
401
|
+
```bash
|
|
402
|
+
gradle sonar \
|
|
403
|
+
-Dsonar.projectKey=<YOUR_PROJECT_KEY> \
|
|
404
|
+
-Dsonar.host.url=http://localhost:9000 \
|
|
405
|
+
-Dsonar.token=<YOUR_TOKEN>
|
|
406
|
+
```
|
|
407
|
+
|
|
408
|
+
---
|
|
409
|
+
|
|
410
|
+
## 典型的な利用フロー
|
|
411
|
+
|
|
412
|
+
### Gulp タスクを使用する場合
|
|
413
|
+
|
|
414
|
+
```bash
|
|
415
|
+
# 1. プロジェクト設定(任意)
|
|
416
|
+
# sonarqube.config.json を作成
|
|
417
|
+
|
|
418
|
+
# 2. SonarQube セットアップ
|
|
419
|
+
npx gulp sonar-local:setup
|
|
420
|
+
|
|
421
|
+
# 3. ブラウザで初期設定・トークン生成(初回のみ)
|
|
422
|
+
# http://localhost:9000
|
|
423
|
+
|
|
424
|
+
# 4. .env に SONAR_TOKEN を追加
|
|
425
|
+
|
|
426
|
+
# 5. スキャン実行
|
|
427
|
+
npx gulp sonar-local:scan
|
|
428
|
+
|
|
429
|
+
# 6. 結果確認
|
|
430
|
+
npx gulp sonar-local:issues
|
|
431
|
+
```
|
|
432
|
+
|
|
433
|
+
### 手動で実行する場合
|
|
434
|
+
|
|
435
|
+
```bash
|
|
436
|
+
# 1. SonarQube コンテナ起動
|
|
437
|
+
cd ops/docker/sonarqube-local
|
|
438
|
+
docker compose up -d
|
|
439
|
+
|
|
440
|
+
# 2. ブラウザで初期設定・トークン生成(初回のみ)
|
|
441
|
+
# http://localhost:9000
|
|
442
|
+
|
|
443
|
+
# 3. スキャン実行(プロジェクトのスキャンツールに応じて実行)
|
|
444
|
+
|
|
445
|
+
# 4. 結果を確認
|
|
446
|
+
# http://localhost:9000
|
|
447
|
+
```
|
|
448
|
+
|
|
449
|
+
---
|
|
450
|
+
|
|
451
|
+
## API による診断情報の取得
|
|
452
|
+
|
|
453
|
+
```bash
|
|
454
|
+
# サーバー状態
|
|
455
|
+
curl -u <TOKEN>: http://localhost:9000/api/system/status
|
|
456
|
+
|
|
457
|
+
# プロジェクト一覧
|
|
458
|
+
curl -u <TOKEN>: "http://localhost:9000/api/projects/search"
|
|
459
|
+
|
|
460
|
+
# 課題一覧(重大度フィルタ付き)
|
|
461
|
+
curl -u <TOKEN>: "http://localhost:9000/api/issues/search?\
|
|
462
|
+
componentKeys=<PROJECT_KEY>&\
|
|
463
|
+
types=BUG,VULNERABILITY,CODE_SMELL&\
|
|
464
|
+
severities=BLOCKER,CRITICAL,MAJOR"
|
|
465
|
+
|
|
466
|
+
# メトリクス
|
|
467
|
+
curl -u <TOKEN>: "http://localhost:9000/api/measures/component?\
|
|
468
|
+
component=<PROJECT_KEY>&\
|
|
469
|
+
metricKeys=bugs,vulnerabilities,code_smells,coverage,duplicated_lines_density,ncloc"
|
|
470
|
+
|
|
471
|
+
# 品質ゲート
|
|
472
|
+
curl -u <TOKEN>: "http://localhost:9000/api/qualitygates/project_status?\
|
|
473
|
+
projectKey=<PROJECT_KEY>"
|
|
474
|
+
```
|
|
475
|
+
|
|
476
|
+
---
|
|
477
|
+
|
|
478
|
+
## Docker 管理コマンド
|
|
479
|
+
|
|
480
|
+
```bash
|
|
481
|
+
# プロジェクトディレクトリに移動
|
|
482
|
+
cd ops/docker/sonarqube-local
|
|
483
|
+
|
|
484
|
+
# コンテナの状態確認
|
|
485
|
+
docker compose ps
|
|
486
|
+
|
|
487
|
+
# コンテナの起動
|
|
488
|
+
docker compose up -d
|
|
489
|
+
|
|
490
|
+
# コンテナの停止
|
|
491
|
+
docker compose down
|
|
492
|
+
|
|
493
|
+
# コンテナの再起動
|
|
494
|
+
docker compose restart
|
|
495
|
+
|
|
496
|
+
# ログの確認(リアルタイム)
|
|
497
|
+
docker compose logs -f sonarqube
|
|
498
|
+
|
|
499
|
+
# ログの確認(直近 100 行)
|
|
500
|
+
docker compose logs --tail=100 sonarqube
|
|
501
|
+
|
|
502
|
+
# コンテナに接続
|
|
503
|
+
docker exec -it sonarqube bash
|
|
504
|
+
```
|
|
505
|
+
|
|
506
|
+
---
|
|
507
|
+
|
|
508
|
+
## バックアップ
|
|
509
|
+
|
|
510
|
+
### データベースのダンプ
|
|
511
|
+
|
|
512
|
+
```bash
|
|
513
|
+
docker exec sonarqube-db \
|
|
514
|
+
pg_dump -U sonarqube sonarqube > backup.sql
|
|
515
|
+
```
|
|
516
|
+
|
|
517
|
+
### データの完全リセット
|
|
518
|
+
|
|
519
|
+
ローカル環境では再構築が容易なため、データを完全にリセットすることもできます。
|
|
520
|
+
|
|
521
|
+
```bash
|
|
522
|
+
cd ops/docker/sonarqube-local
|
|
523
|
+
|
|
524
|
+
# コンテナとボリュームを削除
|
|
525
|
+
docker compose down -v
|
|
526
|
+
|
|
527
|
+
# 再起動(初期状態から)
|
|
528
|
+
docker compose up -d
|
|
529
|
+
```
|
|
530
|
+
|
|
531
|
+
---
|
|
532
|
+
|
|
533
|
+
## トラブルシューティング
|
|
534
|
+
|
|
535
|
+
### SonarQube が起動しない
|
|
536
|
+
|
|
537
|
+
```bash
|
|
538
|
+
# ログを確認
|
|
539
|
+
docker logs sonarqube
|
|
540
|
+
|
|
541
|
+
# vm.max_map_count を確認(Docker Desktop 内部)
|
|
542
|
+
docker run --rm --privileged alpine sysctl vm.max_map_count
|
|
543
|
+
```
|
|
544
|
+
|
|
545
|
+
### Elasticsearch exit code 78: ヒープサイズ不一致
|
|
546
|
+
|
|
547
|
+
```text
|
|
548
|
+
bootstrap check failure [1] of [1]: initial heap size [268435456] not equal to maximum heap size [536870912]
|
|
549
|
+
```
|
|
550
|
+
|
|
551
|
+
ES 8.x は `-Xms` と `-Xmx` が一致していることを要求します。`docker-compose.yml` の `SONAR_SEARCH_JAVAOPTS` で `-Xms` と `-Xmx` を同じ値に設定してください。
|
|
552
|
+
|
|
553
|
+
```yaml
|
|
554
|
+
# NG: Xms != Xmx
|
|
555
|
+
SONAR_SEARCH_JAVAOPTS: "-Xmx512m -Xms256m"
|
|
556
|
+
|
|
557
|
+
# OK: Xms == Xmx
|
|
558
|
+
SONAR_SEARCH_JAVAOPTS: "-Xmx512m -Xms512m"
|
|
559
|
+
```
|
|
560
|
+
|
|
561
|
+
> **注意**: `SONAR_CE_JAVAOPTS` と `SONAR_WEB_JAVAOPTS` も同様に `-Xms` と `-Xmx` を一致させてください。
|
|
562
|
+
|
|
563
|
+
### Elasticsearch exit code 78: vm.max_map_count 不足
|
|
564
|
+
|
|
565
|
+
```bash
|
|
566
|
+
# Docker Desktop 内部の値を確認
|
|
567
|
+
docker run --rm --privileged alpine sysctl vm.max_map_count
|
|
568
|
+
|
|
569
|
+
# 524288 未満の場合は引き上げ
|
|
570
|
+
docker run --rm --privileged alpine sysctl -w vm.max_map_count=524288
|
|
571
|
+
```
|
|
572
|
+
|
|
573
|
+
### メモリ不足
|
|
574
|
+
|
|
575
|
+
Docker Desktop のリソース割り当てを増やすか、`docker-compose.yml` の JVM 設定を調整してください(セクション 4 の JVM メモリ設定の目安を参照)。
|
|
576
|
+
|
|
577
|
+
### ポート競合
|
|
578
|
+
|
|
579
|
+
9000 番ポートが他サービスで使用中の場合、`docker-compose.yml` のポートマッピングを変更します:
|
|
580
|
+
|
|
581
|
+
```yaml
|
|
582
|
+
ports:
|
|
583
|
+
- "9100:9000" # 外部ポートを変更
|
|
584
|
+
```
|
|
585
|
+
|
|
586
|
+
> **ヒント**: ポートを変更した場合は `.env` の `SONAR_HOST_URL` も合わせて変更してください。
|
|
587
|
+
|
|
588
|
+
### コンテナが起動しない
|
|
589
|
+
|
|
590
|
+
| 症状 | 原因 | 対処 |
|
|
591
|
+
| :--- | :--- | :--- |
|
|
592
|
+
| ES exit code 78(ヒープ不一致) | `-Xms` と `-Xmx` が不一致 | JVM オプションで `-Xms` と `-Xmx` を同じ値に設定 |
|
|
593
|
+
| ES exit code 78(vm.max_map_count) | `vm.max_map_count` 不足 | `docker run --rm --privileged alpine sysctl -w vm.max_map_count=524288` |
|
|
594
|
+
| DB 接続エラー | パスワード不一致 | `SONAR_JDBC_PASSWORD` と `POSTGRES_PASSWORD` が一致しているか確認 |
|
|
595
|
+
| OOM / メモリ不足 | Docker のメモリ割り当て不足 | Docker Desktop のリソース設定でメモリを増やす |
|
|
596
|
+
| ヘルスチェック失敗 | 起動に時間がかかる | `start_period` を延長(デフォルト 300s) |
|
|
597
|
+
| ディスク容量不足 | Docker のディスク容量不足 | Docker Desktop のディスク割り当てを増やす、または `docker system prune` で不要イメージを削除 |
|
|
598
|
+
|
|
599
|
+
### Windows 固有の問題
|
|
600
|
+
|
|
601
|
+
#### WSL2 のカーネルパラメータがリセットされる
|
|
602
|
+
|
|
603
|
+
`%USERPROFILE%\.wslconfig` に永続設定を記述してください(セクション 1 参照)。
|
|
604
|
+
|
|
605
|
+
### Docker Desktop のディスク容量を解放
|
|
606
|
+
|
|
607
|
+
```bash
|
|
608
|
+
# 未使用のイメージ・ボリューム・ネットワークを削除
|
|
609
|
+
docker system prune -a
|
|
610
|
+
|
|
611
|
+
# 未使用ボリュームのみ削除(SonarQube が停止中の場合は注意)
|
|
612
|
+
docker volume prune
|
|
613
|
+
```
|
|
614
|
+
|
|
615
|
+
---
|
|
616
|
+
|
|
617
|
+
## ポート一覧
|
|
618
|
+
|
|
619
|
+
| サービス | ポート | 備考 |
|
|
620
|
+
| :--- | :--- | :--- |
|
|
621
|
+
| SonarQube | 9000 | Web UI・API |
|
|
622
|
+
| PostgreSQL | 5432(内部) | SonarQube 専用・外部非公開 |
|
|
623
|
+
|
|
624
|
+
---
|
|
625
|
+
|
|
626
|
+
## 接続情報まとめ
|
|
627
|
+
|
|
628
|
+
| 用途 | 接続先 |
|
|
629
|
+
| :--- | :--- |
|
|
630
|
+
| SonarQube ダッシュボード | `http://localhost:9000` |
|
|
631
|
+
| SonarQube API | `http://localhost:9000/api` |
|
|
632
|
+
|
|
633
|
+
---
|
|
634
|
+
|
|
635
|
+
## セキュリティチェックリスト
|
|
636
|
+
|
|
637
|
+
- [ ] `admin` の初期パスワードを変更した
|
|
638
|
+
- [ ] PostgreSQL のパスワードをデフォルトから変更した
|
|
639
|
+
- [ ] 分析トークンを `.env` に記載し `.gitignore` で除外されている
|
|
640
|
+
- [ ] トークンの有効期限を把握している
|