Keycloak のテストインスタンスのデプロイ
サポートエンジニア向けのテスト環境セットアップオプションとガイドライン
Keycloak のテストインスタンスのデプロイ
前提条件
- 外部 IP アドレスを持つ VM を作成します。本例では RHEL8 ベースのコマンドを使用します。
- この VM 上でポート 8080 と 8443 にアクセスできることを確認します。
- Keycloak インスタンスに使用するホスト名を決め、VM の外部 IP を取得し、IP アドレスとホスト名を紐付ける A レコードを DNS サーバーに設定します。詳細は テストインスタンス用 DNS を参照してください。
- https://punchsalad.com/ssl-certificate-generator/ を使って証明書を生成します。DNS チャレンジが最も簡単な検証方法です。証明書と秘密鍵をローカルに保存しておきます。
インストール
PostgreSQL をインストールします:
dnf install -y https://download.postgresql.org/pub/repos/yum/reporpms/EL-8-x86_64/pgdg-redhat-repo-latest.noarch.rpm dnf -qy module disable postgresql dnf install -y postgresql16-server sudo /usr/pgsql-16/bin/postgresql-16-setup initdb sudo systemctl enable postgresql-16 sudo systemctl start postgresql-16Keycloak 用のデータベースとユーザーを作成します:
sudo -u postgres psql CREATE USER keycloak WITH PASSWORD 'your-database-password'; CREATE DATABASE keycloak OWNER keycloak; GRANT ALL PRIVILEGES ON DATABASE keycloak TO keycloak;java と keycloak をインストールします:
yum install java-21-openjdk-devel wget -y cd /opt sudo wget https://github.com/keycloak/keycloak/releases/download/26.0.7/keycloak-26.0.7.tar.gz sudo tar -xzf keycloak-26.0.7.tar.gz sudo mv keycloak-26.0.7 keycloakDB 接続が正しく機能するか確認するため、
/opt/keycloak/conf/keycloak.confに以下の行を追加してシンプルなインスタンスを設定します:db=postgres db-username=keycloak db-password=your-database-password hostname=your-host-name.domain.tld http-enabled=true http-port=8080keycloak を起動し、ブラウザで http://your-host-name.domain.tld:8080 を開いて動作を確認します。UI は開きますが、HTTPS なしでは使用できません:
cd /opt/keycloak ./bin/kc.sh bootstrap-admin user --bootstrap-admin-username admin --bootstrap-admin-password keycloak-password ./bin/kc.sh startkeycloak を停止し、
/opt/keycloak/conf/keycloak.confに以下の値を追加して HTTPS を設定します。証明書と鍵を所定の場所に配置することを忘れないでください:https-port=8443 https-certificate-file=/opt/keycloak/conf/certificate.pem https-certificate-key-file=/opt/keycloak/conf/key.pem再度 keycloak を起動します。コマンドラインで設定した認証情報を使って https://your-host-name.domain.tld:8443 からログインできるようになっているはずです。
最終更新 June 14, 2026: Merge pull request #403 from kyama0/claude/cool-turing-ls6eck (
bfd74782)