概要
これまでの「オンプレ編」では、Azure の仮想マシン(IaaS)を使って、社員番号から名前を検索できるシンプルな社内システムを構築してきました。Active Directory、SQL Server、ADFS などを組み合わせ、オンプレミスの構成を仮想的に再現しています。
※全体構成の詳細は、【第0回】Azureで社内システム再現(オンプレ編)|構成図と動作の流れ をご参照ください。
クラウド編では、これまでの構成をベースにしつつ、Azure のマネージドサービス(PaaS)を中心とした構成へ段階的に移行していきます。
※クラウド移行全体の設計方針については、【第10.5回】Azureで社内システム再現(クラウド編)|オンプレ構成をどうクラウドに移行するか? にまとめています。
システム構成(今回の対象範囲)
構成図の赤枠で囲った部分が今回の対象です。
今回は、Azure Web App を作成し、GitHub と連携して継続的デプロイ(CI/CD)の構成を行います。
具体的には、以下の作業を行います:
-
Azure Web App(PHP 8.3 / Linux)の作成
-
GitHub リポジトリとの接続
App Service の作成
まずは、PHP アプリケーションをホストするための Azure App Service を作成します。
今回は静的コンテンツのみを扱う「静的 Web アプリ」ではなく、PHP を含む動的アプリケーションのため「Web アプリ」を選択します。
作成時の主な設定は以下のとおりです。
項目 | 設定値 |
---|---|
ランタイムスタック | PHP 8.3 |
オペレーティングシステム | Linux |
オンプレミス環境では Windows 上で PHP アプリを動作させていましたが、本アプリには OS に依存した処理は含まれていません。
そのため、Linux プランでも特に問題なく動作します。PHP 8.3 を選択する必要があったため、今回は Linux を選択しています。
ランタイムとしてPHPを選択すると自動でLinuxになります。
サンプルコードについて
本記事で使用しているPHPコードや設定ファイルは、以下のGitHubリポジトリに公開しています。
- GitHubリポジトリ:
https://github.com/saba-infra/employee-app
コード全体を確認したい方は、上記のリポジトリをご参照ください。
PHPコードの主な変更点
クラウド移行にあたり、主に以下の点を変更しています。
-
SQL Server への接続方式を
sqlsrv
→PDO
に変更 -
データベースへの接続情報
$server = "tcp:sqlsrv-employee.database.windows.net,1433"; $database = "sqldb-employee"; $user = "sqladmin"; $password = "PASSWORD";
接続方式を変更した理由
オンプレミス環境では sqlsrv_connect()
を使用して SQL Server に接続していました。
一方で、Azure App Service(Linux)では SQLSRV
拡張が標準で含まれておらず、この関数は使用できませんでした。
そのため、標準で利用可能な PDO_SQLSRV
拡張を使用する方式に変更しました。
GitHub との接続と継続的デプロイ
App Service を作成した後、GitHub リポジトリと連携することで、継続的デプロイ(CI/CD)の構成を行いました。
GitHub の接続設定
Azure ポータルの「デプロイ センター」から、GitHub のアカウントにサインインし、デプロイ対象のリポジトリとブランチを選択します。
この操作により、GitHub Actions による自動デプロイの構成が自動で作成されます。
GitHub Actions による自動デプロイ
GitHub との接続が完了すると、.github/workflows/
配下に YAML ファイルが自動生成されます。
このファイルには、push をトリガーにアプリをデプロイする処理が記述されています。
ワークフローは主に以下の2ステップで構成されています。
-
build:リポジトリのコードを取得し、本番環境で実行可能な状態に整える処理です。
Python などの言語では、pip install
のように必要なモジュールをインストールするステップが含まれます。
今回の PHP アプリでは特別なビルド処理は不要なため、このステップではコードの取得のみで完了します。 -
deploy:アプリケーションを Azure App Service にデプロイします。
実行結果は GitHubやデプロイセンターのログから確認できます。以下は build および deploy が正常に完了した例です。