nginx+lua を使用した単一マシンでの何万もの同時接続の実装

nginx+lua を使用した単一マシンでの何万もの同時接続の実装

nginx は弊社で最もよく使用されるサーバーで、コンテンツ配信やリバース プロキシによく使用されます。Lua は C に似たスクリプト言語で、ゲーム業界で広く使用されています。Web ゲームが流行していた 10 年前、伝説的なゲームのソース コードを購入したところ、ゲーム内のサーバーは Lua を使用して実装されていました。私たちは、バックエンドJavaに到達するリクエストの頻度を減らすために、オーバーセリングやアンダーセリング、ランキングなどのシンプルで実用的な機能を実行するために、nginx、envoy、redisとよく使用します。

次に、nginx + lua イメージの構築を開始します。自分で構築する理由は、他の人が提供したイメージにウイルスが含まれていることを恐れているためです。非公式の docker イメージには多くのウイルスが含まれているため、誰もが注意する必要があります。

この記事では、nginx の openresty バージョンを使用します。openresty、nginx、lua の具体的な手順については、Baidu で検索してください。

イメージをビルドする前に、nginx-module-vtsモジュールとopenresty-1.15.8.3の圧縮パッケージを用意する必要があります。この2つの圧縮パッケージは、Baiduで検索すると見つかります。公式アカウントの記事が外部リンクを挿入できるかどうかはわかりません。nginx-module-vtsモジュールの機能は、nginxのアクセスデータをカウントすることです。prometheus+grafanaを使用してnginxを監視する場合は、このモジュールをインストールする必要があります。一緒にコンパイルしましょう。

サーバー上にディレクトリを作成する

cd /usr/local/docker
mkdir -p nginx-lua/ビルド
nginx-lua をインストールします

構築後の完全なディレクトリは次のとおりです。

root@today2:/usr/local/docker/nginx-lua# ツリー
。
├── ビルド
│ ├── Dockerファイル
│ ├── nginx-module-vts.zip
│ └── openresty-1.15.8.3.tar.gz
├── docker-compose.yml
├── ルア
│ ├── test.lua
├── nginx.conf
├──wwwルート
│ ├──index.html

Dockerファイル

Dockerfileファイルをビルドディレクトリに置き、ダウンロードしたnginx-module-vts.zipとopenresty-1.15.8.3.tar.gzもビルドディレクトリに置きます。

ubuntu:xenial より

# データソースを更新 WORKDIR /etc/apt
実行 echo 'deb http://mirrors.aliyun.com/ubuntu/ xenial main limited universe multiverse' >sources.list
実行 echo 'deb http://mirrors.aliyun.com/ubuntu/ xenial-security main limited universe multiverse' >>sources.list
実行 echo 'deb http://mirrors.aliyun.com/ubuntu/ xenial-updates main limited universe multiverse' >>sources.list
実行 echo 'deb http://mirrors.aliyun.com/ubuntu/ xenial-backports main 制限付き宇宙 マルチバース' >>sources.list
apt-get updateを実行する

# 依存関係をインストールします。RUN apt-get install unzip make gcc libpcre3-dev libssl-dev perl build-essential curl zlib1g-dev --assume-yes

# ツールパッケージをコピーします ADD openresty-1.15.8.3.tar.gz /usr/local/src
nginx-module-vts.zip /usr/local/src を追加します。

# nginxモジュールvts
ワークディレクトリ /usr/local/src
nginx-module-vts.zip を解凍して実行します。

ワークディレクトリ /usr/local/src/openresty-1.15.8.3
rm -rf ./Makefile を実行します。
実行 ./configure --add-module=/usr/local/src/nginx-module-vts
make && make install を実行します。

# Nginx を設定し、コメントアウトして、コンテナの起動時にコンテナにマウントします # ADD nginx.conf /usr/local/openresty/nginx/conf/

ワークディレクトリ /
エクスポーズ80
CMD ["/usr/local/openresty/nginx/sbin/nginx", "-c", "/usr/local/openresty/nginx/conf/nginx.conf", "-g", "デーモンをオフ;"]

nginx.conf

ユーザー root;
ワーカープロセスは自動です。

ワーカー_rlimit_nofile 65535;

イベント {
 ワーカー接続 102400;
 epoll を使用します。
}

http {
 server_tokens オフ;
 mime.types を含めます。
 デフォルトタイプ アプリケーション/オクテットストリーム;

 アクセスログ
 access_log オフ;
 エラーログ /var/log/nginx/error.log;

 キープアライブタイムアウト65;
 クライアントの最大ボディサイズは10mです。
 
 gzip オン;
 gzip_disable "msie6";
 gzip_min_length 1000;
 gzip_proxied 期限切れ、キャッシュなし、保存なし、プライベート認証。
 gzip_types text/plain application/xml application/javascript text/css application/x-javascript;

 # 次の 3 行は、nginx-module-vts モジュールをインストールした後に nginx トラフィック統計を設定するためのものです。この記事では主に lua について説明しているため、次の 3 行はコメントアウトできます。vhost_traffic_status_zone;
 vhost_traffic_status_filter_by_host がオン;
 vhost_traffic_status_filter_by_set_key $uri uri::$server_name;

 サーバー{
  聞く 80;
  ルート /usr/share/nginx/html;

  # lua スクリプトのキャッシュを有効にするかどうか。デバッグ段階ではオフに設定します (lua ファイルを変更した後に nginx を再起動する必要はありません)。パフォーマンスを向上させるには、正式な環境でこの行を必ずコメント アウトしてください lua_code_cache off;

  # この場所は、実際に Lua スクリプトを呼び出すための設定です。場所 /lua/test {
   #戻り値の型をjsonに指定します
   デフォルトのタイプは 'application/json' です。
   # /lua/test にアクセスしたときに test.lua がコンテンツを返すように指定します。このパスはコンテナ内のパスであり、ホストと混同してはならないことに注意してください。content_by_lua_file '/usr/local/lua/test.lua';
  }

  # トラフィック統計情報もコメントアウトできます。location /status {
   vhost_traffic_status_display;
   vhost_traffic_status_display_format html;
  }

 }
}

ドッカーの作成

バージョン: '3.1'
サービス:
  nginx:
    build: build # 左側のビルドは現在のコンテナがイメージをビルドする必要があることを意味し、右側のビルドはイメージビルドファイルがビルドディレクトリにあることを意味します restart: always
    コンテナ名: nginx
    network_mode: host # ホストモードを指定する必要はありません。これは利便性のためだけのものです。
      nginx.conf は、/usr/local/openresty/nginx/conf にあります。
      - ./log:/var/log/nginx/
      - ./wwwroot:/usr/share/nginx/html
      - ./lua:/usr/local/lua

テスト.lua

./luaディレクトリにtest.luaファイルを作成します。

ngx.say('{"code": 1, "msg": "hello world!"}')

コンテナを起動した後、IP:80/lua/test にアクセスすると、出力 {"code": 1, "msg": "hello world!"} が表示され、Lua スクリプトが有効になったことがわかります。

この時点で、nginx + lua が構築されました。今後の記事では、JWT 検証、Redis 操作、メッセージ キューなど、思いつく限り多くの機能を実現できる、よく使用される lua スクリプトをいくつか紹介します。

nginx+lua を使用して単一マシンで数万の同時呼び出しを実装する方法についての記事はこれで終わりです。nginx lua 単一マシン同時呼び出しに関する関連コンテンツの詳細については、123WORDPRESS.COM で以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • Nginx+Lua+Redis は高並列 Web アプリケーションを構築します

<<:  アクティビティページでの CSS3 アニメーション効果の適用

>>:  印刷広告を成功させるための「3I」基準

推薦する

CSS3で作成した画像スクロール効果

成果を達成する実装コードhtml <base href="https://s3-us...

コンピュータが予期せずシャットダウンした後、VMware で Linux がインターネットに接続できない問題の解決策

問題の説明: Linux システムのネットワーク カード ファイル /etc/sysconfig/n...

Bツリーの削除プロセスの紹介

前回の記事 https://www.jb51.net/article/154157.htm では、B...

例を通してBRタグとPタグの違いを理解する

<br />改行タグの使用<br>改行タグ<br>は終わりのない...

JavaScript の 50 以上のユーティリティ関数の概要

JavaScript は多くの素晴らしい機能を備えています。この記事では、作業効率の向上とコードのデ...

Vueはツリー構造の追加、削除、変更、チェックのサンプルコードを実装します

実は多くの会社がユーザー権限ツリーに似た機能を持っています。最近、追加、削除、修正のツリー構造を書き...

初心者向けウェブサイト構築チュートリアル: 10 日間でウェブサイトの構築方法を学ぶ

10 日間のチュートリアルでは、最も理解しやすい言語を使用し、最も基本的なことから始めて、誰もが W...

HTMLのmarquee属性でテキストを踊らせる

構文: <marquee> …</marquee>モバイル属性マーキーを使用...

GitHub のサードパーティ認証方式を Vue で実装する例

目次OAuth アプリの作成コードを取得するaccess_tokenを取得するユーザー情報を取得する...

Navicatを使用してクラウドサーバーデータベースにリモート接続する方法

秘密鍵を開かずにリモート サーバーのデータベースに接続するのは非常に便利です。新しい接続でデータを入...

MySQL は低速クエリを可能にします (EXPLAIN SQL ステートメントの使用の概要)

今日、データベース操作はますますアプリケーション全体のパフォーマンスのボトルネックになりつつあり、こ...

Vue の一般的な問題と解決策の概要 (推奨)

Vue に限定されず、他の種類の SPA プロジェクトにも当てはまる問題がいくつかあります。 1....

Axios はリクエストをキャンセルし、重複リクエストを回避します

目次起源現状リクエストをキャンセル cancelTokenリクエスト方法の変更重複したリクエストを避...

ウェブページの画像を素早く表示する方法とテクニック

1. .jpg ではなく .gif を使用します。GIF は JPG に比べてサイズが小さくなります...

js 正規表現の先読みと後読み、および非キャプチャグループ化

目次先読みと後読みをキャプチャグループと組み合わせる捕獲グループと非捕獲グループ前を向いて、後ろを振...