HTTP/HTTPSの通信処理実装中のデバッグにはDockerが便利

iOSアプリやAndroidアプリなどのネイティブアプリの開発で、HTTP/HTTPSでWebサーバーと通信する処理を実装するとき、固定のデータが戻ってきて欲しいということは多々あります。

UnitテストとかならHTTPのモックを用意するのが良いですが、実装作業中は実際にHTTP/HTTPSで通信できさえすれば良いという場合が多いのではないでしょうか。

そのようなときに、便利なのがDockerです。DockerでNginxをコンテナ化して動かし、それと通信しながら実装すれば良いのです。

スポンサーリンク

実行方法

本当はnginxのオプションを設定したりするなど、他にもやった方が良いことはあります。しかし、アプリの実装でちょっと通信したいくらいのライトな使い方なら、以下の様な最低限の手順でも大丈夫だったりします。

やってみて、必要になったら、nginxの設定ファイルを追加するなどしましょう。

Dockerイメージの用意

次のようなDockerfileを作成します。

FROM nginx:1.17

Composerの定義

次のようなdocker-compose.ymlを作成します。

version: "3"
services:
   nginx:
     build: .
     ports:
       - 8080:80
     volumes:
       - ./content_home:/usr/share/nginx/html

Webサーバーに配置するファイルの作成

docker-compose.ymlやDockerfileと同じフォルダに、content_homeフォルダを作ります。content_homeフォルダがWebサーバーのルートディレクトリになるので、Webサーバーに配置したいファイルをcontent_homeフォルダに置きます。

サーバー起動

docker-compose.ymlファイルを置いたディレクトリで、次のコマンドを実行します。

$ docker-compose up -d

サーバーへの接続

次のURLで起動したサーバーにアクセスできます。

http://localhost:8080/

サーバーの停止

次のコマンドを実行します。

docker-compose stop

まとめ

Dockerを使うとParallels DesktopやVMWare、Virtual Boxで仮想PCを用意するよりも格段に手軽にテストサーバーを用意できます。

また、定義ファイルや配置するフォルダごとGitで管理できる点も非常に便利です。

POSTで接続するとHTTP STATUS 405 になってしまい、エラーになります。対応方法を書いた記事を公開しました。

関連記事

Webサーバーと通信アプリを作っているとき、デバッグ中は本当のサーバーに接続するよりも、ローカルマシン内にDockerで作ったテストサーバーと通信した方が便利です。次の記事で作り方を紹介しました。 [sitecard subtitle[…]

スポンサーリンク
最新情報をチェックしよう!
>現役のプログラマーが書くプログラミング情報

現役のプログラマーが書くプログラミング情報

日々の開発の中での学びや分かったこと、調べたことなどを書いていくブログです。

CTR IMG