本文章では、Edge 言語(OpenResty Inc. が開発した簡潔かつ強力な小規模言語)を使用して、OpenResty Edge のページルールでカスタム Lua モジュールを呼び出す方法をご紹介します。この方法により、非常に複雑なゲートウェイ操作や計算を容易に実行することが可能になります。

Embeded image

Lua モジュールの作成

OpenResty Edge の管理者用 Web コンソールにアクセスしましょう。これは当社のコンソールのサンプルデプロイメントです。各ユーザーには独自のローカルデプロイメントがあります。

スクリーンショット

まず、Lua モジュールを作成する必要があります。

スクリーンショット

グローバル設定ページに移動します。

スクリーンショット

「グローバル Lua モジュール」を選択します。

スクリーンショット

ここで作成する Lua モジュールは、ページルールから呼び出すことができ、複雑な要求にも可能な限り対応できます。

スクリーンショット

Lua ファイルを直接アップロードすることができます。

スクリーンショット

または、編集ボックスにコードを記述することもできます。

スクリーンショット

ここでは、output-md5.lua という名前の Lua ファイルを作成しました。これは入力パラメータの md5 値を計算できます。

スクリーンショット

Lua モジュールテーブル _M を宣言します。

スクリーンショット

次に、この Lua モジュールに calc という名前の関数を追加します。この関数は入力パラメータの md5 値を計算できます。

スクリーンショット

最後に、末尾でモジュールテーブルを返すことを忘れないでください。

スクリーンショット

編集して保存すると、Lua モジュールは自動的に各ゲートウェイサーバーに配布され、Edgelang コードから参照できるようになります。

スクリーンショット

HTTP アプリケーションにおける Lua モジュールの呼び出し

次に、OpenResty Edge の HTTP アプリケーションで Lua モジュールを呼び出してみましょう。

スクリーンショット

以前のサンプルアプリケーション、test-edge.com を引き続き使用できます。

スクリーンショット

そのアプリケーションに移動します。

スクリーンショット

すでにページルールが定義されています。

スクリーンショット

このページルールは、事前定義されたアップストリームへのリバースプロキシを設定しています。

スクリーンショット

ここで、Lua モジュールを呼び出す新しいページルールを追加しましょう。

スクリーンショット

URI /test-md5 をチェックするルール条件を有効にします。

スクリーンショット

選択可能な変数を確認してみましょう。

スクリーンショット

「URI」を選択します。

スクリーンショット

文字列等価演算子を選択します。

スクリーンショット

スクリーンショット

/test-md5 を入力し、ルートロケーションのみにマッチさせます。

スクリーンショット

次に、新しいアクションを追加します。

スクリーンショット

ここで追加するアクションを検索できます。

スクリーンショット

「EdgeLang を使用」を検索します。

スクリーンショット

それを選択します。

スクリーンショット

Lua モジュールを呼び出すための Edgelang コードを編集ボックスに追加します。URI パラメータ「value」を入力パラメータとして使用していることに注意してください。

スクリーンショット

このルールが既存の通常ルールの前に実行されることを確認します。

スクリーンショット

このルールにマッチした場合、後続のすべてのルールをスキップすることを確認します。

スクリーンショット

このルールには必須ではありませんが、リクエストの処理を即座に停止したい場合は、明示的に指定することをお勧めします。

これでこのルールを作成します。

スクリーンショット

いつものように、先ほどの変更をプッシュするには新しいバージョンをリリースする必要があります。

スクリーンショット

このボタンをクリックします。

スクリーンショット

リリースします!

スクリーンショット

新しいバージョンがすべてのゲートウェイサーバーに同期されました。

スクリーンショット

これで、新しいページルールがすべてのゲートウェイクラスターとサーバーにプッシュされました。

埋め込みビデオ

当社の設定変更には、サーバーのリロード、再起動、またはバイナリアップグレードは必要ありません。そのため、非常に効率的でスケーラブルです。

埋め込み画像

Lua モジュール呼び出しの効果の検証

次に、Lua モジュール呼び出しの効果を検証します。

ターミナル上で、curl コマンドラインツールを使用してこのゲートウェイサーバーに HTTP リクエストを送信します。

スクリーンショット

ここでは、URI パラメータ value=test1 を含むリクエストを送信します。value=test1 という URI パラメータに注目してください。

スクリーンショット

コマンドを実行します。返された md5 値を取得できます。

スクリーンショット

次に、URI パラメータを変更します。value=test2 という URI パラメータに注目してください。

スクリーンショット

実行してみましょう!返された md5 値が変更されていることがわかります。

スクリーンショット

ページルールの先頭で Lua モジュールを呼び出すこともできます。

スクリーンショット

ここに Edgelang コードを追加します。

スクリーンショット

「Edit」ボタンをクリックします。

スクリーンショット

編集ボックスに Edgelang コードを記述します。

スクリーンショット

これは先ほど追加した新しいページルールと同じ効果があります。

OpenResty Edge について

OpenResty Edge は、マイクロサービスと分散トラフィックアーキテクチャ向けに設計された多機能ゲートウェイソフトウェアで、当社が独自に開発しました。トラフィック管理、プライベート CDN 構築、API ゲートウェイ、セキュリティ保護などの機能を統合し、現代のアプリケーションの構築、管理、保護を容易にします。OpenResty Edge は業界をリードする性能と拡張性を持ち、高並発・高負荷シナリオの厳しい要求を満たすことができます。K8s などのコンテナアプリケーショントラフィックのスケジューリングをサポートし、大量のドメイン名を管理できるため、大規模ウェブサイトや複雑なアプリケーションのニーズを容易に満たすことができます。

著者について

章亦春(Zhang Yichun)は、オープンソースの OpenResty® プロジェクトの創始者であり、OpenResty Inc. の CEO および創業者です。

章亦春(GitHub ID: agentzh)は中国江蘇省生まれで、現在は米国ベイエリアに在住しております。彼は中国における初期のオープンソース技術と文化の提唱者およびリーダーの一人であり、Cloudflare、Yahoo!、Alibaba など、国際的に有名なハイテク企業に勤務した経験があります。「エッジコンピューティング」、「動的トレーシング」、「機械プログラミング」 の先駆者であり、22 年以上のプログラミング経験と 16 年以上のオープンソース経験を持っております。世界中で 4000 万以上のドメイン名を持つユーザーを抱えるオープンソースプロジェクトのリーダーとして、彼は OpenResty® オープンソースプロジェクトをベースに、米国シリコンバレーの中心部にハイテク企業 OpenResty Inc. を設立いたしました。同社の主力製品である OpenResty XRay動的トレーシング技術を利用した非侵襲的な障害分析および排除ツール)と OpenResty Edge(マイクロサービスおよび分散トラフィックに最適化された多機能ゲートウェイソフトウェア)は、世界中の多くの上場企業および大企業から高い評価を得ております。OpenResty 以外にも、章亦春は Linux カーネル、Nginx、LuaJITGDBSystemTapLLVM、Perl など、複数のオープンソースプロジェクトに累計 100 万行以上のコードを寄与し、60 以上のオープンソースソフトウェアライブラリを執筆しております。

翻訳

英語版の原文と日本語訳版(本文)をご用意しております。読者の皆様による他の言語への翻訳版も歓迎いたします。全文翻訳で省略がなければ、採用を検討させていただきます。心より感謝申し上げます!