単純なポーリング アルゴリズム
このアルゴリズムは比較的単純です。たとえば、3 つのサーバーがあるとします。
最初のサーバー | 192.168.1.1 |
2 番目のサーバー | 192.168.1.2 |
3 番目のサーバーサーバー | 192.168.1.3 |
最初のリクエストが到着すると、デフォルトで最初のサーバーにアクセスし、2 番目のリクエストは 2 番目のサーバーにアクセスし、3 番目のサーバーにアクセスします。は 3 番目のステーションにアクセスし、4 番目のリクエストは最初のステーションにアクセスする、というようになります。以下は私のコードで実装された簡単なアルゴリズムです:
public class simplepolling { /** * key是ip */ public static list <string> ipservice = new linkedlist <>(); static { ipservice.add("192.168.1.1"); ipservice.add("192.168.1.2"); ipservice.add("192.168.1.3"); } public static int pos = 0; public static string getip(){ if(pos >= ipservice.size()){ //防止索引越界 pos = 0; } string ip = ipservice.get(pos); pos ++; return ip; } public static void main(string[] args) { for (int i = 0; i < 4; i++) { system.out.println(getip()); } } }
4 回のシミュレート実行の結果は
サーバーのパフォーマンスがある場合現時点での比較は OK (192.168.1.1 など)、このサーバーでより多くのリクエストを処理できるようにしたいです。このとき、重み確率が関係します。このアルゴリズムは実装できません。後で説明するポーリング アップグレード アルゴリズムを参照してください。
加重ポーリング アルゴリズム
現時点では、目の前にある 3 台のサーバーの重みを設定する必要があります。たとえば、最初のサーバーは 5 に設定します。 、2 番目の設定は 1 に設定され、最初の設定は 1 に設定されます。 3 つの設定 1
最初のサーバー | 192.168.1.1 | 5 |
2 番目のサーバー | 192.168.1.2 | 1 |
192.168.1.3 | 1 |
public class weightpolling { /** * key是ip,value是权重 */ public static map<string, integer> ipservice = new linkedhashmap<>(); static { ipservice.put("192.168.1.1", 5); ipservice.put("192.168.1.2", 1); ipservice.put("192.168.1.3", 1); } public static int requestid = 0; public static int getandincrement() { return requestid++; } public static string getip(){ //获取总的权重 int totalweight =0; for (integer value : ipservice.values()) { totalweight+= value; } //获取当前轮询的值 int andincrement = getandincrement(); int pos = andincrement% totalweight; for (string ip : ipservice.keyset()) { if(pos < ipservice.get(ip)){ return ip; } pos -= ipservice.get(ip); } return null; } public static void main(string[] args) { for (int i = 0; i < 7; i++) { system.out.println(getip()); } } }現時点での実行結果は
Smooth Weighted Polling Algorithm
このアルゴリズムはより複雑になる可能性があり、最初に使用したときは少し混乱しました。見たのですが、よく分かりませんでした。後で関連する情報を読んで、自分の理解と組み合わせて、画像とテキストで説明しました。ここで例として挙げたサーバー構成と重みは、上記と同じです。現在の体重 = 自重 選択後の現在の体重 | 総重量 | 現在の最大体重 | 返された ip | 選択後の現在の重量 = 現在の最大重量 - 総重量 | |
---|---|---|---|---|---|
{5, 1,1} | 7 | 5 | 192.168.1.1 | {-2,1,1} | |
{3,2 ,2} | 7 | 3 | 192.168.1.1 | {-4,2 ,2} | |
{1,3,3} | 7 | 3 | 192.168 .1.2 | {1,-4 ,3} | |
{6,-3,4} | 7 | 6 | 192.168.1.1 | {-1,-3,4} | |
{4,-2,5} | 7 | 5 | 192.168.1.3 | {4,-2,-2} | |
{9,-1,-1} | 7 | 9 | 192.168.1.1 | {2,-1,-1} | |
{7,0,0} | 7 | 7 | 192.168.1.1 | {0,0,0} |
前の図の意味をよく理解していない人もいるかもしれません。ここで簡単に説明します:
1. まず第一に、総重量は変わりません。デフォルトは現在のものです。重みを設定します。
2 の合計です。最初のリクエストが受信されると、デフォルトで現在の重みの選択値を {0,0,0} に初期化します。そのため、現在の重みの値は {5 0,1 になります。 0,1 0} ,5,1,1 は、目の前の各サーバーによって設定された重みです。
3. ここで、最初のリクエストの最大重みは 5 であると結論付けることができます。次に、最初のサーバー ip
4 に戻ります。選択後に現在の重みを設定します。これは、現在の最大重みから合計重み (5-7) を引いたものです。選択されていない重みの重みは変更されません。今回は現在の重みを取得します。重みの値 {5-7,1,1}
5 を選択します。2 番目のリクエストが来た場合は、上記の手順 2、3、4 を続けます。
まだある場合 理解できない場合は、Java コードを使用して実装したアルゴリズムを以下に示します:
public class polling { /** * key是ip,value是权重 */ public static map <string,integer> ipservice = new linkedhashmap <>(); static { ipservice.put("192.168.1.1",5); ipservice.put("192.168.1.2",1); ipservice.put("192.168.1.3",1); } private static map<string,weight> weightmap = new linkedhashmap <>(); public static string getip(){ //计算总的权重 int totalweight = 0; for (integer value : ipservice.values()) { totalweight+=value; } //首先判断weightmap是否为空 if(weightmap.isempty()){ ipservice.foreach((ip,weight)->{ weight weights = new weight(ip, weight,0); weightmap.put(ip,weights); }); } //给map中得对象设置当前权重 weightmap.foreach((ip,weight)->{ weight.setcurrentweight(weight.getweight() + weight.getcurrentweight()); }); //判断最大权重是否大于当前权重,如果为空或者小于当前权重,则把当前权重赋值给最大权重 weight maxweight = null; for (weight weight : weightmap.values()) { if(maxweight ==null || weight.getcurrentweight() > maxweight.getcurrentweight()){ maxweight = weight; } } //最后把当前最大权重减去总的权重 maxweight.setcurrentweight(maxweight.getcurrentweight() - totalweight); //返回 return maxweight.getip(); } public static void main(string[] args) { //模拟轮询7次取ip for (int i = 0; i < 7; i++) { system.out.println(getip()); } } } class weight{ /** * ip */ private string ip; /** * 设置得权重 */ private int weight; /** * 当前权重 */ private int currentweight; public weight(string ip, int weight,int currentweight) { this.ip = ip; this.weight = weight; this.currentweight = currentweight; } public string getip() { return ip; } public void setip(string ip) { this.ip = ip; } public int getweight() { return weight; } public void setweight(int weight) { this.weight = weight; } public int getcurrentweight() { return currentweight; } public void setcurrentweight(int currentweight) { this.currentweight = currentweight; } }
コードの実行結果は次のとおりです:
#ここでの実行結果は、表で説明されているものと一致していることがわかります。
以上がNginx がポーリング アルゴリズムを実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

Nginxは、高い並行リクエストの処理に適していますが、Apacheは複雑な構成と機能的拡張が必要なシナリオに適しています。 1.Nginxは、イベント駆動型の非ブロッキングアーキテクチャを採用しており、高電流環境に適しています。 2。Apacheはプロセスまたはスレッドモデルを採用して、複雑な構成のニーズに適したリッチモジュールエコシステムを提供します。

Nginxは、Webサイトのパフォーマンス、セキュリティ、およびスケーラビリティを改善するために使用できます。 1)逆プロキシおよびロードバランサーとして、Nginxはバックエンドサービスを最適化し、トラフィックを共有できます。 2)イベント駆動型および非同期アーキテクチャを通じて、nginxは高い並行接続を効率的に処理します。 3)構成ファイルでは、静的ファイルサービスやロードバランシングなどのルールの柔軟な定義を可能にします。 4)最適化の提案には、GZIP圧縮の有効化、キャッシュの使用、およびワーカープロセスの調整が含まれます。

Nginxunitは複数のプログラミング言語をサポートし、モジュラー設計を通じて実装されています。 1。言語モジュールの読み込み:構成ファイルに従って対応するモジュールをロードします。 2。アプリケーションの起動:呼び出し言語が実行されたときにアプリケーションコードを実行します。 3。リクエスト処理:リクエストをアプリケーションインスタンスに転送します。 4。応答返品:処理された応答をクライアントに返します。

NginxとApacheには独自の利点と短所があり、さまざまなシナリオに適しています。 1.Nginxは、高い並行性と低リソース消費シナリオに適しています。 2。Apacheは、複雑な構成とリッチモジュールが必要なシナリオに適しています。コア機能、パフォーマンスの違い、ベストプラクティスを比較することで、ニーズに最適なサーバーソフトウェアを選択するのに役立ちます。

質問:nginxを開始する方法は?回答:nginxスタートアップnginx検証nginxはnginxを開始しました他のスタートアップオプションを自動的に開始

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

NGINXサービスをシャットダウンするには、次の手順に従ってください。インストールタイプを決定します:Red Hat/Centos(SystemCtl Status Nginx)またはDebian/Ubuntu(Service Nginx Status)サービスを停止します:Red Hat/Centos(SystemCtl Stop Nginx)またはDebian/Ubuntu(Service Nginx Stop)無効自動起動(オプション):Debuntos/Centos/Centos/Centos/Centos/Centos (syst

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


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン

EditPlus 中国語クラック版
サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境
