SC(非公式)Advent Calendar 2018 の16日目です。
#はじめに
Azureの話ですが、クラウドを利用する場合、システムの種類や特性を理解した上で、自分たちの管理する領域をなるべくクラウドベンダーに任せる設計にすることがクラウド上のシステム構築のポイントの一つです。
しかしながら、どうしてもサードパーティ製品をインストールしなければならない場面はでてきます。
最近.NetCore+AppServiceばかり構築していて、
IISの設定や、ネットワーク周りでつまづいたので、備忘録として投稿します。
#環境
WindowsServer2016
VisualStudio2017
.NetFramework4.7
.NetFramework WebAPI2.0
#Azure上にVMを構築する
Azureのポータルから新規作成-->
Windows Server 2016 DatatCenter のイメージを選択します。
リソースグループと仮想マシン名を決めます。
基本的にはデフォオルト値でいいですが、
後述の作業のために、RDPのポート(3398)を開けておきます。
VMが作成できたら、リモートデスクトップでログインします。
が、その前に、DNS名を構成します
adv20181216というDNS名にしました。
これを設定しておくか、IPを静的にしておかないと、マシンの再起動のたびにIPが変更されるので、
RDPファイルをDLしないといけません。
ではRDPファイルをDLしてリモートデスクトップします。
#WindowsServerへのIISと.NetFrameworkの設定
Add roles and features をクリック
Nextをクリック
Nextをクリック
Nextをクリック
Web Server(IIS)のチェックボックスをクリック
Add Featuresをクリック
Nextをクリック
ASP.NET 4.6を選択してNextをクリック
Nextをクリック
Mangement Sserviceを選択してNextをクリック
必要に応じてサーバーを再起動(意訳)にチェックを入れて
Installをクリック
インストールが完了したら、Closeをクリック
#WebDeployのインストール
ローカルのVisusalStudioからAzure上のWindowsServerに発行するために、
WindowsServerにWeb Deployをインストールする必要があります。
以下のサイトからダウンロードできます。
https://www.microsoft.com/ja-jp/download/details.aspx?id=43717
※Azure上のWinServerのIEはデフォルトではファイルダウンロードが禁止されていますので、
必要に応じてインターネットオプションの設定を変えてください
WinServerは64bitなので、WebDeploy_amd64_ja-JP.msi をダウンロードしてください
ダウンロードしたmsiファイルを実行します。
セットアップの種類は完全を選択してください
#IIS Manager でのサイトの設定
###バインドポートの変更
Bindingsをクリック
今回は80ポートではなく、8080ポートで接続するので、
バインド先を8080ポートに変更します。
###WebDeployの発行設定
Default Web Site を右クリックしてメニューを表示
Configure Web Deploy Publishingをクリック
デフォルトの設定でSetupをクリック
デプロイユーザーはVMを作成した時のadminユーザーになっています。
セキュリティ的に問題がある場合はユーザーを作成して、デプロイ用のユーザーを設定してください。
#ネットワーク設定
###Windowsファイアウォールのポートの解放
Windowsファイアウォールの受信設定
8172はWebDeployのデフォルトポートです
同じくWebAPI用の8080ポートの受信許可も追加します
###ネットワークインターフェースの設定
Azureのネットワークインターフェースの受信設定で、
Webアプリ用の8080ポートとWebDeploy用の8172ポートを受信許可に追加します。
#WebAPI作成とデプロイ
ここからはVisualStudioでアプリを作成していきます。
.NetFrameworkのWebAPIを作成します。
発行オプションを開きます
保存したら、発行します。
証明書エラーが出ますが承諾を押して、進めます。
発行したら、以下の500InternalServereエラーがでます。
リモートデスクトップ上でlocalhost:8080に対してリクエストしてみると、
以下のエラーがでます。
「HandlerMapping」「Modules」をRead/Writeに設定します
サーバーの役割のWebServer(IIS)の下層のAppricationDevelopmentの以下の項目にチェックを付けて追加します。
再度VisualStudioから発行します。
これで設定は完了です。
#さいごに
今回はMicrosoft.Office.interopを使用しなければならず、DotnetCoreではまだ対応していない(そもそもWindowwsOffice用のライブラリは思想的に違う)ので、.NetFrameworkのWebAPIを用意して、機能的に切り出しました。
マイクロサービスの時代なので、機能ごとに言語や、インフラを選択してk8sなどを使用して管理する方法がDeveloperもOperatorも幸せになれそうです。
WebAPIの技術はどの言語でも勉強していきたいです。