JP2004536406A - セッション複製及びフェイルオーバーのための方法及び装置 - Google Patents

セッション複製及びフェイルオーバーのための方法及び装置 Download PDF

Info

Publication number
JP2004536406A
JP2004536406A JP2003514431A JP2003514431A JP2004536406A JP 2004536406 A JP2004536406 A JP 2004536406A JP 2003514431 A JP2003514431 A JP 2003514431A JP 2003514431 A JP2003514431 A JP 2003514431A JP 2004536406 A JP2004536406 A JP 2004536406A
Authority
JP
Japan
Prior art keywords
server
session
request
client
primary
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
JP2003514431A
Other languages
English (en)
Other versions
JP4295089B2 (ja
JP2004536406A5 (ja
Inventor
エリック エム ハルパーン
プラサド ペダダ
アダム ミッシンガー
ディーン バーナード ジェイコブス
サム プラーラ
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
BEA Systems Inc
Original Assignee
BEA Systems Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Priority claimed from US10/000,708 external-priority patent/US7409420B2/en
Priority claimed from US10/000,709 external-priority patent/US7702791B2/en
Application filed by BEA Systems Inc filed Critical BEA Systems Inc
Publication of JP2004536406A publication Critical patent/JP2004536406A/ja
Publication of JP2004536406A5 publication Critical patent/JP2004536406A5/ja
Application granted granted Critical
Publication of JP4295089B2 publication Critical patent/JP4295089B2/ja
Anticipated expiration legal-status Critical
Expired - Lifetime legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1001Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
    • H04L67/1027Persistence of sessions during load balancing
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1001Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1001Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
    • H04L67/1034Reaction to server failures by a load balancer
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/14Session management
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/14Session management
    • H04L67/142Managing session states for stateless protocols; Signalling session states; State transitions; Keeping-state mechanisms
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/40Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass for recovering from a failure of a protocol instance or entity, e.g. service redundancy protocols, protocol state redundancy or protocol service redirection
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1001Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
    • H04L67/1004Server selection for load balancing
    • H04L67/1008Server selection for load balancing based on parameters of servers, e.g. available memory or workload

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Computer Security & Cryptography (AREA)
  • Computer And Data Communications (AREA)
  • Information Transfer Between Computers (AREA)
  • Multi Processors (AREA)

Abstract

本発明によるシステムは、ウェブブラウザーのようなネットワーククライアントからの要求に応じるために、一次サーバーを利用することができる。この一次サーバーは、一団のサーバー又はサーバー群から選ばれることができる。一次サーバーが選択されると、その一次サーバー上でクライアント要求に応じることができる。次に二次セッションサーバーが、例えば一次サーバーによって、選択されることができる。一次サーバーが要求に応答すると、そのセッションに関する情報が、一次サーバーから二次セッションサーバーへ送られる。
また、システムは、ハードウェア又はソフトウェアの何れかを使って、負荷平衡化を利用することができる。一次サーバー上で要求に応じようとする試みがなされ、もし、一次サーバーが要求を受け取る、又は要求に応答することができない場合には、その要求は二次アプリケーションサーバー上で応じられることができる。もし、二次サーバーが要求を受け取るならば、その二次サーバーが新たな一次サーバーとなる。冗長性を維持するため、新たな二次サーバーが選択され、かつ、その新しい一次サーバーからセッション情報を送られることができる。

Description

【技術分野】
【0001】
本出願は、一般的に、データ複製、特にクライアントネットワークセッションへの冗長性の提供に関するものである。
【0002】
(優先権の主張)
本出願は、引用により本出願中に組み入れられる2001年7月16日に出願された「サーブレットセッション複製及びフェイルオーバーのための方法及び装置」という名称の米国仮特許出願60/305,992号、2001年10月31日に出願された「セッション複製及びフェイルオーバーのための方法及び装置」という名称の米国特許出願10/000,708号、2001年7月16日に出願された「サーブレットセッション複製のためのハードウェアの負荷を均衡化する装置」という名称の米国仮特許出願60/305,969号、2001年10月31日に出願された「セッション複製のためのハードウェアの負荷を均衡化する装置」という名称の米国特許出願10/000,709号、に基づく優先権を主張するものである。
【0003】
(著作権表示)
本特許文書の開示の一部には、著作権保護を条件とする題材が含まれている。本特許文書又は特許開示が、特許局及び商標局の特許書類又は記録に掲載される限りでは、何人によるその複製に対しても著作権者に異議はないが、しかしそうでないならば、一切の無断転載を禁ずる。
【背景技術】
【0004】
クライアントがネットワーク上でサーバーに接続し、かつセッションを開始する時、サーバー上に格納される、そのクライアントセッションに特有な情報が存在し得る。例えば、クライアントのユーザーが仮想買い物かごに品物を入れるとする。それら品物の選択物は、少なくとも一時的にサーバー上に格納されることができる。この例では、他のユーザー又はサーバーはこの情報にアクセスする必要はない。しかしながら、もしセッションデータを格納するサーバーが故障した場合に他のサーバー上のデータを回収することが可能となるように、このデータがネットワーク又はサーバー群全体に渡って大いに利用可能であることが望ましい。
【0005】
そのような状況におけるデータ復旧を遂行するための一つの方法は、セッションの間、データベース内に情報を格納することであるが、とはいえ、データファイルのような他の手段により格納することもできるかもしれない。データベースへのアクセス権を有するあらゆるサーバーがそのデータにアクセスできるように、セッションデータに変更がなされる度に、最新情報がデータベースに書き込まれる。データは永続的な場所に格納され、かつ他のサーバーにより容易に検索されることができる。
【0006】
しかしながら、各要求に対してデータベースからセッション情報を取り出すことは相当にコストがかかるという点で、この手法には問題がある。システムのスループットは、サーバーからのデータベースへの接続数に依存することができるため、データベースへの複数の該当は、障害を生み出し、かつ基本的に動作不能な点となるシステムダウンにはまり込ませ得る。また、これらのセッションは情報の形式を含むこともでき、ユーザーはこれにすぐアクセスしたい。いくつかのアプリケーションと共に、何千ものクライアントが同時に動作することが可能であり、それは何千もの並列実行セッションという結果となる。いくつかのサーバーは多くの異なるアプリケーションのホストとして動作することが望まれ、それは更に、それらサーバーをホストとする必要のあり得るセッション数を増やすこととなる。
【0007】
これら何万ものユーザーがシステムを効果的に使用できるように、そのようなシステムの速度及び効率を高めることが望まれる。そのような障害を避けるための一つの方法は、サーバーが99.9%の時間立ち上がって稼動中であり、かつ、単純に如何なる情報のバックアップもとらないことを想定するものである。これは、最速のユーザー体験を提供するという解決策となり得るが、しかし、データ損失という結果となる0.1%の動作不能時間でさえも、多くのユーザーには容認されないものである。
【0008】
(要約)
本発明によるシステムは、ウェブブラウザーのようなネットワーククライアントからの要求に応じるために、一次サーバーを利用することができる。この一次サーバーは、一団のサーバー又はサーバー群から選ばれることができる。一次サーバーが選択されると、その一次サーバー上でクライアント要求に応じることができる。次に二次セッションサーバーが、例えば一次サーバーによって、選択されることができる。一次サーバーが要求に応答すると、そのセッションに関する情報が、一次サーバーから二次セッションサーバーへ送られる。これは、セッション上の最初の要求における完全な一連の情報とすることができる、又はただ単に、後に続く要求に応じたセッション中の既存情報への更新とすることもできる。一次及び二次サーバーを特定する情報は、例えばクッキーとして格納される「トークン」のように、クライアント上に格納されることができ、又はトランザクション若しくはセキュリティ状況と同様な手法で標準RMIの最上位に渡されることができる。この識別情報又は「トークン」は、各要求に伴うことができる。
【0009】
システムは、ハードウェア又はソフトウェアの何れかを使って、負荷平衡化を利用することができる。ソフトウェア平衡化を伴って有用となる処理では、既に一次及び二次セッションサーバーが選択されたセッション上で、要求が受け取られることができる。一次サーバー上で要求に応じようとする試みがなされる。もし、一次サーバーが要求を受け取る、又は要求に応答することができない場合には、その要求は二次アプリケーションサーバー上で応じられることができる。もし、二次サーバーが要求を受け取るならば、その二次サーバーが新たな一次サーバーとなる。冗長性を維持するため、新たな二次サーバーが選択され、かつ、その新しい一次サーバーからセッション情報を送られることができる。
【0010】
ハードウェア負荷平衡器を伴って有用となる処理では、一次及び二次セッションサーバーが選択されたセッション上で、要求が受け取られる。次に、一次サーバー上で要求に応じようとする試みがなされる。もし、一次サーバーが要求を受け取る、又は要求に応答することができない場合には、二次セッションサーバーを使用するのではなく、ハードウェア負荷平衡器は新たな一次サーバーを選択し、かつ、その新たな一次サーバー上でその要求に応じようと試みることができる。セッション情報は、例えば新しい一次サーバーからの要求に応じて、二次セッションサーバーから新しい一次サーバーに送られることができる。次に、新しい一次サーバーは要求に応答し、かつ更新されたセッション情報を二次サーバーへ送ることができ、その結果、そのセッションについてサーバーが同期することとなる。
【0011】
(発明の詳細な説明)
本発明は、従来の複製システムの不備の多くを克服する。本発明のある実施形態による一つのシステムでは、クライアントがLAN、イーサーネット(登録商標)、又はインターネットのようなネットワーク上のサーバーに対して要求を作成する時に、セッションが作られる。要求を受け取るセッションサーバーは、例えばアプリケーションサーバー、ウェブサーバー、オブジェクトサーバー、又はサーブレットエンジンのような、セッションにおける情報を格納し、及び/又はセッション要求への応答を作り出すのに使用される如何なるサーバーからも構成されることができる。最終的に要求を受け取るサーバーが、「一次」サーバー、すなわちクライアントがこの後の要求を送るサーバーとなる。次にシステムは、そのセッションにおける「二次」サーバーを選択することができ、これは冗長性のソースとして動作することとなる。
【0012】
そのセッションの中で更新がなされる度に、その変更は一次サーバー上に格納されることができるだけでなく、例えばリモート呼び出しによって、二次サーバーに送られることもできる。変更がなされる度に、セッションデータの全てを二次サーバーに送る必要はないが、しかし変更のあったデータ又は情報のみを、例えば情報の差分又はパケットで送ることができる。最低限必要な情報を差分で送ることは、システム全体の効率を高めることができる。それがセッションデータ上で動作するという事実を除いて、その複製はミラーリングのように動作する。一例では、サーブレットエンジンを使ったウェブアプリケーションのために、このミラーリングが行われることができる。
【0013】
クライアントがサーバーに接続する時、クライアント又はユーザーに関連するセッションオブジェクトが作成される。セッションオブジェクトは、セッションの継続時間の間一次サーバー上で保持されることができる、又は指定された時間の後タイムアウトとなることができる。各セッションオブジェクトには、サーバーに対するクライアント及び/又はオブジェクトを特定するための一意の識別子、又は識別番号を与えることができる。要求に応じるために選択されたサーバーは、セッションの継続時間の間、一次サーバーとして動作することができる。一次サーバーは、セッションオブジェクトに対して二次サーバーを選択することができ、その結果オブジェクトが更新される度に、その更新がまた二次サーバー上にも格納されるようになる。システムの効率を高めるために、二次サーバーは、最低限の情報のみを受け取る、又は一括更新を行うように最適化されることができる。
【0014】
本発明のある実施形態による一つのウェブベースのシステム100が、図1に示されている。このシステムでは、ブラウザ102又はクライアントは、ウェブサーバー104によって受け取られる要求を作成する。ウェブサーバー104が要求を見て、かつ、どのオブジェクトサーバー110がその要求を受け取るべきかを判断するという点で、ウェブサーバー104はプロキシとして動作する。ウェブサーバーはプラグイン又はプラグインAPIを持つことができ、これは要求を認識するものである。プラグインは一般的に、如何なる外部アプリケーションも起動する必要なく追加機能を提供するために、アプリケーションに付加されるオブジェクトである。クライアント102におけるセッションを作成及び収容するのに利用できるオブジェクトサーバー110の間で選択するために、プラグインは、負荷平衡化の決定を行う。ウェブサーバー104は、今度は反対に、選択されたオブジェクトサーバー110に対してプロキシとして動作し、これはアプリケーションサーバー106に収容されることができる。アプリケーションサーバー106の中のサーブレットエンジン108は、要求に応答するために、オブジェクトサーバー110上のオブジェクトを呼び出すサーブレットを実行することができる。その要求に完全に応答するために、オブジェクトサーバー110はまた、データベース112又はデータ記憶装置から情報を引き出す必要もあり得る。オブジェクトサーバー110は、要求を受け取る時にセッションを作り出すことができる。当業者にはよく知られかつ使用されているように、セキュリティを提供するため、アプリケーションサーバー106及びデータベースはファイアウォール114の向こう側に置かれることができる。
【0015】
この例では、次にオブジェクトサーバーは、そのセッションにおける二次サーバーを選択する。代替の実施形態では、二次サーバーを選択するのにプラグインを使用することができる。プラグインはまた、その決定のために負荷平衡化を使用することもできる。
【0016】
オブジェクトサーバーは二次サーバーへデータを渡し、かつ、それがバックアップされることを二次サーバーに知らせる。次にオブジェクトサーバーは、クライアントに送られ、及び格納されるクッキーを作り出す。クッキーには、セッションにおいて使用される一次及び二次サーバーの識別表示が含まれている。
【0017】
クライアントがそれに続く要求を同じセッション上で送る時、どのウェブサーバーがその要求を受け取るかということは全く問題にはならない。ウェブサーバーは、そのセッションにおける一次サーバーを判断するためにクッキーを見て、次に、その一次サーバーに要求を配信する。
【0018】
図3に示されるような、各々が一次サーバーとして動作する能力のある三つのサーブレットエンジン306、308、及び312を有する例を想定する。もし、セッションが一次サーバー306上で現在稼動中で、しかし一次サーバー306が機能しない場合、ウェブサーバー304は、ブラウザ302からの要求と共に送られてくるクッキー情報を調べることにより、どのサーバーが二次サーバーとして選ばれたかを判断することができる。次にウェブサーバーはその要求を二次サーバー308へ送ろうとすることができ、それにはまたセッション状態情報310が含まれている。ウェブサーバーはブラウザ302へ応答を返すことができ、それはウェブサーバー304により二次サーバー308に送られることのできる他の要求を作成することになるであろう。二次サーバー308は、もし一次サーバー306が要求の受け入れに失敗する場合には、自己のみがウェブサーバーから直接要求を受け取るということを知っているので、もし二次サーバーがその要求を受け取る場合には、自動的に新たな一次サーバーとなることができる。この時点で、二次サーバー308は一次サーバー308となり、新しい二次サーバー312を選択することができる。あるいはそのかわりに、ウェブサーバー304に対するプラグインが新しい二次サーバー312を選択することもできる。通信途絶の可能性のある場所の一つは、第一仮想境界314によって示され、これはブラウザ/クライアント302とウェブサーバー304との間に存在する。第二仮想境界は、ウェブサーバー304とサーブレットエンジン306、308、及び312との間に存在する。
【0019】
いくつかの実施形態では、一次サーバーの状態を判断するために、二次サーバー又はウェブサーバーが自発的に一次サーバーを監視する。この監視は、例えば、ネットワークに繋がれているか否かを判断するために継続的又は定期的に一次サーバーに「pingをかける」というような適切な方法により行われることができる。もし一次サーバーが要求を受け入れることが出来ないと判断される場合には、二次サーバーが新たな一次サーバーとなることができる。次に新しい二次サーバーが選択されることができる。このような設計の利点は、二重サーバーの障害がセッション状態損失という結果となるかもしれない空白時間が短縮されるということである。いくつかの実施形態では、その空白期間をクライアント要求の率によって定めることが可能であるが、一方この手法では、その空白期間をサーバーにpingをかける率によって定めることが可能となる。
【0020】
新たな一次及び二次サーバーは同様に、セッションに関する情報を担っている。以前に一次サーバーであったサーバーは、たとえまだそのセッションが動作中に要求を受け入れ及び処理することができるようになったとしても、もはやそのセッションにおける如何なる責務又は情報も持つことはできない。二次サーバーは自動的にその状態を変更することができ、その結果、そのセッションにおける新たな一次サーバーとなるが、しかしその新しい一次サーバーが要求を受け取るまでは、新たな二次サーバーを指定しないようにすることができる。
【0021】
新たな一次サーバーが他の要求を受け取るか否かわからないので、自発的に新たな二次サーバーを作成する、又は二次サーバー上でセッション情報のバックアップをとることは望まれないであろう。使用されることのない、新たな二次サーバーの作成又は情報のバックアップは、不必要に資源を浪費することとなり得る。あるいはまた、そのセッションが短命で、かつ後に続く要求を受け取るほど長く「存続する」ものではないこともある。各セッションは典型的にタイムアウト値を持っており、その為もしそのセッションが指定された時間のあいだ動作しないような場合には、それは「タイムアウト」または「消滅」し、そのセッションは終了され、及びそのセッションにおいて格納された全てのデータはメモリ保全のため消去されることができる。このような場合には、二次サーバーの作成は資源を浪費するかもしれないというだけでなく、新たな二次サーバーからセッション情報を消去するという不必要な「清掃」作業を要求することにもなり得る。
【0022】
一次及び/又は二次サーバーはあるアルゴリズムによって選択されることができ、それは例えば、指定されたサーバークラスタ内の如何なるサーバーをも選択肢として持つことができる。各セッションについて一次及び二次サーバーを選択することは、アルゴリズムのために効率的なものとすることができるが、その一方で管理者の入力が望ましいとすることができる場合もある。例えば、複数のサーバーが一つのマシン上に置かれるという可能性もあるだろう。もし負荷に基づくようなアルゴリズムがサーバーを選択しているならば、そのアルゴリズムは同一マシン上で二つのサーバーを選択することができる。マシン故障の場合には、両サーバーとも利用不可能となり得、かつセッションデータは利用不可能及び/又は失われることとなり得る。しかしながら管理者は、異なるマシン上に存在する一次及び二次サーバーを指定することができる。これにより、サーバー間のみならずマシン間にまたがる冗長性についても備えることができる。
【0023】
あるいはまた、負荷平衡化解析を行っている時に、サーバーが置かれているマシンを考慮に入れるアルゴリズム自身の中で、パラメータを構築することもできるであろう。もし現在最も負荷の低いサーバーが一次サーバーと同じマシン上に存在するならば、アルゴリズムは、他のマシン上に存在する最も負荷の低いサーバーとなるようにすることができる。この手法は、例えば異なる部屋、異なる建物、又は異なる街のサーバーのような、如何なる階層の離隔にも拡張されることができる。
【0024】
クラスタ内のサーバーが独立して機能することを可能にするため、サーバーは緩く繋がれることができる。この緩い結合を遂行するために、クラスタ内の各サーバーは、あるサーバーがクラスタから離れる時、その動作を受け取ることができるように、自発的に又は非自発的に他のクラスタサーバーの状態を検知するように構成されることができる。ある実施形態では、サーバーは、クラスタサーバーの状態を監視することを、基盤であるOSに依存することができる。他の実施形態では、サーバーが監視を行うことを要求することができる。サーバーの資源はシステム全体のスループットを高めるために利用可能であるため、クラスタサーバーがクラスタ監視に関与する必要のない実施形態のほうが好ましいであろう。
【0025】
図2は本発明による多層クラスタアーキテクチャ200を示している。システム内の各オブジェクトは、いくつかのサーバーで利用可能なオブジェクトのインスタンスを作成することにより、クラスタ化されることができる。このアーキテクチャは仮想境界を含むことが示されている。「仮想境界」という語は、ネットワーク接続が切れ得る場所を意味している。
【0026】
図2では、第一の仮想境界212が、ブラウザ202とウェブサーバー204との間に示される。第二の障壁214は、ウェブサーバー204とサーブレットエンジン206との間に示される。第三の障壁216は、サーブレットエンジン206とオブジェクトサーバー208との間に示される。最後に、第四の障壁218が、オブジェクトサーバー208とデータベース210との間に示される。各障壁は通信断絶の可能性のある点を示しており、それはまた、負荷平衡化を利用することもできる。
【0027】
第一の仮想障壁において、ブラウザが特定のウェブサーバーには至ることができない可能性がある。しかしながら、一次及び二次サーバーに関する情報は既にブラウザのクッキーの中に格納されることができるので、本発明によるシステムにおいてこれは問題にはならないであろう。ブラウザは、どのサーバーが要求を受け取るべきであるかを、クッキーを通してそのウェブサーバーに示すことができるので、ネットワーク上の如何なるウェブサーバーとも連絡をとることができる。このシステムはLAN上で最も効率的であるとすることができるが、如何なる可能なネットワーク上においても、同様の手法を使用することができる。例えば、ブラウザは、第一のウェブサーバーとは離れた建物に置かれているかもしれない第二のウェブサーバー及び/又は終端サーバーと、インターネット越しに連絡をとることも可能であろう。
【0028】
アプリケーションによって、一次及び二次サーバーはウェブサーバー、サーブレットエンジン、又はEnterpriseJavaBean(「ejb」)エンジンのように、幾つかの異なるサーバー形式となることができる。例えば異なるサーバー形式であるというように、クラスタ内の各サーバーは、さらに独立しかつ特化されることも可能であろうが、しかしまだ一次及び/又は二次サーバーとして動作することもできるであろう。
【0029】
本発明によるシステム上でクラスタリングが可能であるならば、付加的な一次及び二次サーバーとして動作するように、新たなサーバーをシステムに透過的に付加することが可能であろう。クラスタリングは一般的に、一連のサーバー内に「管理用」サーバーを設けることにより、一連のサーバーの管理を可能にするサーバー管理の手法である。この手法により、クラスタ内のサーバー全体にわたる、潜在的に多様なコンポーネントの配置及び同期を簡単化することができる。クラスタリングは、実質的にシステムの信頼性及び拡張性を高めることができる。
【0030】
本発明によるシステムにおけるクラスタリングの時には、クラスタ内の各サーバーは、新しいサーバーがクラスタ内に入って来たことを検知し、かつその新しいサーバーを現存の一次サーバーのいずれかに対する二次サーバーとして指定するように構築されることができる。負荷平衡化に使用されるこの方法は、新しいサーバーを一次又は二次サーバーとして即座に指定することができる。
【0031】
あるいはその代わりに、本発明によるシステムは、入ってくる要求を送るためにハードウェア負荷平衡器を利用することもできる。例えばインターネットの環境下で、ハードウェア負荷平衡器は、IPアドレスを持ち、ネットワーク上に存在することができる。ブラウザ又はクライアントから入ってくる要求は、そのIPアドレスに送られることができる。次にハードウェア負荷平衡器は、他のIPアドレス、すなわち各々IPアドレスを割り当てられ、システム内ではあるがハードウェア負荷平衡器の「向こう側」に置かれている他のサーバーへ、それら要求を転送することができる。このように、ブラウザにはあたかも要求はいつも同じIPアドレスに向かうように見えるが、その時実際には、そのIPアドレスの向こう側にある複数のサーバーに向かうことができるのである。ソフトウェアクラスタリングのような他の方法を利用するのではなく、例えばハードウェア負荷平衡器にサーバーを直結させた結果とすることができるように、ハードウェア負荷平衡器は、ネットワーク内で自分の背後に置かれている全てのサーバーを意識することができる。
【0032】
ハードウェア負荷平衡器を使用する利点が存在し得る。ハードウェア負荷平衡器は、他の手法よりも、負荷平衡化のためのよりよいアルゴリズムを利用することができる。ハードウェア負荷平衡器はノード障害を検知することができ、その結果それらのノードはアルゴリズムで利用可能なサーバーのリストから抜き取られるであろう。たとえそれら個々のサーバーにまだ要求が送られていなかったかもしれないとしても、このノード除去により、アルゴリズムが、到達不可能なサーバーに向かおうとするのを防ぐことができる。
【0033】
本発明によるシステムはまた、ドメイン名をいくつかのIPアドレスにマッピングする、すなわちウェブサーバーに送られた要求をいくつかのオブジェクトサーバーに転送するハードウェア負荷平衡器を使用するのではなく、DNSRoundRobinのようなDNSプロトコルを使用することもできる。しかしながら、DNSは典型的に、それらのIPアドレスが実際に「生きている」か否かを判定又は検知しない。
【0034】
ハードウェア負荷平衡器は、その要求が動的なページ作成を要求するものであるのか、又はその要求が静的なページに対するものであるのかによって、特定のサーバー又はサーバークラスタへのある決まった形式の要求のプロキシに使用されることができる。図4では、負荷平衡器414が、ウェブブラウザ402とウェブサーバー404、408、412との間に示される。
【0035】
本発明での使用のためにハードウェア負荷平衡器414を最適化することが望ましいとすることができる一方で、負荷平衡器自身に物理的な変更を求めるのは望ましくないとすることができる。また、ハードウェア負荷平衡器がクッキーを読み取り、かつ、もし最初の一次サーバー404が機能しない場合には、ブラウザ402上に格納されたクッキーに示される二次サーバー408にその要求を転送する必要があることを理解しなければならない、ということも望ましくないであろう。しかしながら、負荷平衡器に希望のところに要求を送らせ、そして次にシステムが適切に回復していることを確認させることは望ましいであろう。
【0036】
そのような手法の一つでは、ハードウェア負荷平衡器414が、ウェブブラウザ上のクッキーに格納されたいくらかの任意の情報に基づいて、ブラウザ402又はクライアントから一つのサーバーへ要求を送る傾向がある。例えば、クッキーは情報の最初の文字列を持つことができ、その後には複製に使用されるセッション識別子だけでなく、一次及び二次サーバーに関連する情報の部分が続く。ハードウェア負荷平衡器414は、情報のこの部分のみを見るように構築されることができる。もし、情報のこの部分が連続したクッキー間で変わらない場合には、負荷平衡器は要求を一次サーバー404に転送し戻し続けることができる。また、このような「セッション粘着性」は、例えばクライアントのIPアドレスを利用できるような他の適切な方式に基づくこともできる。
【0037】
クッキー中の情報のその部分は、要求が一次サーバーに戻ることができる限りは、同じままでいることができる。もし一次サーバーが何らかの理由で機能しない場合、二次サーバーは自分自身を新たな一次サーバーに指定することができる。次にその新たな一次サーバーは、セグメント中に新しい二次サーバーについての新たな情報を挿入することができ、それは新たな一次サーバー又は負荷平衡化機構により選択されることができる。あるいはその代わりに、ハードウェア負荷平衡器が新たな一次サーバーを選択し、かつ要求をその新しい一次サーバーに転送することもできる。
【0038】
負荷平衡器で受け取られるセッションの第一の要求は、本来一つのサーバーに行くようにしっかりとコードされることはできない。ある一つのサーバーに「固執する」判断は、第一の要求が作成され、かつそれがオブジェクトサーバー又は他の終端サーバーから戻って来た後に、定められることができる。ハードウェア負荷平衡器は、この「単純な粘着性」を行う、すなわち本質的にその負荷平衡器が接続している指定された一次サーバーに戻るほどには、充分洗練されているとすることができる。
【0039】
もしクッキーが全く存在しないならば、ハードウェア負荷平衡器は、負荷又は応答時間に基づくような、多数の負荷平衡化方法のいずれかを使用するように構築されることができる。次に負荷平衡器は、例えば適当なクラスタの中で、サーバーを選択し、かつ要求をそのサーバーに送ることができる。一次サーバーは要求に応答する時、一次及び二次サーバーに関する情報の部分を含むクッキーをブラウザに送ることができる。ハードウェア負荷平衡器によって受け取られる、そのブラウザからの次に続く各要求は、それに関連するクッキーを有することができ、そのため負荷平衡器はその要求を一次サーバーと対応付けることができる。
【0040】
システムはまだ、要求が一次サーバーに行くことを保証することはできないであろう。図4に示されるように、もし一次サーバー404で障害が発生し、かつ他の要求が負荷平衡器414に入ってくる場合には、負荷平衡器はただ単に、異なった負荷平衡化決定を行い、かつ要求を他のサーバー412に送ることができる。その要求は、二次サーバー408に行くことはできない。この手法は、要求が自動的に二次サーバーに行くことができるプラグイン手法について上で述べたものとは異なる。このように、ハードウェア負荷平衡器は上述されたものと同様に、特別なプロキシプラグインに比べると「知的」ではない。
【0041】
負荷平衡器414によって選択されるサーバー412が二次サーバー408でないならば、選択されたサーバー412は、その要求が自己をホストとしていないセッション上の要求であるということを認識することができる。この場合、選択されたサーバー412は、二次サーバー408を判断するためにクッキーを見ることができる。
【0042】
選択されたサーバー412が二次サーバー408を突き止めると、その二次サーバー408からセッション状態情報410を要求することができる。次に、選択されたサーバー412は、自分自身をそのセッションにおける新たな一次サーバーに変えることができる。この場合、二次サーバー408は同じままでいることができる。クッキーは、負荷平衡器414が新たな一次サーバー412に要求を導きつづけるように更新される。
【0043】
負荷平衡器414が、偶然にも二次サーバー408である新しいサーバーに要求を導くことに決める場合には、二次サーバーは自分自身を新たな一次サーバーとして設定することができ、かつ新たな二次サーバーが選択されることができる。
【0044】
その背後にサーブレットクラスタを有するハードウェア負荷平衡器を持つシステムは、高速データパスを提供することができる。もしウェブサーバーが経路制御を行うならば、要求は、何らかのコードが実行されているソフトウェアの中までやってきて、かつその後ネットワーク上に送り返される必要があるであろう。負荷平衡器/サーブレットクラスタシステムは全てを低プロトコル層で行うため、それは非常に早いものとなることができる。
【0045】
負荷平衡化アルゴリズムを可能な限り配置させることは、有利となり得る。ハードウェア負荷平衡器の場合、Javaで書かれることのできるソフトウェアのような、サーバー上のソフトウェアが正しく動作していることを確認することだけが必要となり得る。ハードウェア負荷平衡器のないシステムでは、システム内の各ウェブサーバーの特別なプラグインの各々が同様にうまく動作していることを確認しなければならないであろう。
【0046】
また、異なるプラットフォームのためのプラグインをサポートすることも必要であろう。ハードウェア負荷平衡器は、例えば、NetscapeApplicationServer(NAS)、WebLogicServer(WLS)、MicrosoftInternetInformationServer(IIS)、又はApacheHTTPServerのような異なるプラットフォームに基づくシステムにおいても、同じようにうまく動作することができる。ハードウェア負荷平衡器を用いることで、堤防の一つを取り除くことができるように、システムは複雑さを一段階減らすことができる。これは図4に示されるが、ここではウェブサーバーとサーブレットエンジンは同じプロセス中に存在する。
【0047】
上述のシステムの幾つかは、ウェブアクセスのためにサーブレットを利用することができる。同様な機構を、状態有りセッションビーン、ある形式のEnterpriseJavaBean(「ejb」)へのアクセスに使用することも出来る。サーブレットはブラウザクライアントからの要求に応じるために使用されることができるが、一方ejbサーバーはJavaクライアントからの要求をサポートするために使用されることができる。
【0048】
Javaクライアントにおいては、セッションの存続時間の間ずっと、一つの持続的な接続が存在することができる。その時、クッキーの必要(又はサポート)はないであろう。また、持続的な接続が存在しているため、もはや負荷平衡器の必要もないであろう。Javaクライアントは、例えばDNS又は負荷平衡器を用いて、終端サーバーの一つに接続することができる。次に、Javaクライアントは、状態有りセッションへの「ハンドル」を捜すことができる。Javaにおけるハンドルとはポインタと似ており、適切なセッションの位置を捜し出すために使用されることができる。
【0049】
図5のシステム500に注目すると、Javaクライアント502がハンドルに接続されると、状態有りセッションビーン510が作成されることができる。状態有りセッションビーン510は、セッションにおける情報をキャッシュ又は格納することを扱うのに使用されることができる。状態有りセッションビーンが作成される時、ビーンを収容しているサーバーは一次サーバー508となることができ、それに対してJavaクライアント502は要求を作成することができる。次に一次サーバー506は、二次サーバー510を選択することができる。二次サーバー510はまた、セッション情報をキャッシュ又は格納するために、状態有りセッションビーン512を有することができる。
【0050】
状態有りセッションビーン508は、クッキーを送るのと同様に、RMIプロトコルを用いてこの情報をJavaクライアント502に返すことができる。トランザクションの状況伝搬が動作する方法と同様に、このクッキーのシミュレーションを動作させるために、付加情報を標準RMIの「最上位」に置くことができる。一次/二次サーバーの識別子のペアは、各応答と共にJavaクライアント502に返されることができる。Javaクライアント502が呼び出しを作成する度に、それは、インターフェース504を通して、セッションにおける一次サーバー506への呼び出しを作成し続けるのに適応した特別なRMIコードの中に呼び出しをかけることができる。もし一次サーバーが動作不能である場合には、Javaクライアント502は二次サーバー510の所在に関する情報を見ることができ、かつその代わりに二次サーバーに対して要求を作成することができる。もし、サーバー特定に関する必須情報のみがRMIの最上位に返されるのであれば、それは効率のために望ましいことであろう。
【0051】
Javaクライアント502は、どのサーバーが二次サーバー510であるかを常に知ることができる。例えば、もし一次サーバー506が利用不可能である場合には、二次サーバー510に行くことを常にわかっているように、Javaクライアントは、プロキシが所有するかもしれないロジックと同じロジックの多くを持つことができる。Javaクライアントは、要求を利用不可能なサーバーに送らないようにするため、サーバーの状態を監視することができる。二次サーバー510が新しい一次サーバーとなる場合には、さらに新たな二次サーバー504を選択することができる。新しい一次及び/又は二次サーバーを選択するためのロジックは、上述のもの同様なものであるとすることができる。Javaクライアントは即座に、新たな一次/二次サーバーに更新することができる。
【0052】
上の検討より、上述のものを含む様々な変形が利用され得るけれども、本発明によるシステムは一般的に、二つに分岐している方針の一方を辿ることができる。そのような方針の共通部分が図6に示される。図6の過程600では、一次サーバーが一団のサーバーから選択される602。一次サーバーが選択されると、クライアント要求はその一次サーバーで応じられる604。次に、もしかすると一次サーバーにより、二次サーバーが選択される606。次に、セッション情報が一次サーバーから二次サーバーへ送られる608。一次及び二次サーバーを特定する情報は、例えばクッキー内に格納され、又は標準(又はその他)RMIの最上位に渡されることができる、というようにクライアント上に格納されることができる610。
【0053】
この点から、処理はソフトウェア負荷平衡化に有用となり得る方針、及びハードウェア負荷平衡化に有用となり得る過程とに分かれる。図7は、ソフトウェア負荷平衡化に有用な過程700を示している。過程700では、一次及び二次サーバーが既に選択されているセッション上で要求が受け取られ、かつクライアント上に格納された情報から一次サーバーの識別情報が作成される702。次に、一次サーバー上で要求に応じようとする試みがなされる704。もし一次サーバーが要求を受け取ることができない場合には、要求は二次サーバー上で応じられる706。二次サーバーが要求を受け取ると、その二次サーバーが新たな一次サーバーとなる708。次に新たな二次サーバーが選択され、かつ新しい一次サーバーからセッション情報が送られる710。
【0054】
ハードウェア負荷平衡器を有するシステムに有用である、もう一方の方針が図8に示されている。図8の過程800では、既に一次及び二次サーバーが選択されているセッション上で要求が受け取られ、クライアント上に格納された情報から一次サーバーの識別情報が作成される802。次に、一次サーバー上で要求に応じようとする試みがなされる804。もし一次サーバーが要求に応じることができない場合には、ハードウェア負荷平衡器は新たな一次サーバーを選択し、かつその新しい一次サーバー上で要求に応じようと試みる806。次にセッション情報は、例えば新しい一次サーバーからの要求に応じて、二次サーバーからその新しいサーバーに送られる808。次に、新しい一次サーバーは要求に応答し、かつ更新されたセッション情報を二次サーバーに送ることができる810。
【0055】
本発明の如何なる実施形態においても整合性を保つために、セッションデータにおける変更はバージョン番号に対応付けられることができる。一次及び二次サーバーはそれぞれ、セッションのどのバージョンを自己が格納しているか、知ることができる。サーバーは、もし自己が現在格納しているものよりも後の、又は大きいバージョン番号を持つ要求を受け取った場合に限り、データを修正するように指示されることができる。一次及び二次サーバーは、双方が同じバージョン番号上にあることを確認するために、互いに定期的に調べることができる。バージョン番号は、順番を保証するために数を増やしていく、というのと同じくらい単純な方法を使用することができる。セッション情報における整合性を維持するために、一次及び二次サーバーが同期することが望まれるであろう。バージョン番号の同期がとれない時、一次サーバーは、セッションの同期を回復させるために、二次サーバーへ全セッション情報を送ることに決めることができる。この同期はまた、必要が生じれば、一次と二次の間の役割を切り替えるというサーバーの能力を促進する。
【0056】
もし一次サーバーが、例えば悪い接続というような理由で、二次サーバー上の情報を更新することが出来ない場合には、一次サーバーは更新し続け、かつ二次サーバーは如何なる更新も認識しないということがあり得るであろう。その時、一次サーバーが二次サーバーよりもいくつかバージョンが先になるということがあり得るであろう。一次サーバーが再び二次サーバーに情報を送ることができるようになると、二つの連続したバージョン間の差分は機能することができない。このような場合、両サーバー間のデータセッションの整合性を取るため、一次サーバーは、新しい一連のセッションデータ全体を二次サーバーに送ることができる。この場合、二次サーバーは、連続したバージョン間の差分を得るか、又はセッション全体における全てのデータを得るかのいずれかとなる。他の実施形態では、二次サーバーを現在のバージョンに達するようにするために、任意のバージョン間の差分を作成することもあり得るであろう。
【0057】
Javaの状態を辿るためのクッキーのシミュレーションでは、大きい乱数をサーバー識別のために使用することができる。その数は、二つの異なるペアの識別番号の合計が同じになることが極めてないほどに、充分大きいものとすることができる。これら二つの番号をJavaクライアントに送り返すのみということも可能であり、かつ新しい番号を得るためにその二つの番号を足すことによりそのサーバーのペアが特定されるころができる。これにより、たった一つの数を渡すことで二つのサーバーを特定することが可能となり、それは効率を高めることができる。Javaクライアントは特定のサーバーと持続的に接続することが可能であるため、クライアントは、二次サーバーの識別番号を得るために、渡されている合計数から一次サーバーの識別番号を引くことにより二次サーバーを特定することができる。
【0058】
しかしながら、セッションビーンのようなJavaオブジェクトは、上で考察された持続的な状態とは対照的に、状態なし又は一時的な状態を持つものとすることができる。もしJavaセッションビーンが状態なしの場合には、ビーンは、呼び出し間又は連続した要求間のセッション情報を保持することができないであろう。もし、セッション情報が他のどこかに格納されるならば、状態なしビーンは、要求に応じるために、一時的にセッション情報をロードすることができる。フェ−ルオーバー、すなわち複製されたセッション情報を有する新しい一次サーバーにセッション制御を任せることは、例えば一次サーバーが要求を決して受け取らず、その要求が手続き的でかつ異常終了した、すなわち一回限りの要求であった、というような明らかな呼び出し失敗があったところでのみ、生じることが可能である。これに対して、もしセッションビーンが一時的なものである場合は、インタスタンスは、状態なし負荷平衡化及びフェ−ルオーバーを用いて、状態なしの製造場によって作られることができる。一時的な状態の中のビーンは、メモリ内にバックアップされることができない、又は上で説明したような一次/二次複製を用いてバックアップされることができる、のいずれかである。
【0059】
一括変更は、失敗の空白期間の増大したシステムのスループットを高めるのに使用されることができる。一括処理又は「箱運搬」の際、効率及び拡張性を高めるため、いくつかの要求が、一つの大きな要求としてまとめて送られる。要求の一括処理は、時間間隔又は要求の数、というような多くの基準のうちのいずれかに基づくことができる。例えばシステムは、10秒毎に、又は100の個々のセッション更新メッセージ毎に対して、一バッチ分の要求を送ることができる。システムはまた、最後の一括処理から10秒経過した時、又は100の要求が受け取られた時に一バッチを送り、双方の基準に対応することもでき、どちらも第一になる。一括処理により、もはやシステムは、同期更新ほど信頼性の高いものではなくなるであろうが、しかしシステム全体の拡張性を高めることができる。
【0060】
その基準はまた、例えばユーザー又は管理者によって、設定可能なものとすることができる。設定可能な基準は、システムがある決まった時間には大量のトラフィックに直面するが、それ以外の時間には殆どトラフィックがないというような状況に適しているとすることができる。例えば、設定可能な基準により、ピーク時には100メッセージ毎に一括処理し、空いている時間には全く一括処理を行わないということが可能になり、その結果、各要求は適度な時間で送られることとなる。
【0061】
システム管理者はまた、一次及び二次サーバーとして、クラスタ内の2つのサーバーを組にすることもできる。システム全体の耐故障性を高めるため、管理者の入力が望まれるであろう。例えば、複数のサーバーは一つの物理的なマシン上に置かれることができ、かつ、アルゴリズムが一次及び二次サーバーの両方を同じマシン上に配置することに決めるかもしれない。すると、もしそのマシンが故障する場合には、セッション情報はすっかり失われてしまうこともあるかもしれない。マシン故障からのセッション情報の喪失を防ぐために、管理者は、一次及び二次サーバーそれぞれを、物理的に別個のマシン上に指定することに決めることができる。管理者はまた、様々な負荷平衡化方式に基づいて一次サーバーを選択することもできる。可能性のある方式の例としては、サーバー負荷、接続数、及び物理的な近さに基づくものがある。
【0062】
本発明のより好ましい実施形態についての上述の説明は、例証及び説明の目的のために提供されたものである。それは網羅的なもの、又は本発明を開示された厳密な形態に限定することを意図したものではない。明らかに、当業者には多くの修正及び変更が明白であろう。本実施形態は、本発明の原理及びその実際の応用を最もよく説明するために、選択され及び説明されたものであり、それゆえ他の当業者は、意図した特定の使用に適した様々実施形態における、かつ様々な修正を伴った本発明を理解することが可能となる。本発明の技術的範囲は、次に続く特許請求の範囲、及びその均等技術によって定められることを意図したものである。
【図面の簡単な説明】
【0063】
【図1】本発明の一実施形態によるアプリケーションサーバーシステムのダイヤグラムである。
【図2】本発明の一実施形態による複数階層アーキテクチャのダイヤグラムである。
【図3】本発明の一実施形態によるサーブレットエンジンシステムのダイヤグラムである。
【図4】本発明の一実施形態による負荷平衡器システムのダイヤグラムである。
【図5】本発明の一実施形態によるJavaシステムのダイヤグラムである。
【図6】本発明の一実施形態による処理におけるフローチャートである。
【図7】本発明の一実施形態によるソフトウェア負荷平衡器の処理におけるフローチャートである。
【図8】本発明の一実施形態によるハードウェア負荷平衡器の処理におけるフローチャートである。

Claims (74)

  1. クライアントセッション中の情報を複製するためのシステムであって、
    b.クライアントセッション中の要求を受け取り、当該要求に応答し、さらに前記クライアントセッションにおけるセッション情報を格納する一次サーバーと、
    c.クライアントセッション中の要求を受け取り、当該要求に応答し、さらに前記クライアントセッションにおけるセッション情報を格納する二次サーバーと、
    d.前記一次及び二次サーバーの識別情報を含むクライアントからの要求を受け取り、前記識別情報を処理し、前記一次サーバー上で前記プロセス要求に応じるウェブサーバーと、
    を備え、前記ウェブサーバーは、さらに前記一次サーバーが要求を処理できない場合に、前記二次サーバー上で当該要求に応じる、
    ことを特徴とするシステム。
  2. 前記一次及び二次サーバーと通信するデータベースをさらに備え、前記データベースは要求を処理するのに役立つ情報を格納する、
    請求項1記載のシステム。
  3. 前記一次サーバーが、さらに、前記クライアントセッションにおける要求を受け取る度に、前記二次セッションサーバーに格納された前記セッション情報を更新する、
    請求項1記載のシステム。
  4. 前記ウェブサーバーが、さらに、前記クライアントセッションにおいて最初の要求が受け取られかつ前記クライアント上に何の識別情報も存在しない時、複数のサーバーから前記一次サーバーを選択する、
    請求項1記載のシステム。
  5. 前記クライアント上に格納されるクッキーをさらに備え、前記クッキーは前記一次及び二次サーバーの識別情報を含む、
    請求項1記載のシステム。
  6. 前記一次サーバーが、さらに、前記クライアント上の前記クッキーを作成する、
    請求項5記載のシステム。
  7. 前記ウェブサーバーが、前記一次サーバーを選択するのに使用されるアルゴリズムを含むプラグインをさらに備える、
    請求項1記載のシステム。
  8. 前記ウェブサーバーが、前記一次及び二次サーバーに要求を送るのに使用されるアルゴリズムを含むプラグインをさらに備える、
    請求項1記載のシステム。
  9. 前記アルゴリズムが負荷平衡化アルゴリズムである、
    請求項7記載のシステム。
  10. 前記一次サーバーが前記二次サーバーを選択するのに適応した、
    請求項1記載のシステム。
  11. 前記一次サーバーが、クライアントからの最初の要求を受け取った時に、前記クライアントセッションを開始する、
    請求項1記載のシステム。
  12. 前記二次サーバーが、さらに、前記一次サーバーが処理できなかった要求を受け取る場合に、新たな一次サーバーとなる、
    請求項1記載のシステム。
  13. 前記二次サーバーが、さらに、新たな二次サーバーを選択し、当該新たな二次サーバーにセッション情報を送る、
    請求項12記載のシステム。
  14. 前記ウェブサーバーが新たな二次サーバーを選択する、
    請求項12記載のシステム。
  15. 前記二次サーバーが、さらに、前記一次サーバーが要求を受け取ることができるか否かを判定するために前記一次サーバーを監視する、
    請求項1記載のシステム。
  16. 前記二次サーバーが、さらに、前記一次サーバーが要求を受け取ることができない場合に、新たな一次サーバーとなる、
    請求項1記載のシステム。
  17. 前記一次及び二次サーバーの一つが、ウェブサーバー、サーブレットエンジン、及びenterprise Java beanエンジンからなるグループから選択される、
    請求項1記載のシステム。
  18. Javaクライアントセッション中の情報を複製するためのシステムであって、
    a.クライアントセッション中でJavaクライアントからの要求を受け取り、当該要求に応答し、さらに、前記クライアントセッションにおけるセッション情報を格納する一次サーバーと、
    b.クライアントセッション中で要求を受け取り、当該要求に応答し、さらに、前記クライアントセッションにおけるセッション情報を格納する二次サーバーと、
    c.前記クライアントセッションにおける情報を保持し、かつ前記一次及び二次サーバーの識別情報をクライアントに送り返すのに使用される、前記一次サーバー上の状態有りセッションビーンと、
    を備えることを特徴とするシステム。
  19. クライアントからの要求を受け取り、かつ前記一次サーバーを選択する負荷平衡器をさらに備える、
    請求項18記載のシステム。
  20. 前記一次サーバーが、さらに、前記クライアントセッションの間、Javaクライアントとの持続的な接続を維持する、
    請求項18記載のシステム。
  21. 前記ウェブサーバーが、さらに、前記一次サーバーへの要求を一括で送る、
    請求項1記載のシステム。
  22. クライアントセッション中に冗長性を提供するための方法であって、
    a.複数のセッションサーバーから一次サーバーを選択するために、クライアントセッション中のクライアントからの最初の要求に対して負荷平衡化の決定を行うステップと、
    b.前記一次サーバー上で前記要求に応じるステップと、
    c.二次サーバーを選択するステップと、
    d.前記一次サーバーから前記二次サーバーへ、前記クライアントセッションにおけるセッション情報を送るステップと、
    e.前記クライアントセッションで要求が受け取られる度に、前記一次及び二次サーバー上のセッション情報を更新するステップと、
    を含むことを特徴とする方法。
  23. 前記クライアント上のクッキー内に前記情報を格納するステップをさらに含む、
    請求項22記載の方法。
  24. 前記一次サーバーが要求を処理できない場合に、前記二次サーバー上で当該要求に応じるステップをさらに含む、
    請求項22記載の方法。
  25. 新たな二次サーバーを選択するステップをさらに含む、
    請求項24記載の方法。
  26. 前記一次サーバーへの要求に一括で応じるステップをさらに含む、
    請求項22記載の方法。
  27. 前記一次サーバーから前記二次サーバーへ、前記クライアントセッションにおけるセッション情報を一括で送るステップをさらに含む、
    請求項22記載の方法。
  28. 状態有りセッションビーン内にセッション情報を保持するステップをさらに含む、
    請求項22記載の方法。
  29. バージョン番号を、要求に応じた前記セッション情報への各更新に対応付けるステップをさらに含む、
    請求項22記載の方法。
  30. 前記一次サーバーから前記二次サーバーへ前記クライアントセッションにおけるセッション情報を送るステップが、前記セッション情報内の変更を含む情報の差分を送ることを含む、
    請求項22記載の方法。
  31. 前記一次及び二次サーバー各々に識別番号を割り当てるステップをさらに含む、
    請求項22記載の方法。
  32. 前記一次及び二次サーバーの両方を表す一つの番号を得るために、前記一次及び二次サーバーの識別番号を足すステップをさらに含む、
    請求項31記載の方法。
  33. クライアントセッション中の情報を複製するためのシステムであって、
    a.複数のセッションサーバーと、
    b.クライアントセッション中の要求を受け取り、当該要求に応答し、さらに、当該クライアントセッションにおけるセッション情報を格納し、かつ前記一次サーバーに関する情報を含むクッキーを作成し、当該クッキーをセッションクライアントに送る、前記複数のセッションサーバー内の一次サーバーと、
    c.前記一次サーバーから前記セッション情報を受け取り、当該セッション情報を格納し、さらに、クライアントセッション中の要求を受け取り、当該要求に応答する、前記一次サーバーにより選択される、前記複数のセッションサーバー内の二次サーバーと、
    d.前記一次及び二次サーバーの識別情報を含むクライアントからの要求を受け取り、前記識別情報を処理し、かつ前記一次サーバー上で前記プロセス要求に応じるウェブサーバーと、
    を備え、前記ウェブサーバーはさらに、前記一次サーバーが要求を処理できない場合に、前記二次サーバー上で当該要求に応じる、
    ことを特徴とするシステム。
  34. クライアントセッション中に冗長性を提供するための方法であって、
    a.複数のセッションサーバーから一次サーバーを選択するために、クライアントセッション中のクライアントからの最初の要求に対する負荷平衡化の決定を行うステップと、
    b.前記一次サーバー上で前記要求に応じるステップと、
    c.前記一次サーバーから当該一次サーバーにより選択される二次サーバーに、前記クライアントセッションにおけるセッション情報を送るステップと、
    d.前記一次及び二次サーバーを特定する情報を含むクッキーをセッションクライアント上に格納するステップと、
    e.前記クライアントセッションで要求が受け取られる度に、前記一次及び二次サーバー上のセッション情報を更新するステップと、
    を含むことを特徴とする方法。
  35. 前記クライアントセッション内で受け取られた要求の中の識別情報を読み取り、かつ前記一次サーバー上で前記要求に応じるステップをさらに含む、
    請求項34記載の方法。
  36. クライアントセッション中の情報を複製するためのシステムであって、
    a.複数のセッションサーバーと、
    b.クライアントセッション中の要求を受け取り、当該要求に応答するのに適応し、さらに前記クライアントセッションにおけるセッション情報を格納するし、かつ、前記一次サーバーに関する情報を含むクッキーを作成し、当該クッキーをセッションクライアントに送る、前記複数のセッションサーバー内の一次サーバーと、
    c.前記一次サーバーから前記セッション情報を受け取り、当該セッション情報を格納し、さらに、クライアントセッション中の要求を受け取り、当該要求に応答する、前記一次サーバーにより選択される、前記複数のセッションサーバー内の二次サーバーと、
    d.クライアントから最初の要求を受け取り、当該要求を前記一次サーバーに送り、さらに、前記一次及び二次サーバーの識別情報を含むクライアントからの次に続く要求を受け取り、かつ前記識別情報を処理し、前記一次サーバー上で前記プロセス要求に応じる、前記一次サーバーを選択するための負荷平衡化ロジックを含むウェブサーバーと、
    を備え、前記ウェブサーバーはさらに、前記一次サーバーが要求を処理できない場合に、前記二次サーバー上で当該要求に応じる、
    ことを特徴とするシステム。
  37. クライアントセッション中に冗長性を提供するための方法であって、
    a.複数のセッションサーバーから一次サーバーを選択するために、クライアントセッション中のクライアントからの最初の要求に対する負荷平衡化の決定を行うステップと、
    b.前記一次サーバー上で前記要求に応じるステップと、
    c.前記一次サーバーから当該一次サーバーにより選択された二次サーバーへ、前記クライアントセッションにおけるセッション情報を送るステップと、
    d.セッションクライアント上にクッキーを格納するステップであって、当該クッキーが前記一次及び二次サーバーを特定する情報を含む当該ステップと、
    e.前記クライアントセッション中の、次に続くいずれかの要求と共に受け取られる前記識別情報を読み取り、かつ前記一次サーバー上で当該次に続く要求に応じるステップと、
    f.前記クライアントセッションにおいて、次に続く要求が前記一次サーバー上で応じられる度に、前記一次及び二次サーバー上のセッション情報を更新するステップと、
    を含むことを特徴とする方法。
  38. クライアントセッション中に冗長性を提供するための方法であって、
    a.クライアントからの最初の要求に応じて、複数のセッションサーバーから一次サーバーを選択するステップと、
    b.クライアントセッションを開始するために、前記一次サーバー上で前記要求に応じるステップと、
    c.二次サーバーを選択するステップと、
    d.前記一次サーバーから前記二次サーバーへ、前記クライアントセッションにおけるセッション情報を送るステップと、
    e.前記クライアントセッションで要求が受け取られる度に、前記一次及び二次サーバー上のセッション情報を更新するステップと、
    を含むことを特徴とする方法。
  39. 前記クライアント上のクッキー内に前記情報を格納するステップをさらに含む、
    請求項38記載の方法。
  40. 前記一次サーバーが要求を処理できない場合に、前記二次サーバー上で当該要求に応じるステップをさらに含む、
    請求項38記載の方法。
  41. 新たな二次サーバーを選択するステップをさらに含む、
    請求項40記載の方法。
  42. 前記一次サーバーへの要求に一括で応じるステップをさらに含む、
    請求項38記載の方法。
  43. 前記一次サーバーから前記二次サーバーへ、前記クライアントセッションにおけるセッション情報を一括で送るステップをさらに含む、
    請求項38記載の方法。
  44. クライアントセッション中の情報を複製するためのシステムであって、
    a.複数のサーバーと、
    b.クライアントセッション中の要求を受け取り、当該要求に応答し、さらに、前記クライアントセッションにおけるセッション情報を格納する、前記複数のサーバー内の一次サーバーと、
    c.クライアントセッション中の要求を受け取り、当該要求に応答し、さらに、前記クライアントセッションにおけるセッション情報を格納する、前記複数のサーバー内の二次サーバーと、
    d.前記一次及び二次サーバーの識別情報を含むクライアントからの要求を受け取り、前記識別情報を含む要求の該当部分を調べるハードウェア負荷平衡器と、
    を備え、前記ハードウェア負荷平衡器がさらに、当該部分が前の要求以来変更されていない場合には、前記一次サーバー上で前記プロセス要求に応じ、当該部分が変更されていた場合には、前記複数のサーバーから新たな一次サーバーを選択する、
    ことを特徴とするシステム。
  45. クライアント上に格納されるクッキーをさらに備え、前記クッキーは、前記一次及び二次サーバーの識別情報を含む、
    請求項44記載のシステム。
  46. 前記クッキーが、前記一次サーバーに対する番号、及び前記二次サーバーに対する番号を含む、
    請求項45記載のシステム。
  47. 前記クッキーが、前記一次サーバーに対する番号と前記二次サーバーに対する番号との合計である番号を含む、
    請求項45記載のシステム。
  48. 前記ハードウェア負荷平衡器が、さらに、前記一次サーバーが要求を処理できない場合に、前記複数のサーバーから新たな一次サーバーを選択する、
    請求項44記載のシステム。
  49. 前記一次サーバーが、自己をホストとしないあるクライアントセッション上の要求を受け取る時に、前記二次サーバーから前記クライアントセッションにおけるセッション情報を要求し、前記二次サーバー上に格納されている前記クライアントセッションにおける情報を要求する、
    請求項44記載のシステム。
  50. 前記一次サーバーが、さらに、クライアントセッションにおいて受け取られる要求に関連するクッキーを読み取り、かつ前記一次サーバーが当該クライアントセッションのホストとして働いているか否かを判定する、
    請求項44記載のシステム。
  51. 前記ハードウェア負荷平衡器が、さらに、前記一次サーバーへの要求を一括で送る、
    請求項44記載のシステム。
  52. クライアントセッション中に冗長性を提供するための方法であって、
    a.複数のサーバーから一次サーバーを選択するために、クライアントセッション中のクライアントからの最初の要求に対する負荷平衡化の決定を、ハードウェア負荷平衡器内のアルゴリズムを使って行うステップと、
    b.前記一次サーバー上で前記要求に応じるステップと、
    c.前記一次サーバーを使って二次サーバーを選択するステップと、
    d.前記一次サーバーから前記二次サーバーへ、前記クライアントセッションにおけるセッション情報を送るステップと、
    e.前記クライアントセッションで要求が受け取られる度に、前記一次及び二次サーバー上のセッション情報を更新するステップと、
    を含むことを特徴とする方法。
  53. 前記クライアント上のクッキー内に前記情報を格納するステップをさらに含む、
    請求項52記載の方法。
  54. 前記一次サーバーが要求を処理できない場合に、前記ハードウェア負荷平衡器を使って新たな一次サーバーを選択するステップをさらに含む、
    請求項52記載の方法。
  55. 前記新たな一次サーバー上で要求に応じるステップをさらに含む、
    請求項54記載の方法。
  56. 新たな二次サーバーを選択するステップをさらに含む、
    請求項54記載の方法。
  57. 前記一次サーバーへの要求に一括で応じるステップをさらに含む、
    請求項52記載の方法。
  58. 前記一次サーバーから前記二次サーバーへ、前記クライアントセッションにおけるセッション情報を一括で送るステップをさらに含む、
    請求項52記載の方法。
  59. バージョン番号を、要求に応じた前記セッション情報への各更新に対応付けるステップをさらに含む、
    請求項52記載の方法。
  60. 前記一次サーバーから前記二次サーバーへ前記クライアントセッションにおけるセッション情報を送るステップが、前記セッション情報内の変更を含む情報の差分を送ることを含む、
    請求項52記載の方法。
  61. 前記一次及び二次サーバー各々に識別番号を割り当てるステップをさらに含む、
    請求項52記載の方法。
  62. 前記一次及び二次サーバーの両方を表す一つの番号を得るため、前記一次サーバーに対する識別番号と前記二次サーバーに対する識別番号を足すステップをさらに含む、
    請求項52記載の方法。
  63. クライアントセッション中の情報を複製するためのシステムであって、
    a.複数のサーバーと、
    b.クライアントセッション中の要求を受け取り、当該要求に応答し、さらに、前記クライアントセッションにおけるセッション情報を格納し、かつ前記一次サーバーに関する情報を含むクッキーを作成し、当該クッキーをセッションクライアントに送る、前記複数のサーバー内の一次サーバーと、
    c.前記一次サーバーから前記セッション情報を受け取り、当該セッション情報を格納し、さらに、クライアントセッション中の要求を受け取り、当該要求に応答する、前記一次サーバーによって選択される、前記複数のサーバー内の二次サーバーと、
    d.前記一次及び二次サーバーの識別情報を含むクライアントからの要求を受け取り、ウェブサーバーが前記識別情報を処理しかつ前記一次サーバー上で前記プロセス要求に応じる、ハードウェア負荷平衡器と、
    を備え、前記ハードウェア負荷平衡器は、前記一次サーバーが要求を処理できない場合に、新たな一次サーバー上で当該要求に応じる、
    ことを特徴とするシステム。
  64. クライアントセッション中に冗長性を提供するための方法であって、
    a.複数のサーバーから一次サーバーを選択するために、クライアントセッション中のクライアントからの最初の要求に対する負荷平衡化の決定を、ハードウェア負荷平衡器内のアルゴリズムを使って行うステップと、
    b.前記一次サーバー上で前記要求に応じるステップと、
    c.前記一次サーバーから当該一次サーバーにより選択される二次サーバーへ、前記クライアントセッションにおけるセッション情報を送るステップと、
    d.前記一次及び二次サーバーを特定する情報を含むクッキーをセッションクライアント上に格納するステップと、
    e.前記クライアントセッションで要求が受け取られる度に、前記一次及び二次サーバー上のセッション情報を更新するステップと、
    を含むことを特徴とする方法。
  65. 前記クライアントセッション中で受け取られる要求に対する識別情報を含むクッキーの一部分を処理し、かつ前記一次サーバー上で当該要求に応じるステップをさらに含む、
    請求項64記載の方法。
  66. クライアントセッション中の情報を複製するためのシステムであって、
    a.複数のサーバーと、
    b.クライアントセッション中の要求を受け取り、当該要求に応答し、さらに、前記クライアントセッションにおけるセッション情報を格納し、かつ前記一次サーバーに関する情報を含むクッキーを作成し、当該クッキーをセッションクライアントに送る、前記複数のサーバー内の一次サーバーと、
    c.前記一次サーバーから前記セッション情報を受け取り、当該セッション情報を格納し、さらに、クライアントセッション中で要求を受け取り、当該要求に応答する、前記一次サーバーによって選択される、前記複数のサーバー内の二次サーバーと、
    d.クライアントからの最初の要求を受け取り、当該要求を前記一次サーバーに送り、さらに、前記一次及び二次サーバーの識別情報を含むクライアントからの次に続く要求を受け取り、かつ、前記識別情報を処理し、前記一次サーバー上で前記プロセス要求に応じる、前記一次サーバーを選択するための負荷平衡化ロジックを含むハードウェア負荷平衡器と、
    を備え、前記ハードウェア負荷平衡器はさらに、前記一次サーバーが要求を処理できない場合に、新たな一次サーバーを選択し、当該新たな一次サーバー上で当該要求に応じる、
    ことを特徴とするシステム。
  67. クライアントセッション中に冗長性を提供するための方法であって、
    a.複数のサーバーから一次サーバーを選択するために、クライアントセッション中のクライアントからの最初の要求に対する負荷平衡化の決定を、ハードウェア負荷平衡器内のアルゴリズムを使って行うステップと、
    b.前記一次サーバー上で前記要求に応じるステップと、
    c.前記一次サーバーから当該一次サーバーにより選択された二次サーバーへ、前記クライアントセッションにおける情報を送るステップと、
    d.前記セッションクライアント上に、前記一次及び二次サーバーを特定するための情報を含むクッキーを格納するステップと、
    e.前記クライアントセッション中の、次に続くいずれかの要求と共に受け取られる前記識別情報を読み取り、かつ前記一次サーバー上で当該次に続く要求に応じるステップと、
    f.前記クライアントセッションにおいて、次に続く要求が前記一次サーバー上で応じられる度に、前記一次及び二次サーバー上のセッション情報を更新するステップと、
    を含むことを特徴とする方法。
  68. クライアントセッション中に冗長性を提供するための方法であって、
    a.クライアントからの最初の要求に応じて、複数のサーバーから一次サーバーを、ハードウェア負荷平衡器内の負荷平衡化ロジックを使って選択するステップと、
    b.クライアントセッションを開始するために、前記一次サーバー上で前記要求に応じるステップと、
    c.二次サーバーを選択するステップと、
    d.前記一次サーバーから前記二次サーバーへ、前記クライアントセッションにおけるセッション情報を送るステップと、
    e.前記クライアントセッションで要求が受け取られる度に、前記一次及び二次サーバー上のセッション情報を更新するステップと、
    を含むことを特徴とする方法。
  69. 前記クライアント上のクッキー内に前記情報を格納するステップをさらに含む、
    請求項68記載の方法。
  70. 前記一次サーバーが要求を処理できない場合に、新たな一次サーバー上で当該要求に応じるステップをさらに含む、
    請求項68記載の方法。
  71. 前記ハードウェア負荷平衡器内の負荷平衡化ロジックを使って、新たな一次サーバーを選択するステップをさらに含む、
    請求項68記載の方法。
  72. 新たな二次サーバーを選択するステップをさらに含む、
    請求項68記載の方法。
  73. 前記一次サーバーへの要求に一括で応じるステップをさらに含む、
    請求項68記載の方法。
  74. 前記一次サーバーから前記二次サーバーへ、前記クライアントセッションにおけるセッション情報を一括で送るステップをさらに含む、
    請求項68記載の方法。
JP2003514431A 2001-07-16 2002-07-15 セッション複製及びフェイルオーバーのための方法及び装置 Expired - Lifetime JP4295089B2 (ja)

Applications Claiming Priority (5)

Application Number Priority Date Filing Date Title
US30596901P 2001-07-16 2001-07-16
US30599201P 2001-07-16 2001-07-16
US10/000,708 US7409420B2 (en) 2001-07-16 2001-10-31 Method and apparatus for session replication and failover
US10/000,709 US7702791B2 (en) 2001-07-16 2001-10-31 Hardware load-balancing apparatus for session replication
PCT/US2002/022429 WO2003009157A1 (en) 2001-07-16 2002-07-15 Method and apparatus for session replication and failover

Publications (3)

Publication Number Publication Date
JP2004536406A true JP2004536406A (ja) 2004-12-02
JP2004536406A5 JP2004536406A5 (ja) 2006-01-05
JP4295089B2 JP4295089B2 (ja) 2009-07-15

Family

ID=27485017

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2003514431A Expired - Lifetime JP4295089B2 (ja) 2001-07-16 2002-07-15 セッション複製及びフェイルオーバーのための方法及び装置

Country Status (5)

Country Link
EP (1) EP1415236B1 (ja)
JP (1) JP4295089B2 (ja)
CN (1) CN100568214C (ja)
AU (1) AU2002329602B2 (ja)
WO (1) WO2003009157A1 (ja)

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2004178286A (ja) * 2002-11-27 2004-06-24 Fujitsu Ltd 中継装置
JP2007511807A (ja) * 2003-08-14 2007-05-10 オラクル・インターナショナル・コーポレイション サーバ間の透過的なセッション移送
JP2009521741A (ja) * 2005-12-22 2009-06-04 インターナショナル・ビジネス・マシーンズ・コーポレーション Httpセッション負荷の特性を明らかにするデータを収集するための方法及び装置
JPWO2014020742A1 (ja) * 2012-08-02 2016-07-11 株式会社Murakumo 負荷分散装置、情報処理システム、方法およびプログラム
WO2019167421A1 (ja) * 2018-03-01 2019-09-06 株式会社日立製作所 シミュレーター、シミュレーション装置、および、シミュレーション方法

Families Citing this family (20)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7689685B2 (en) 2003-09-26 2010-03-30 International Business Machines Corporation Autonomic monitoring for web high availability
US7941556B2 (en) 2005-02-23 2011-05-10 At&T Intellectual Property I, Lp Monitoring for replica placement and request distribution
CN100391162C (zh) * 2005-04-13 2008-05-28 华为技术有限公司 一种切换服务器的控制方法
EP1770954A1 (en) 2005-10-03 2007-04-04 Amadeus S.A.S. System and method to maintain coherence of cache contents in a multi-tier software system aimed at interfacing large databases
CL2007001655A1 (es) * 2006-06-07 2008-02-22 Qualcomm Inc Aparato de operacion en una red de acceso que comprende un sistema de procesamiento configurado para conservar una copia de un estado de sesion de un terminal de acceso y para efectuar consultas a un maestro de sesiones para determinar si ha cambiado
US7725764B2 (en) * 2006-08-04 2010-05-25 Tsx Inc. Failover system and method
WO2011043892A2 (en) * 2009-10-06 2011-04-14 Motorola Mobility, Inc. Method and system for restoring a server interface for a mobile device
US8335765B2 (en) 2009-10-26 2012-12-18 Amazon Technologies, Inc. Provisioning and managing replicated data instances
CN103051647B (zh) * 2011-10-13 2016-03-30 阿里巴巴集团控股有限公司 一种会话实现的方法、设备及系统
US9148304B2 (en) 2011-11-16 2015-09-29 International Business Machines Corporation Generating production server load activity for a test server
CN102521027B (zh) * 2011-12-02 2013-10-30 华中科技大学 虚拟桌面系统中的窗口界面传输方法
CN103795767B (zh) * 2012-11-02 2017-04-12 阿里巴巴集团控股有限公司 一种跨应用会话信息的同步方法及系统
CN103024058A (zh) * 2012-12-19 2013-04-03 中国电子科技集团公司第十五研究所 Web服务调用方法及系统
CN104283948B (zh) * 2014-09-26 2018-12-07 东软集团股份有限公司 服务器集群系统及其负载均衡实现方法
CN105306598A (zh) * 2015-11-19 2016-02-03 炫彩互动网络科技有限公司 一种可实现负载均衡的远程数据调用方法
CN106933675A (zh) * 2015-12-31 2017-07-07 华为技术有限公司 一种处理任务的方法、管理器、服务器及系统
WO2018164610A1 (en) * 2017-03-06 2018-09-13 Telefonaktiebolaget Lm Ericsson (Publ) Method and control node for managing cloud resources in a communications network
CN108769257B (zh) * 2018-06-28 2021-05-07 新华三信息安全技术有限公司 一种服务器切换方法及装置
CN110191165B (zh) * 2019-05-20 2023-05-12 深圳前海微众银行股份有限公司 一种处理代码执行请求的方法及装置
CN113014629A (zh) * 2021-02-10 2021-06-22 上海牙木通讯技术有限公司 句柄标识的代理转发方法、服务器及计算机可读存储介质

Family Cites Families (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5774668A (en) * 1995-06-07 1998-06-30 Microsoft Corporation System for on-line service in which gateway computer uses service map which includes loading condition of servers broadcasted by application servers for load balancing
US5828847A (en) * 1996-04-19 1998-10-27 Storage Technology Corporation Dynamic server switching for maximum server availability and load balancing
US5933606A (en) * 1997-02-19 1999-08-03 International Business Machines Corporation Dynamic link page retargeting using page headers
US6134673A (en) * 1997-05-13 2000-10-17 Micron Electronics, Inc. Method for clustering software applications
US6199110B1 (en) * 1997-05-30 2001-03-06 Oracle Corporation Planned session termination for clients accessing a resource through a server
JPH11167510A (ja) * 1997-12-04 1999-06-22 Hitachi Ltd レプリケーション方法、レプリケーションツール、および、レプリケーションサーバ
US6195680B1 (en) 1998-07-23 2001-02-27 International Business Machines Corporation Client-based dynamic switching of streaming servers for fault-tolerance and load balancing
KR100729288B1 (ko) 1999-01-28 2007-06-18 웹스펙티브 소프트웨어, 인크. 웹 서버 콘텐츠 복제
AU4717901A (en) 1999-12-06 2001-06-25 Warp Solutions, Inc. System and method for dynamic content routing

Cited By (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2004178286A (ja) * 2002-11-27 2004-06-24 Fujitsu Ltd 中継装置
JP2007511807A (ja) * 2003-08-14 2007-05-10 オラクル・インターナショナル・コーポレイション サーバ間の透過的なセッション移送
JP2009521741A (ja) * 2005-12-22 2009-06-04 インターナショナル・ビジネス・マシーンズ・コーポレーション Httpセッション負荷の特性を明らかにするデータを収集するための方法及び装置
JPWO2014020742A1 (ja) * 2012-08-02 2016-07-11 株式会社Murakumo 負荷分散装置、情報処理システム、方法およびプログラム
WO2019167421A1 (ja) * 2018-03-01 2019-09-06 株式会社日立製作所 シミュレーター、シミュレーション装置、および、シミュレーション方法
KR20200029574A (ko) * 2018-03-01 2020-03-18 가부시키가이샤 히타치세이사쿠쇼 시뮬레이터, 시뮬레이션 장치, 및 시뮬레이션 방법
KR102339747B1 (ko) 2018-03-01 2021-12-16 가부시키가이샤 히타치세이사쿠쇼 시뮬레이터, 시뮬레이션 장치, 및 시뮬레이션 방법

Also Published As

Publication number Publication date
CN100568214C (zh) 2009-12-09
JP4295089B2 (ja) 2009-07-15
CN1549978A (zh) 2004-11-24
EP1415236A1 (en) 2004-05-06
AU2002329602B2 (en) 2008-05-22
WO2003009157A1 (en) 2003-01-30
EP1415236A4 (en) 2009-11-04
EP1415236B1 (en) 2018-04-18
AU2002329602A2 (en) 2003-03-03

Similar Documents

Publication Publication Date Title
JP4295089B2 (ja) セッション複製及びフェイルオーバーのための方法及び装置
US7409420B2 (en) Method and apparatus for session replication and failover
US7702791B2 (en) Hardware load-balancing apparatus for session replication
US11349949B2 (en) Method of using path signatures to facilitate the recovery from network link failures
AU2002329602A1 (en) Method and apparatus for session replication and failover
US5774660A (en) World-wide-web server with delayed resource-binding for resource-based load balancing on a distributed resource multi-node network
US6182139B1 (en) Client-side resource-based load-balancing with delayed-resource-binding using TCP state migration to WWW server farm
EP1963985B1 (en) System and method for enabling site failover in an application server environment
US6430622B1 (en) Methods, systems and computer program products for automated movement of IP addresses within a cluster
US7424547B2 (en) File sharing device and inter-file sharing device data migration method
EP1192545B1 (en) Internet server session backup apparatus
US7254636B1 (en) Method and apparatus for transparent distributed network-attached storage with web cache communication protocol/anycast and file handle redundancy
US20020169889A1 (en) Zero-loss web service system and method
US6934875B2 (en) Connection cache for highly available TCP systems with fail over connections
JP4087271B2 (ja) 代理応答装置およびネットワークシステム
US20050141506A1 (en) Methods, systems and computer program products for cluster workload distribution
US20020087912A1 (en) Highly available TCP systems with fail over connections
JP4658412B2 (ja) データ共有装置
JP2002132568A (ja) 顧客管理システム及び顧客管理方法
JP4123440B2 (ja) オブジェクト指向のネットワーク分散型コンピューティングシステム、その負荷分散装置及びサーバ
CN115632987A (zh) 基于dns与路由发布控制的负载均衡方法

Legal Events

Date Code Title Description
A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20050713

A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20050713

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20080519

A601 Written request for extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A601

Effective date: 20080819

A602 Written permission of extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A602

Effective date: 20080826

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20080919

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20081125

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20090323

A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20090409

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20120417

Year of fee payment: 3

R150 Certificate of patent or registration of utility model

Ref document number: 4295089

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

Free format text: JAPANESE INTERMEDIATE CODE: R150

S111 Request for change of ownership or part of ownership

Free format text: JAPANESE INTERMEDIATE CODE: R313113

S531 Written request for registration of change of domicile

Free format text: JAPANESE INTERMEDIATE CODE: R313531

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20120417

Year of fee payment: 3

R350 Written notification of registration of transfer

Free format text: JAPANESE INTERMEDIATE CODE: R350

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20120417

Year of fee payment: 3

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20130417

Year of fee payment: 4

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20130417

Year of fee payment: 4

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20140417

Year of fee payment: 5

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

EXPY Cancellation because of completion of term