重要
Cloud Services (クラシック) は、2024 年 9 月 1 日をもって、すべてのお客様に対して非推奨になりました。 実行中の既存のデプロイはすべて Microsoft によって停止およびシャットダウンされ、2024 年 10 月以降、そのデータは永久に失われます。 新しいデプロイでは、新しい Azure Resource Manager ベースのデプロイ モデル Azure Cloud Services (延長サポート) を使用する必要があります。
node.js には、コア ランタイムの最小限の機能セットが含まれます。 多くの場合、開発者は Node.js アプリケーションを開発するときに、Microsoft 以外のモジュールを使用して追加機能を提供します。 このチュートリアルでは、 Express モジュールを使用して新しいアプリケーションを作成します。これにより、Node.js Web アプリケーションを作成するためのモデルView-Control フレームワークが提供されます。
次に示すのは完成したアプリケーションのスクリーンショットです。
クラウド サービス プロジェクトの作成
注
このセクションを適切に実行するには、正常に動作している Node.js のインストールと、ご利用のプラットフォーム用の Azure SDK for Node.js が必要です。
- Azure SDK for Node.jsをインストールする: Windows インストーラー
次の手順を実行して、expressapp という名前の新しいクラウド サービス プロジェクトを作成します。
スタート メニューまたはスタート画面から、Windows PowerShell を検索します。 最後に、 Windows PowerShell を右クリックし、[ 管理者として実行] を選択します。
ディレクトリを c:\node ディレクトリに変更し、次のコマンドを入力して、
expressappという名前の新しいソリューションと WebRole1 という名前の Web ロールを作成します。PS C:\node> New-AzureServiceProject expressapp PS C:\Node\expressapp> Add-AzureNodeWebRole PS C:\Node\expressapp> Set-AzureServiceProjectRole WebRole1 Node 0.10.21注
既定では、 Add-AzureNodeWebRole は古いバージョンの Node.jsを使用します。 上記 の Set-AzureServiceProjectRole 行は、Node の v0.10.21 を使用するように Azure に指示します。 パラメーターには大文字と小文字の区別があることに注意してください。 WebRole1\package.jsの engines プロパティをオンにすることで、正しいバージョンの Node.js が選択されていることを確認できます。
Express のインストール
次のコマンドを発行して Express ジェネレーターをインストールします。
PS C:\node\expressapp> npm install express-generator -g次のスクリーンショットは npm コマンドの出力を示しています。 出力は似たものになるはずです。
ディレクトリを WebRole1 ディレクトリに変更し、express コマンドを使用して新しいアプリケーションを生成します。
PS C:\node\expressapp\WebRole1> express続行するには、以前のアプリケーションを上書きするように求められたら、「 y 」または「 はい 」と入力します。 Express によって、app.js ファイルと、アプリケーションを構築するためのフォルダー構造が生成されます。
package.json ファイルに定義された他の依存関係をインストールするには、次のコマンドを入力します。
PS C:\node\expressapp\WebRole1> npm install
次のコマンドを使用して 、bin/www ファイルを server.jsにコピーします。 このステップにより、クラウド サービスがこのアプリケーションのエントリ ポイントを見つけられるようになります。
PS C:\node\expressapp\WebRole1> copy bin/www server.jsこのコマンドが完了すると、WebRole1 ディレクトリに server.js ファイルが作成されます。
server.js を変更して、次の行から '.' 文字のいずれかを削除します。
var app = require('../app');この変更を行うと、行は次のようになります。
var app = require('./app');ファイルを必要なアプリケーション ファイルと同じディレクトリに移動しているため (前は
bin/www)、この変更が必要です。 この変更を行った後、 server.js ファイルを保存します。次のコマンドを使用して、アプリケーションを Microsoft Azure エミュレーターで実行します。
PS C:\node\expressapp\WebRole1> Start-AzureEmulator -launch
ビューの変更
次に、"Welcome to Express in Azure" というメッセージが表示されるようにビューを変更します。
次のコマンドを入力して、index.jade ファイルを開きます。
PS C:\node\expressapp\WebRole1> notepad views/index.jade
Jade は Express アプリケーションで使用される既定のビュー エンジンです。
Azure に追加して、テキストの最後の行を変更します。
ファイルを保存して、メモ帳を終了します。
変更を確認するには、ブラウザーを最新の情報に更新します。
アプリケーションをテストした後、 Stop-AzureEmulator コマンドレットを使用してエミュレーターを停止します。
Azure にアプリケーションをデプロイする
Azure PowerShell ウィンドウで、 Publish-AzureServiceProject コマンドレットを使用して、クラウド サービスにアプリケーションをデプロイします
PS C:\node\expressapp\WebRole1> Publish-AzureServiceProject -ServiceName myexpressapp -Location "East US" -Launch
デプロイ操作が完了すると、ブラウザーが開き、Web ページが表示されます。
次のステップ
詳細については、 Node.js デベロッパー センターを参照してください。