Nginx ドメイン転送の使用シナリオ コード例

Nginx ドメイン転送の使用シナリオ コード例

シナリオ 1: サーバーの制限により、外部に開かれているポートは 1 つだけですが、別の外部ネットワーク環境を要求する必要があるため、トランジット サーバーで nginx を使用してデータを転送します。

成し遂げる:

サーバー{
 聞く 8051;
 server_name ローカルホスト;
 
 場所 /ライセンス/ {
      プロキシパス http://xxx.xxx.xxx.xxx:8058/;
 }
 
 位置 / {
      proxy_pass http://xxx.xxx.xxx.xxx:8051/; } }

特記事項:

注: ここでファイルアップロード転送が関係する場合は、server_name の下に client_max_body_size 100m を追加します。

ドメイン名転送アドレスproxy_passの後に「/」を付ける必要があります。そうしないと、異常な転送が発生します。

nginx で proxy_pass プロキシ転送を設定するときに、proxy_pass の後の URL に / を追加すると、絶対ルート パスを意味します。
/ がない場合は相対パスを意味し、一致するパス部分もプロキシされます。

次の 4 つの状況にそれぞれ http://192.168.1.1/proxy/aerchi.html を使用してアクセスすると仮定します。

最初のもの:

場所 /proxy/ {
プロキシパス http://127.0.0.1/;
}

URL へのプロキシ: http://127.0.0.1/aerchi.html

2 番目のタイプ (最初のタイプと比較して、末尾の / が 1 つ少ない)

場所 /proxy/ {
プロキシパス http://127.0.0.1;
}

URL へのプロキシ: http://127.0.0.1/proxy/aerchi.html

3番目のタイプ:

場所 /proxy/ {
プロキシパス http://127.0.0.1/aaa/;
}

URL へのプロキシ: http://127.0.0.1/aaa/aerchi.html

4 番目のタイプ (3 番目のタイプと比較して、末尾の / が 1 つ少ない)

場所 /proxy/ {
プロキシパス http://127.0.0.1/aaa;
}

URL へのプロキシ: http://127.0.0.1/aaaaerchi.html

シナリオ2: ビジネス上のニーズにより、フロントエンドコードのセットを2つのバックエンドアドレスにマッピングする必要があるため、インターフェース上で区別して転送する必要があり、転送中に識別マークを削除する必要があります。

成し遂げる:

サーバー{
  0.0.0.0:8204 をリッスンします。
  server_name ローカルホスト;
  #静的ページ ディレクトリ ルート E:\xxxxxxx;
  #デフォルトのホームページインデックス /index.html;
  proxy_set_header ホスト $http_host;       
  proxy_set_header X-Real-IP $remote_addr;       
  proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  #プロキシクッキーパス /* /*;
  クライアントの最大ボディサイズは100mです。
    
  location ~*/wx/(.*) {#インターフェースに/wx/#が含まれているかどうかに基づいて動的ページを区別し、処理のためにTomcatに渡します。if (!-e $request_filename) {
        proxy_pass http://127.0.0.1:8091/$1;#バックエンドに行くときは、/wxを削除する必要があります}
  }
  位置 / {
    # ユーザーブラウザのキャッシュ設定の場所 ~* \.(css|js|jpg|jpeg|gif|png|swf|htm|html|json|xml|svg|woff|ttf|eot|map|ico)$ {
      有効期限 -1;
      if (-f $リクエストファイル名) {
        壊す;
      }
    }
    # 動的ページ。処理のためにTomcatに渡されます。if (!-e $request_filename) {
      プロキシパス http://127.0.0.1:8092;
    #プロキシクッキーパス /* /*;
    }
  }

  エラーページ 500 502 503 504 /50x.html;
  場所 = /50x.html {
    ルートhtml;
  }
}

特記事項:

1. proxy_set_header ホスト $http_host;

リクエスト ヘッダーは変更されません。

2. proxy_set_header ホスト ホスト。クライアント要求ヘッダーにこのヘッダーが含まれていない場合、バックエンド サーバーに渡される要求にはこのヘッダーが含まれません。この場合、ホストが使用されます。クライアント要求ヘッダーにこのヘッダーが含まれていない場合、バックエンド サーバーに渡される要求にもこのヘッダーは含まれません。 この場合、ホストが使用されます。クライアント要求ヘッダーにこのヘッダーが含まれていない場合、バックエンド サーバーに渡される要求にもこのヘッダーは含まれません。この場合、ホスト変数が使用されます。その値は、リクエストに「Host」リクエスト ヘッダーが含まれている場合は「Host」フィールドの値であり、リクエストに「Host」リクエスト ヘッダーが含まれていない場合は仮想ホストのプライマリ ドメイン名です。

3. proxy_set_header ホスト ホスト: host:host:proxy_port;

サーバー名は、バックエンド サーバーのポートとともに渡すことができます。

4. リクエスト ヘッダーの値が空の場合、リクエスト ヘッダーはバックエンド サーバーに送信されません。

proxy_set_header Accept-Encoding "";

5. ユーザーの実際のIPアドレスがバックエンドサーバーに転送されます。

proxy_set_header ホスト $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Real-IP $remote_addr;

シナリオ3: 前のコードはVueで実装されています。Vueは特定のページを持たず、/xx/xxを通じてリソースにアクセスします。このとき、バックグラウンドインターフェースと区別する必要があります。

成し遂げる:

これらは「#」などの特殊文字で区別できます。# を含むリクエストは、デフォルトでは静的リソースです。

場所 ~* \.(#|css|js|jpg|jpeg|gif|png|swf|htm|html|json|xml|svg|woff|ttf|eot|map|ico)$ {
  有効期限 -1;
  if (-f $リクエストファイル名) {
    壊す;
  }
}

シナリオ4: サーバーの制限により、データベースアクセスにはnginx転送が必要

成し遂げる:

ストリーム {
  アップストリームクラウドソケット
    ハッシュ $remote_addr は一貫しています。
    サーバー データベースの実際の IP:3306 weight=5 max_fails=3 fail_timeout=30 秒;
  }
 
 サーバー{
    listen 127.0.0.1:8058; #ローカルプロキシポート proxy_connect_timeout 10s;
    proxy_timeout 300s;#クライアントとプロキシサービス間のタイムアウトを設定します。5分以内に操作がない場合、自動的に切断されます。
    proxy_pass クラウドソケット;
  }

}

特別な注意:

ストリームはhttpと同じレベルなので、httpに入れないでください。

シナリオ5: ドメイン名にアクセスするときに、別のアドレスにリダイレクトする必要がある

成し遂げる:

サーバー{
  7000を聴く;
  server_name ローカルホスト;
  クライアントの最大ボディサイズは100mです。

  場所 = / {
    ^(.*) https://www.baidu.com を永久に書き換えます。
  }
}

特別な注意:

最後にこのルールが一致したら、新しい場所URIルールの一致を続行します
break このルールは一致後に終了し、それ以上のルールは一致しません
リダイレクトは302一時リダイレクトを返します
permanentは301パーマネントリダイレクトを返します

以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。

以下もご興味があるかもしれません:
  • ドメイン名を指定されたポートに転送するようにNginxを設定する方法
  • Nginxドメイン名転送の実装
  • nginx フォワード プロキシを使用してイントラネット ドメイン名転送プロセス分析を実装する
  • Nginxリバースプロキシはイントラネットドメイン名転送に使用されます
  • 複数のドメイン名に対する Nginx リバース プロキシを使用した HTTP および HTTPS サービスの実装
  • nginx + セカンダリドメイン名 + https サポートを使用する
  • Nginxはドメイン名のアクセス方法を定義しています
  • ドメイン名を介してプロジェクトにアクセスするnginx + tomcatの例

<<:  Web面接におけるJS事前解析と変数プロモーションの違い

>>:  ノードをMySQLデータベースに接続する際に発生する問題と解決策

推薦する

Vue フロントエンド開発における階層的にネストされたコンポーネント間の通信の詳細な説明

目次序文例まとめ序文Vue の親子コンポーネントは、props を通じて親コンポーネントの値を子コン...

vue+antv でレーダーチャートを実装するためのサンプルコード

1. 依存関係をダウンロードするnpm インストール @antv/データセットnpm インストール ...

Nginx リバース プロキシを使用して go-fastdfs を実行する例

背景go-fastdfs は、http プロトコルをサポートする分散ファイルシステムです。一般的なプ...

Docker を使ってゼロから SOLO 個人ブログを構築する方法

目次1. 環境整備2. Dockerをインストールする3. MySQLマスタースレーブデータベースを...

Vueでフォーム検証を実装する方法

1. インストールと使用まず、Vue プロジェクトにインストールします。 npm インストール --...

MySQL DEFINER の使用方法の詳細な説明

目次序文: 1.DEFINERの簡単な紹介2. いくつかの注意点要約:序文: MySQL データベー...

水平スクロールバーを実装する2つの方法の例

序文:プロジェクトの開発中に、1 行にナビゲーション バーが多すぎる場合に水平スクロール バーを実装...

HTMLテーブルレイアウトの実践的な使い方の詳しい説明

テーブルはいつ使用されますか?最近では、Web ページの全体的なレイアウトにテーブルが使用されること...

Web 上の要素を非表示にする方法とその利点と欠点

ソースコードの例: https://codepen.io/shadeed/pen/03caf6b36...

Windows Server 2016 で Flash を有効にする方法

最近、VMware Horizo​​n を導入してテストしましたが、そのコンソールにはデフォルトで ...

Vue での this.$set の使用に関する詳細な説明

目次Vue での this.$set の使用使用なぜレスポンシブなのか?分析する要約するVue での...

主軸上のFlex子要素の比率を制御する方法

背景フレックス レイアウトにより、配置とスペースの割り当てがより効果的に実現されます。最近、flex...

gorm で MySql データベースを操作する方法

1. テーブル内のフィールドの大文字と小文字の区別を設定するgorm クエリを使用する場合、MySQ...

docker 環境でのデータベース バックアップ (postgresql、mysql) のサンプル コード

目次posgresql バックアップ/リストアMySQL バックアップ/復元posgresql バッ...