0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

Apache OpenWhisk(Standalone)をブラウザから実行してみる

Posted at

目的

以前の記事でCentOS Stream 9条にStandaloneで起動させたApache OpenWhiskを別の端末からブラウザを用いアクセスし、Web UI上で簡単なサービスを実行できるように環境を用意する。

稼働環境

OpenWhiskが起動しているOSのIP、コンテナのIPは以下の通り。コンテナ起動時にOSのIPへバインドしても良かったのですが、どのファイルでdocker runを実行しているのかすぐに把握できなかったためStandaloneを起動した状態でリモート提供する形を模索しました。

$ ip addr show ens33 | grep "inet "
    inet 192.168.11.55/24 brd 192.168.11.255 scope global dynamic noprefixroute ens33
$ docker ps -a
CONTAINER ID   IMAGE                                 COMMAND                   CREATED         STATUS         PORTS      NAMES
b4ba49dd1a27   openwhisk/action-nodejs-v20:nightly   "docker-entrypoint.s…"   7 minutes ago   Up 7 minutes   8080/tcp   wsk0_9_prewarm_nodejs20
$ docker inspect b4ba49dd1a27 | grep OW_API_HOST
                "__OW_API_HOST=http://172.17.0.1:3233",

プロキシの導入と設定

外部から直接アクセスできないサービスを外部に提供する方法として、リバースプロキシで実装していきます。実装にはnginxを導入し、定義を以下のように追加し起動します。

$ sudo dnf install -y nginx
$ sudo vi /etc/nginx/nginx.conf
〜省略〜
    server {
        listen       13232;
        server_name  _;
        root         /usr/share/nginx/html;

        location / {
            proxy_pass http://172.17.0.1:3232;
        }
    }

    server {
        listen       13233;
        server_name  _;
        root         /usr/share/nginx/html;

        location / {
            proxy_pass http://172.17.0.1:3233;
        }
    }
〜省略〜
$ sudo firewall-cmd --permanent --add-port=13232-13233/tcp
success
$ sudo firewall-cmd --reload
success
$ sudo systemctl start nginx

準備ができたのでブラウザで試す前にホストOS上で簡単な動作確認を行います。3232ポート(Controller)、3232ポート(Playground)と2つサービスされている様なので確認してきます。

$ curl http://192.168.11.55:13232
The requested resource temporarily resides under <a href="/playground/ui/index.html">this URI</a>.
$ curl http://192.168.11.55:13233|jq
〜省略〜
{
  "api_paths": [
    "/api/v1"
  ],
  "description": "OpenWhisk",
〜省略〜

次に別の端末のブラウザからそれぞれへリクエストしてみます。いずれも何かしらのコンテンツがレスポンスとして返ってきました。うまくプロキシが動作している様です。では次に、いよいよ機能を使っていきます。
3233ポートからのレスポンス
3232ポートからのレスポンス

JavaScriptのRuntimeを用いHello World!を実行

Web UIのコンソールとレスポンスに"Hello World!"を応答するコードを作成し、「Run」ボタンを押下し実行してみます。

初めてのFaaS JavaScriptでHello World!

。。。待てど暮らせどRunningから状況が変わりません。。そして1分後くらいにエラーと思われる表示に変わり失敗の様です。

Running
失敗か?

原因調査

まずはホストOSでリクエストを受信できているかtcpdumpコマンドで確認してみます。tcpdumpコマンドを実行後にRunを実行しましたが何もパケットが飛んできません。ブラウザからのリクエストがうまくいっていのでしょうか。

$ sudo dnf install -y tcpdump
$ sudo tcpdump -i any port 3232 or port 3233
tcpdump: data link type LINUX_SLL2
dropped privs to tcpdump
tcpdump: verbose output suppressed, use -v[v]... for full protocol decode
listening on any, link-type LINUX_SLL2 (Linux cooked v2), snapshot length 262144 bytes

ブラウザの開発者機能を用いリクエスト確認

Chromeの「その他のツール」→「デベロッパーツール」を起動し、再度Runを実行して暫く待つと、どうやら特定のURL http://172.17.0.1:3233 へのアクセスが失敗している様です。このIPはホストOS上で起動したOpenWhiskコンテナのIPアドレスです。どこから呼び出されているか引き続き調査すると、playgroundFunction.jsに固定で定義されていました。

デベロッパーツール

playgroundFunction.js

変数名window.APIHOST=やファイル名playgroundFunctions.jsをキーにgit cloneしてきたからソースを検索してみます。以下の2ファイルで見つかりました。localhost:3233の部分を192.168.11.55:13233に変更すれば良さそうです。srcは以下の方を修正しました。buildは修正してもgradle実行時にsrcのコードで上書きされてしまいます。

$ find . -type f | grep playgroundFunctions.js |  xargs grep window.APIHOST=
./core/standalone/src/main/resources/playground/ui/playgroundFunctions.js:  window.APIHOST='http://localhost:3233'
./core/standalone/build/resources/main/playground/ui/playgroundFunctions.js:  window.APIHOST='http://localhost:3233'

再実行

bootRunを再実行し、ブラウザをリロードしてみます。最初にリクエストした時と異なり、サンプルコードが初期表示されています。修正したリソースをデベロッパーツールで参照すると、修正した内容でコンテンツが反映されていました。このままRunを実行してみると正常に動作していることを確認することができました。console.logの出力がどこにされているかはわかりませんでした。

リロード

修正後リソース

実行

終わりに

この方法が正しいかどうかわかりませんが、動作確認する環境を用意するという当初の目的にはたどり着けた様です。ホストOSを用意せず1つの端末で完結させる方法が一番手っ取り早い方法かと思いますが、私のMacBookではdockerやgradle、java等々色々とエラーが発生したため断念し今回の方法で実現した次第です。

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?