Nginx + IIS + Web フロントエンド (Spring MVC) - 負荷分散 (1)
はじめに
大規模な Web プロジェクトを開発する場合、Web がサーバー上の IIS 上で公開されている場合、IIS サービスに対して大量のリクエストが行われると、コンピューターは簡単にクラッシュします。そこで私たちは、サービスを複数のコンピューターに配置してはどうだろうかと考えました。このようにして、前のリクエストが 192.168.**.252:8070 に送信されると、次のリクエストを 192.168.**.253:8071 に送信できるため、サーバーへの負荷を軽減できます。
ここで問題が発生しました。ユーザーが発行したリクエストを異なるサーバーに送信するにはどうすればよいでしょうか?このとき、Nginxが必要になります。
ここで、Nginx で公開されている .net Web サービスを紹介します。
Nginx は解凍されたパッケージです。Nginx サーバー上で解凍し、設定ファイルを変更するだけで、Nginx がインストールされます。
Nginxのインストールと構成
NginxはCドライブのルートディレクトリに抽出されます:
Nginxの下にファイルディレクトリが表示されます。ここでconfを変更する必要がありますフォルダー内の nginx.conf ファイル:
大まかな説明:
ファイルは次のようになります:
<span style="font-size:18px;">#user nobody; worker_processes 1;#工作进程的个数,可以配置多个 #error_log logs/error.log; #error_log logs/error.log notice; #error_log logs/error.log info; #pid logs/nginx.pid; events { worker_connections 1024;#单个进程最大连接数(最大连接数=连接数*进程数) } #设定http服务器,利用它的反向代理功能提供负载均衡支持 http { include mime.types; #文件扩展名与文件类型映射表 default_type application/octet-stream;#默认文件类型 #log_format main '$remote_addr - $remote_user [$time_local] "$request" ' # '$status $body_bytes_sent "$http_referer" ' # '"$http_user_agent" "$http_x_forwarded_for"'; #access_log logs/access.log main; sendfile on;#开启高效文件传输模式,sendfile指令指定nginx是否调用sendfile函数来输出文件,对于普通应用设为 on,如果用来进行下载等应用磁盘IO重负载应用,可设置为off,以平衡磁盘与网络I/O处理速度,降低系统的负载。注意:如果图片显示不正常把这个改成off。 #tcp_nopush on; #keepalive_timeout 0; keepalive_timeout 65; #长连接超时时间,单位是秒 gzip on;#启用Gizp压缩 #服务器的集群 upstream netitcast.com { #服务器集群名字 server 127.0.0.1:8030 weight=1; #服务器配置 weight是权重的意思,权重越大,分配的概率越大。 server 127.0.0.1:8040 weight=1; } #当前的Nginx的配置 server { listen 8090;#监听80端口,可以改成其他端口 server_name localhost;############## 当前服务的域名 #charset koi8-r; #access_log logs/host.access.log main; #location / { # root html; # index index.html index.htm; #} location / { proxy_pass http://netitcast.com; proxy_redirect default; } #location ~ \.(jpg|png|jpeg|bmp|gif|swf|css)$ #{ # expires 30d; # root /nginx-1.4.7;#root: # break; #} #error_page 404 /404.html; # redirect server error pages to the static page /50x.html # error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } # proxy the PHP scripts to Apache listening on 127.0.0.1:80 # #location ~ \.php$ { # proxy_pass http://127.0.0.1; #} # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000 # #location ~ \.php$ { # root html; # fastcgi_pass 127.0.0.1:9000; # fastcgi_index index.php; # fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name; # include fastcgi_params; #} # deny access to .htaccess files, if Apache's document root # concurs with nginx's one # #location ~ /\.ht { # deny all; #} } # another virtual host using mix of IP-, name-, and port-based configuration # #server { # listen 8000; # listen somename:8080; # server_name somename alias another.alias; # location / { # root html; # index index.html index.htm; # } #} # HTTPS server # #server { # listen 443; # server_name localhost; # ssl on; # ssl_certificate cert.pem; # ssl_certificate_key cert.key; # ssl_session_timeout 5m; # ssl_protocols SSLv2 SSLv3 TLSv1; # ssl_ciphers HIGH:!aNULL:!MD5; # ssl_prefer_server_ciphers on; # location / { # root html; # index index.html index.htm; # } #} } </span>
変更が必要な点:
<span style="font-size:18px;"> #服务器的集群 upstream netitcast.com { #服务器集群名字 server 127.0.0.1:8030 weight=1; #服务器配置 weight是权重的意思,权重越大,分配的概率越大。 server 127.0.0.1:8040 weight=1; } #当前的Nginx的配置 server { listen 8090;#监听80端口,可以改成其他端口 server_name localhost;############## 当前服务的域名 #charset koi8-r; #access_log logs/host.access.log main; #location / { # root html; # index index.html index.htm; #} location / { proxy_pass http://netitcast.com; proxy_redirect default; } </span>
サーバーがクラスター名:
server ip: port
サーバーの IP とポートでプロジェクトを公開します。ここに IP とポート番号を書くことができます。次の重みは重みです。つまり、両方のサーバーが 1 の場合、リクエストは 1:1 で、最初のリクエストはポート 8030 でアクセスされ、2 番目のリクエストはポート 8040 でアクセスされます。
server{ listen 8090} は nginx のリスニング ポート番号です。つまり、サーバー クラスター内のサービスにアクセスするには、Nginx サーバーの IP とポート番号にアクセスするだけです。
Nginx の原理:
次のブログでは、Web サービスを IIS に公開します。
参考ブログ:http://blog.csdn.net/zhanghan18333611647/article/details/50282951
以上、Nginx + IIS + Web フロントエンド (Spring MVC) - 負荷分散 (1) の内容を紹介しましたが、PHP チュートリアルに興味のある友人の参考になれば幸いです。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











Web開発におけるHTML、CSS、およびJavaScriptの役割は次のとおりです。1。HTMLは、Webページ構造を定義し、2。CSSはWebページスタイルを制御し、3。JavaScriptは動的な動作を追加します。一緒に、彼らは最新のウェブサイトのフレームワーク、美学、および相互作用を構築します。

Windowsでnginxを構成する方法は? nginxをインストールし、仮想ホスト構成を作成します。メイン構成ファイルを変更し、仮想ホスト構成を含めます。 nginxを起動またはリロードします。構成をテストし、Webサイトを表示します。 SSLを選択的に有効にし、SSL証明書を構成します。ファイアウォールを選択的に設定して、ポート80および443のトラフィックを許可します。

HTMLの将来は、無限の可能性に満ちています。 1)新機能と標準には、より多くのセマンティックタグとWebComponentsの人気が含まれます。 2)Webデザインのトレンドは、レスポンシブでアクセス可能なデザインに向けて発展し続けます。 3)パフォーマンスの最適化により、応答性の高い画像読み込みと怠zyなロードテクノロジーを通じてユーザーエクスペリエンスが向上します。

すべてのコンテナ(Docker PS)をリストする手順に従って、Dockerコンテナ名を照会できます。コンテナリストをフィルタリングします(GREPコマンドを使用)。コンテナ名(「名前」列にあります)を取得します。

nginxが開始されるかどうかを確認する方法:1。コマンドラインを使用します:SystemCTLステータスnginx(Linux/unix)、netstat -ano | FindStr 80(Windows); 2。ポート80が開いているかどうかを確認します。 3.システムログのnginx起動メッセージを確認します。 4. Nagios、Zabbix、Icingaなどのサードパーティツールを使用します。

Docker Containerの起動手順:コンテナ画像を引く:「Docker Pull [Mirror Name]」を実行します。コンテナの作成:「docker create [options] [mirror name] [コマンドとパラメーター]」を使用します。コンテナを起動します:「docker start [container name or id]」を実行します。コンテナのステータスを確認してください:コンテナが「Docker PS」で実行されていることを確認します。

Dockerでコンテナを作成します。1。画像を引く:Docker Pull [ミラー名]2。コンテナを作成:Docker Run [Options] [Mirror Name] [コマンド]3。コンテナを起動:Docker Start [Container Name]

nginxバージョンを照会できるメソッドは次のとおりです。nginx-vコマンドを使用します。 nginx.confファイルでバージョンディレクティブを表示します。 nginxエラーページを開き、ページタイトルを表示します。
