JP3953109B2 - クライアント/サーバ通信システム - Google Patents
クライアント/サーバ通信システム Download PDFInfo
- Publication number
- JP3953109B2 JP3953109B2 JP52931197A JP52931197A JP3953109B2 JP 3953109 B2 JP3953109 B2 JP 3953109B2 JP 52931197 A JP52931197 A JP 52931197A JP 52931197 A JP52931197 A JP 52931197A JP 3953109 B2 JP3953109 B2 JP 3953109B2
- Authority
- JP
- Japan
- Prior art keywords
- server
- client
- web browser
- data stream
- communication
- 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.)
- Expired - Lifetime
Links
- 238000004891 communication Methods 0.000 title claims abstract description 669
- 238000000034 method Methods 0.000 claims abstract description 85
- 230000005540 biological transmission Effects 0.000 claims abstract description 14
- 230000004044 response Effects 0.000 claims description 165
- 230000002085 persistent effect Effects 0.000 claims description 36
- 230000001427 coherent effect Effects 0.000 claims description 20
- 238000012546 transfer Methods 0.000 claims description 16
- 230000009467 reduction Effects 0.000 abstract description 6
- 230000006870 function Effects 0.000 description 71
- 238000010586 diagram Methods 0.000 description 24
- 238000004364 calculation method Methods 0.000 description 15
- 230000008859 change Effects 0.000 description 8
- 230000008901 benefit Effects 0.000 description 6
- 230000008569 process Effects 0.000 description 6
- 230000000694 effects Effects 0.000 description 5
- 238000004590 computer program Methods 0.000 description 4
- 206010009944 Colon cancer Diseases 0.000 description 3
- 125000004122 cyclic group Chemical group 0.000 description 2
- 230000003993 interaction Effects 0.000 description 2
- VKWMGUNWDFIWNW-UHFFFAOYSA-N 2-chloro-1,1-dioxo-1,2-benzothiazol-3-one Chemical compound C1=CC=C2S(=O)(=O)N(Cl)C(=O)C2=C1 VKWMGUNWDFIWNW-UHFFFAOYSA-N 0.000 description 1
- 201000007902 Primary cutaneous amyloidosis Diseases 0.000 description 1
- 230000010267 cellular communication Effects 0.000 description 1
- 238000013500 data storage Methods 0.000 description 1
- 230000007246 mechanism Effects 0.000 description 1
- 238000012544 monitoring process Methods 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 229920001690 polydopamine Polymers 0.000 description 1
- 208000014670 posterior cortical atrophy Diseases 0.000 description 1
- 238000000513 principal component analysis Methods 0.000 description 1
- 238000012545 processing Methods 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/40—Network security protocols
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L69/00—Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
- H04L69/16—Implementation or adaptation of Internet protocol [IP], of transmission control protocol [TCP] or of user datagram protocol [UDP]
- H04L69/161—Implementation details of TCP/IP or UDP/IP stack architecture; Specification of modified or new header fields
- H04L69/162—Implementation details of TCP/IP or UDP/IP stack architecture; Specification of modified or new header fields involving adaptations of sockets based mechanisms
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L69/00—Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
- H04L69/16—Implementation or adaptation of Internet protocol [IP], of transmission control protocol [TCP] or of user datagram protocol [UDP]
Landscapes
- Engineering & Computer Science (AREA)
- Computer Security & Cryptography (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Computer And Data Communications (AREA)
- Information Transfer Between Computers (AREA)
- Communication Control (AREA)
- Financial Or Insurance-Related Operations Such As Payment And Settlement (AREA)
- Pharmaceuticals Containing Other Organic And Inorganic Compounds (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
Description
【発明の属する技術分野】
本発明は、ウェブ・ブラウザとウェブ・サーバ間などのクライアント・サーバ・アプリケーション間の通信に関する。具体的には、本発明は、一方のコンピュータがクライアント・アプリケーションを稼働させ、他方のコンピュータがサーバ・アプリケーションを稼働させている2台のコンピュータ間の低速通信または無線通信リンクを介した通信に関する。
【0002】
【従来の技術】
最近、「情報スーパーハイウェイ」に関して宣伝され、重要視されていることにより、マスコミュニケーション媒体としてのインターネットがますます知られ、受け入れられるようになってきた。複数のネットワークにまたがる通信と対話のための実現可能な媒体としてインターネットがこのように広く認識されるようになったことにより、コンピュータ・ネットワーク間の対話のためのインターネット標準化プロトコルに基づく大規模なユーザ基盤も確立されている。
【0003】
インターネットのパラダイムは、インターネット・クライアント(ブラウザ)がインターネット・サーバと通信するクライアント−サーバ関係のパラダイムである。インターネットへのアクセスを拡大するために、クライアントとサーバが使用する通信プロトコルと言語が標準化されるようになった。これらのプロトコルには、クライアントとサーバの間の通信に使用される通信プロトコルであるハイパーテキスト転送プロトコル(HTTP)と、伝送制御プロトコル/インターネット・プロトコル(TCP/IP)がある。TCP/IPのTCP部分は、コンピュータ間またはアプリケーション間の通信のためのトランスポート固有のプロトコルである。クライアントとサーバが通信する言語も標準化されており、これはハイパーテキスト・マークアップ言語(HTML)と呼ばれる。これらのプロトコルと言語は機械から独立しており、コネクションレスの最善のプロトコルを使用して情報を送信し、各トランザクションは完全に自己完結している。したがって、たとえば、クライアントからの各メッセージにはブラウザの機能に関する情報が含まれ、通信を完結させるために他のどの通信からも独立している。クライアントとサーバの間の通信のこの自己完結性は「ステートレス」通信と呼ばれることがあり、これは所与の通信のためにクライアントとサーバの間で伝送しなければならないデータの量を増大させる。
【0004】
ワールド・ワイド・ウェブのクライアント/サーバ・アプリケーションの関連では、ユーザ・インタフェースとして機能するウェブ・ブラウザがクライアントであろう。ウェブ・ブラウザは適切なウェブ・サーバにユーザ要求を送り、ウェブ・サーバから返されたHTMLデータのフォーマットと表示を行う。また、ウェブ・ブラウザはHTMLデータを評価して、ブラウザが発行する後続のブラウザ要求を必要とすることになるハイパーリンク・ステートメントがHTMLデータに埋め込まれていないかどうかを判断する。ウェブ・サーバはクライアントのためのサーバの役割を果たし、ウェブ・ブラウザ要求を処理し、要求された応答をHTTPデータ・ストリームのHTMLデータ部分として返す。
【0005】
典型的なワールド・ワイド・ウェブ通信の例として、ウェブ・ブラウザがウェブ・サーバに対して「ホーム・ページ」を求める要求を出す事例を用いて、HTTPとHTMLとTCPとウェブ・ブラウザとウェブ・サーバとの間の基本的な関係を例示する。ウェブ・ブラウザのユーザが特定のウェブ・サイトに対して情報を要求すると、ウェブ・ブラウザはウェブ・サーバに所望のウェブ・サイト(この例では「ホーム・ページ」)のユニバーサル・リソース・ロケータ(URL)を指定する「get」要求を送ることによって、ウェブ・サーバの通信を開始する。URLはウェブ・サイトのアドレスの役割を果たし、インターネット全体を通じて固有である。次にウェブ・サーバは、URLで指定されたホーム・ページに対応するHTMLデータを入手してウェブ・ブラウザに供給する。この操作には、インターネット・ウェブ・サーバによるインターネット上での通信がさらに必要となったり、ブラウザが接続しているローカル・ネットワーク内にあるサーバをURLによって指定する必要がある場合がある。次にウェブ・ブラウザはウェブ・サーバからHTTPデータ・ストリームとして受け取ったHTMLデータを評価して、アイコンやイメージなどのハイパーリンクが埋め込まれていないかどうかを調べ、そのようなハイパーリンクがある場合は、そのハイパーリンクのURLを指定する要求を出して、指定されたデータを入手する。このデータはホーム・ページに組み込まれ、ユーザに対して表示されることになる。この単純な例でわかるように、ウェブ・ブラウザによる1つのユーザ入力要求の結果、ユーザ要求に対応するHTMLデータの受信に応答してウェブ・ブラウザが自動的に複数の追加の要求を行うことになる。
【0006】
インターネット・ベースのシステムの基本的な通信構造を第1図に示す。第1図では、ウェブ・ブラウザ10が通信リンク15を介してウェブ・サーバ20と通信する。この通信リンクは典型的にはローカル・エリア・ネットワーク接続、ワイド・エリア・ネットワーク接続、電話回線による接続、または各種接続方法の組合せである。ウェブ・ブラウザ10はTCP/IPを使用してウェブ・サーバ20と通信する。インターネット通信では一般に、ウェブ・ブラウザは、ウェブ・ブラウザとウェブ・サーバの間のTCP/IPリンクを介してウェブ・ブラウザとウェブ・サーバの間で伝送される汎用通信プロトコルHTTPを使用して、ウェブ・サーバと通信する。ウェブ・ブラウザ10とウェブ・サーバ20の間で伝送される実データは前述のHTTPデータ・オブジェクト(たとえばHTMLデータ)である。ウェブ・サーバ20はいくつかのウェブ・ブラウザからウェブ・ブラウザ通信を受け取り、それらを適切なサーバにルーティングするプロキシとすることもできる。
【0007】
ウェブ・ブラウザ/ウェブ・サーバと、それらの共通の情報とトランスポート・プロトコルであるHTMLとHTTPの普及によって、ウェブ技法が情報へのネットワーク・アクセスのための汎用インタフェースとして急速に受け入れられるようになった。さらに、ウェブ・ブラウザとウェブ・サーバの間の通信のためのプロトコルと言語が標準化されているため、ユーザがネットワーク情報にアクセスするためのウェブ・ブラウザとしてNetscape NavigatorTM、NCSA、MosaicTM、WebExplorerTM、または他のどのブラウザを使用するかを問わず、通信プロトコルおよび言語は同じになる。したがって、ウェブ・ブラウザの大規模なインストール済みユーザ基盤と、インタフェースの接続性と、HTTP定義の共通ゲートウェイ・インタフェース(CGI)を使用したウェブ・アプリケーション・サーバの作成の容易さとが組合わさって、ウェブ技法を大規模なクラスの書式ベース・アプリケーションにとってきわめて魅力的なものにしている。
【0008】
インタフェースの普及と受け入れの拡大と同時に、移動体コンピューティングも普及している。ラップトップ、ノートブック、パーソナル・ディジタル/通信アシスタント(PDA/PCA)およびその他の携帯用装置の使用によって、無線通信の需要が増大している。しかし、無線ワイド・エリア・ネットワーク、セルラ通信、およびパケット無線には、ウェブの環境で使用した場合に共通の制約がある。1バイト当たりの高い通信コストと、遅い応答時間と、低帯域幅と、信頼性のなさはすべて、ワールド・ワイド・ウェブのステートレス通信プロトコルに無線技法を使用するのを阻害している。また、ウェブ・プロトコルはステートレスであるため、1要求当たりのデータ量と無線接続を介して伝送される要求の数は、通信が自己完結型でない場合に必要となる量と数よりも大きい。したがって、無線技法またはいずれかの低速通信技法をウェブ技法と組み合わせることは、ウェブ技法の汎用的性質の強さによって無線技法の弱点がさらにひどくなるため実際的ではないと思われる。
【発明が解決しようとする課題】
上記の制約に鑑みて、本発明の目的は、無線通信などの低速通信環境においてワールド・ワイド・ウェブ技法のインストール済みユーザ基盤を利用することである。
【0009】
本発明の他の目的は、ウェブ・ブラウザまたはウェブ・サーバのアプリケーションに変更を加える必要なしに低速または無線通信システムにおいて既存の通信プロトコルおよび言語を使用することである。
【0010】
本発明の他の目的は、必要な通信量を減らし、それによって通信システムのパフォーマンスを向上させる、外部通信リンクを介した通信方法を提供することである。
【0011】
【課題を解決するための手段】
上記およびその他の目的に鑑みて、本発明は、第1のコンピュータ上にあり、ハイパーテキスト転送プロトコル(HTTP)を使用して第1のコンピュータからは遠隔の第2のコンピュータ上にあるウェブ・サーバ・アプリケーションと通信するウェブ・ブラウザ・アプリケーションのパフォーマンスを向上させる方法を提供する。第1のコンピュータにおけるウェブ・ブラウザ・アプリケーションと第2のコンピュータにおけるウェブ・サーバ・アプリケーションとの間の通信の少なくとも1つのセグメントは外部通信リンクを介して行われる。本発明の方法の一実施例は、ウェブ・ブラウザによって発信された通信に対応するHTTPデータ・ストリームを、外部通信リンクで送信される前にインタセプトすることを含む。ウェブ・ブラウザによって開始されたインタセプトされたHTTPデータ・ストリームを、HTTPプロトコルからクライアント/サーバ固有の通信プロトコルに変換し、変換されたウェブ・ブラウザ発信通信をクライアント/サーバ固有のデータ・ストリームとして外部通信リンクを介して第2のコンピュータに送信する。第2のコンピュータは、外部通信リンクを介して送られたクライアント/サーバ固有データ・ストリームを受け取り、クライアント/サーバ固有通信プロトコルで受け取ったクライアント/サーバ固有データ・ストリームをHTTPデータ・ストリームに変換することによって、外部通信リンクを介して受け取ったクライアント/サーバ固有データ・ストリームから、ウェブ・ブラウザからの通信に対応するHTTPデータ・ストリームを再構築する。ウェブ・ブラウザによって発信された通信はHTTPデータ・ストリームとしてウェブ・サーバに供給される。
【0012】
本発明の他の実施例では、変換されたウェブ・ブラウザ発信通信は無線通信リンクを介して伝送される。
【0013】
第1のコンピュータ内にあるキャッシュを使用する本発明の他の態様は、ウェブ・サーバとのウェブ・ブラウザ発信通信に応答してウェブ・ブラウザが受け取るHTTPデータ・ストリームを、第1のコンピュータにあるキャッシュに格納し、ウェブ・サーバとのウェブ・ブラウザ発信通信に対応するクライアント・キャッシュ項目を作成するステップをさらに含む。ウェブ・ブラウザ発信通信に問い合わせて、ウェブ・ブラウザ発信通信に対応するクライアント・キャッシュ項目があるかどうかを判断する。ウェブ・ブラウザ発信通信に対応するクライアント・キャッシュ項目がある場合、ウェブ・ブラウザ発信通信に応答してそのクライアント・キャッシュ項目がHTTPデータ・ストリームとしてウェブ・ブラウザに供給される。
【0014】
本発明の他の態様は、特定のウェブ・ブラウザ情報要求に関連づけられたユーザ定義情報を格納して、第1のコンピュータ内にあるユーザ定義情報が供給されるようにするステップを含む。ウェブ・ブラウザ発信通信に問い合わせて、ウェブ・ブラウザによって要求された情報が、ユーザ定義情報が格納されている要求に対応しているかどうかを判断し、ウェブ・ブラウザ通信がユーザ提示情報が格納されている要求に対応している場合は、ウェブ発信通信に応答してそのユーザ定義格納情報をHTTPデータ・ストリームとしてウェブ・ブラウザに供給する。
【0015】
時間コヒーレント・キャッシュを使用する本発明の他の実施例は、クライアント・キャッシュ項目の作成時刻を格納してクライアント・キャッシュ項目時間レコードを作成するステップと、クライアント・キャッシュ項目時間レコードを評価してウェブ・ブラウザ発信通信に対応するクライアント・キャッシュ項目がウェブ・ブラウザが情報を要求する前の所定のクライアント・コヒーレンシ時間間隔内に作成されたかどうかを判断するステップとを含む。クライアント・キャッシュ項目がウェブ・ブラウザが情報を要求する前の所定のクライアント・コヒーレンシ時間間隔内に作成された場合は、ウェブ・ブラウザ発信通信に応答してクライアント・キャッシュ項目がHTTPデータ・ストリームとしてウェブ・ブラウザに供給される。クライアント・キャッシュ項目はウェブ・ブラウザの複数のインスタンスにわたって維持することもできる。
【0016】
本発明の他の態様は、ブラウザ発信通信に応答してウェブ・サーバから受け取ったHTTPデータ・ストリームを第2のコンピュータ内のキャッシュに格納してサーバ要求キャッシュ・項目を作成するサーバ・キャッシュを含む。ウェブ・ブラウザ発信通信に問い合わせて、ブラウザ発信通信に対応するサーバ要求キャッシュ項目が前にキャッシュに格納されているかどうかを判断する。サーバ・キャッシュ項目が存在する場合、ブラウザ発信通信に関連づけられたサーバ・キャッシュ項目がクライアント/サーバ固有通信プロトコルに変換され、外部通信リンクを介してクライアント/サーバ固有データ・ストリームとして第1のコンピュータに送られる。第1のコンピュータは、外部リンクを介して送られたクライアント/サーバ固有データ・ストリームを入手し、クライアント/サーバ固有通信プロトコルで受け取ったクライアント/サーバ固有データ・ストリームをHTTPデータ・ストリームに変換することによって、外部通信リンクを介して受け取ったクライアント/サーバ固有データ・ストリームからクライアント/サーバ固有データ・ストリームからサーバ要求キャッシュ項目に対応するHTTPデータ・ストリームを再構築する。ウェブ・ブラウザが受け取った情報に対応するサーバ要求キャッシュ項目は、HTTPデータ・ストリームとしてウェブ・ブラウザに供給される。
【0017】
本発明のキャッシュ態様の他の実施例は、ウェブ・ブラウザ発信通信に対応するサーバ要求キャッシュ項目が第2のコンピュータがウェブ・ブラウザ発信通信を受け取る前の所定のクライアント・コヒーレンシ時間間隔内に作成されたかどうかを判断するステップと、サーバ要求キャッシュ項目が所定のクライアント・コヒーレンシ時間間隔内に作成された場合は、ウェブ・ブラウザ発信通信に対応するサーバ要求キャッシュ項目をクライアント/サーバ固有通信プロトコルに変換するステップとを含む。他の実施態様は、ウェブ・ブラウザ発信通信に対応するサーバ・キャッシュ項目と同じウェブ・ブラウザ発信通信に対応するクライアント・キャッシュ項目が存在するかどうかを判断するステップを含む。第2のコンピュータがウェブ・ブラウザ発信通信を受け取った時点とウェブ・ブラウザ発信通信に対応するサーバ要求キャッシュ項目が作成された時点との間の時間間隔を計算して項目エージ・データを求める。2つのキャッシュ項目が同じ場合は、ウェブ・ブラウザ発信通信に対応するサーバ・キャッシュ項目の項目エージ・データを含むコヒーレント項目応答を外部通信リンクを介して第1のコンピュータに送る。ウェブ・ブラウザ発信通信に対応するクライアント・キャッシュ項目時間レコードは、第1のコンピュータの現在時刻から、コヒーレント項目応答から受け取った項目エージ・データを差し引くことによって更新される。
【0018】
差分を計算して外部通信リンク上のデータを削減する本発明の実施例では、ウェブ・ブラウザ発信通信は共通ゲートウェイ・インタフェース(CGI)要求に対応する。インタセプトされたCGI要求に問い合わせて、インタセプトされたCGI要求に対応するクライアント・ベース・キャッシュ項目が存在するかどうかを判断し、クライアントCGIベース書式を提供する。インタセプトされたCGI要求に問い合わせて・インタセプトされたCGI要求に対応するサーバ・ベース・キャッシュ項目が存在するかどうかも判断し、サーバCGIベース書式を提供する。共通ゲートウェイ・インタフェース(CGI)に対する要求であるブラウザ発信通信に応答してウェブ・サーバから受け取ったHTTPデータ・ストリームを第2のコンピュータにあるキャッシュに格納してサーバ・ベース・キャッシュ項目を作成し、CGIに対する要求であるブラウザ発信通信に応答してウェブ・ブラウザに提供されるHTTPデータ・ストリームを第1のコンピュータにあるキャッシュに格納してクライアント・ベース・キャッシュ項目を作成する。インタセプトされたCGI要求に応答してウェブ・サーバによって発信された通信に対応するHTTPデータ・ストリームを、外部通信リンクで伝送される前にインタセプトする。インタセプトされたCGI応答をサーバCGIベース書式と比較して、インタセプトされたCGI応答とサーバCGIベース書式との差に対応するCGI差分データを求め、そのCGI差分データを外部通信リンクを介してクライアント/サーバ固有データ・ストリームとして第1のコンピュータのウェブ・ブラウザに送る。第2のコンピュータによって外部通信リンクを介して送られたクライアント/サーバ固有データ・ストリームを第1のコンピュータが獲得し、クライアントCGIベース書式を外部通信リンクを介して受け取ったCGI差分データと結合してインタセプトされたCGI応答に対応するHTTPデータ・ストリームを作成することによって、ウェブ・サーバからの通信に対応するHTTPデータ・ストリームが外部通信リンクを介して受信したクライアント/サーバ固有データ・ストリームから再構築される。ウェブ・サーバによって発信された通信はウェブ・ブラウザにHTTPデータ・ストリームとして供給される。
【0019】
本発明の差分計算態様のベース変更計算実施例は、サーバCGIベース書式がクライアントCGIベース書式と同じかどうかを判断し、サーバCGIベース書式とCGI差分データを外部通信リンクを介してクライアント/サーバ固有データ・ストリームとしてウェブ・ブラウザに送る。サーバCGIベース書式を、外部通信リンクを介して受け取ったCGI差分データと結合してインタセプトされたCGI応答に対応するHTTPデータ・ストリームを作成することによって、外部通信リンクを介して受け取ったクライアント/サーバ固有データ・ストリームから、ウェブ・サーバからの通信に対応するHTTPデータ・ストリームを再構築する。CGI要求に対応するクライアントCGIベース書式は、受け取ったサーバCGIベース書式をCGI要求に対応するクライアント・ベース・キャッシュ項目として格納することによって更新される。
【0020】
本発明の他の態様では、サーバCGIベース書式は、サーバCGIベース書式とCGI応答との間の差が事前定義差分しきい値より大きいかどうかを判断することによって更新することもできる。CGI差分データおよび比較が第1のコンピュータに送られる更新されたサーバCGIベース書式を使用する場合、CGI要求に対応するサーバ・ベース・キャッシュ項目としてウェブ・サーバから受け取ったCGI応答を格納することによってCGI要求に対応するサーバCGIベース書式を更新することができる。
【0021】
本発明のプロトコル縮小態様では、外部通信リンクを介して第1のコンピュータと第2のコンピュータの間に持続的接続を確立する。この持続的接続は、すべてのウェブ・ブラウザ発信通信が完了するまで維持される。持続的接続が維持されている間に複数のウェブ・ブラウザ発信通信がインタセプトされ、多重化されて外部通信リンクに送られる。次にクライアント/サーバ固有データ・ストリームを多重化解除して複数のHTTPデータ・ストリームを作成し、その複数のHTTPデータ・ストリームをウェブ・サーバに送る。
【0022】
本発明のヘッダ削減態様は、外部通信リンクを介して第2のコンピュータに、第1のコンピュータの所定の特性に対応するコンピュータ固有情報を供給し、第1のコンピュータの所定の特性に対応するコンピュータ固有情報を格納して、ブラウザ・ヘッダ情報を提供する。第1のコンピュータはウェブ・ブラウザ発信通信からこのコンピュータ固有情報を取り除き、第2のコンピュータは格納されたブラウザ・ヘッダ情報をクライアント/サーバ固有データ・ストリームと結合してHTTPデータ・ストリームを作成する。
【0023】
本発明の他の態様では、ウェブ・サーバによって発信された通信に対応するHTTPデータ・ストリームが、HTTPデータ・ストリームを外部通信リンクで送る前にキャプチャされ、HTTPプロトコルからクライアント/サーバ固有通信プロトコルに変換される。変換されたウェブ・サーバ発信通信は外部通信リンクを介してクライアント/サーバ固有データ・ストリームとしてウェブ・ブラウザに送られる。第1のコンピュータは外部通信リンクを介して送信されたクライアント/サーバ固有データ・ストリームを獲得し、クライアント/サーバ固有通信プロトコルで受け取ったクライアント/サーバ固有データ・ストリームをHTTPデータ・ストリームに変換することによって、ウェブ・サーバからの通信に対応するHTTPデータ・ストリームを外部通信リンクを介して受け取ったクライアント/サーバ固有データ・ストリームから再構築する。ウェブ・サーバによって発信された通信はHTTPデータ・ストリームとしてウェブ・ブラウザに供給される。
【0024】
本発明のヘッダ削減態様の他の実施例は、第1のコンピュータに外部通信リンクを介して第2のコンピュータの所定の特性に対応するコンピュータ固有情報を供給するステップと、第2のコンピュータの所定の特性に対応するコンピュータ固有情報を格納してサーバ・ヘッダ情報を提供するステップとを含む。第2のコンピュータは、ウェブ・サーバ発信通信からコンピュータ固有情報を取り除き、第1のコンピュータはサーバ・ヘッダ情報をクライアント/サーバ固有データ・ストリームと結合してHTTPデータ・ストリームを作成する。
【0025】
本発明のプロトコル縮小態様の他の実施例では、外部通信リンクを介して第1のコンピュータと第2のコンピュータとの間に持続的接続を確立する。この持続的接続を、全てのウェブ・サーバ発信通信が完了するまで維持する。持続的接続を維持している間に複数のウェブ・サーバ発信通信をインタセプトし、外部通信リンクに多重化して送る。クライアント/サーバ固有データ・ストリームを多重化解除して複数のHTTPデータ・ストリームを作成し、その複数のHTTPデータ/ストリームをウェブ・サーバに供給することができる。
【0026】
本発明の他の実施例は、第1のコンピュータ上にあり、第1のコンピュータから遠隔にある第2のコンピュータ上にあるサーバ・アプリケーションと通信するクライアント・アプリケーションを有するクライアント/サーバ・システムのパフォーマンスを向上させる方法を提供する。クライアント・アプリケーションとサーバ・アプリケーションは、クライアントとサーバの間の通信のためにクライアント/サーバから独立した通信プロトコル(すなわちステートレス)を使用し、第1のコンピュータにあるクライアント・アプリケーションと第2のコンピュータにあるサーバ・アプリケーションとの間の通信の少なくとも1セグメントが外部通信リンクを介して行われる。この方法は、クライアント/サーバ独立通信プロトコルで遠隔クライアントから発信された通信を、その通信が外部通信リンクで送られる前にインタセプトするステップを含む。クライアントから発信されたインタセプトされた通信は、第2のクライアント/サーバ固有通信プロトコルに変換され、外部通信リンクを介して伝送される。第2のコンピュータが、外部通信リンクを介して送られた通信を受信し、外部通信リンクを介して受信した通信をクライアント/サーバ固有通信プロトコルからクライアント/サーバ独立通信プロトコルに変換する。遠隔クライアントによって発信された通信はクライアント・サーバ独立通信プロトコルでサーバに共有される。本発明の他の態様は、サーバからクライアント/サーバ独立通信プロトコルで発信された通信を、外部通信リンクで送信する前にインタセプトするステップを組み込む。インタセプトされた通信は、第2のクライアント/サーバ固有通信プロトコルに変換され、外部通信リンクを介して送信される。この通信を外部通信リンクで第1のコンピュータが受け取り、クライアント/サーバ固有通信プロトコルからクライアント・サーバ独立プロトコルに変換する。サーバによって発信された通信はクライアント/サーバ独立通信プロトコルで遠隔クライアントに供給される。
【0027】
当業者ならわかるように、本発明の前述の態様は装置またはコンピュータ可読プログラム手段としても提供することができる。
【0028】
【発明の実施の形態】
以下に、本発明の好ましい実施例が図示されている添付図面を参照しながら本発明について詳述する。しかし、本発明は多くの異なる態様で実施することができ、本明細書に記載の実施例に限定されるものと解釈してはならない。これらの実施例は、本開示を綿密かつ十全なものとし、本発明の範囲を当業者に完全に伝えるために示すものである。全体を通じて同様の番号は同様の要素を指す。
【0029】
第3図ないし第10図と第13図ないし第17−2図は、本発明による方法およびシステムを示すフローチャートである。フローチャートの各ブロックと、フローチャートのブロックの組合せは、コンピュータ・プログラム命令によって実施することができることがわかるであろう。これらのコンピュータ・プログラム命令は、コンピュータまたはその他のプログラム式装置にロードし、それによってコンピュータまたはその他のプログラム式装置上で実行される命令がフローチャートの1つまたは複数のブロックに指定されている機能を実施する手段を生じさせるように機械を作り出すことができる。これらのコンピュータ・プログラム命令を、コンピュータまたはその他のプログラム式装置に対して特定の方式で機能するように指示することができるコンピュータ可読メモリに格納し、それによってコンピュータ可読メモリに格納された命令がフローチャートの1つまたは複数のブロックに指定されている機能を実施する命令手段を含む製品を作り出すようにすることができる。また、コンピュータ・プログラム命令をコンピュータまたはその他のプログラム式装置にロードして、コンピュータまたはその他のプログラム式装置上で一連の操作ステップが行われるようにし、コンピュータまたはその他のプログラム式装置上で実行される命令がフローチャートの1つまたは複数のブロックに指定されている機能を実施するステップを提供するようにコンピュータ実施プロセスを作り出すこともできる。
【0030】
したがって、フローチャートのブロックは、指定された機能を実行する手段の組合せと、指定された機能を実行するステップの組合せとに対応する。また、フローチャートの各ブロックと、フローチャートのブロックの組合せは、指定された機能またはステップを実行する特定用途向けハードウェア・ベースのコンピュータ・システムによって、または特定用途向けハードウェアとコンピュータ命令の組合せによって実施することができることがわかるであろう。
【0031】
第2図に、本発明の一実施例を示す。第2図に示すように、ウェブ・ブラウザ10はクライアント側インタセプト・モジュール30と通信する。ウェブ・サーバ20はサーバ側インタセプト・モジュール40と通信する。次にクライアント側インタセプト・モジュール30が通信リンク35を介してサーバ側インタセプト・モジュール40と通信する。ウェブ・ブラウザ10とクライアント側インタセプト・モジュール30は、第1のコンピュータ5に組み込むことができる。サーバ側インタセプト・モジュール40とウェブ・サーバ20は第2のコンピュータ6に組み込むことができる。第1のコンピュータ5と第2のコンピュータ6は外部通信リンク35を介して通信する。
【0032】
ウェブ・ブラウザ10は、ハイパーテキスト転送プロトコル(HTTP)とハイパーテキスト・マークアップ言語(HTML)を使用して、やはりHTTPとHTMLを使用するインターネット・ウェブ・サーバ20と通信するインターネット・ウェブ・ブラウザであることが好ましい。動作中、ウェブ・ブラウザ10はHTTPデータ・ストリームを出力し、それがクライアント側インタセプト・モジュール30によってインタセプトされる。クライアント側インタセプト・モジュール30によるHTTPデータ・ストリームのインタセプトは、クライアント側インタセプト・モジュール30が127.0.0.1のようなネットワーク番号127を有するIPアドレスにあるTCP/IPループバック機構1を使用して行うことができる。次に、クライアント側インタセプト・モジュール30はHTTPデータ・ストリームをクライアント/サーバ固有プロトコルに変換または変形し、そのクライアント/サーバ固有データ・ストリームを外部通信リンク35に送る。サーバ側インタセプト・モジュール40はこのクライアント/サーバ固有データ・ストリームを受け取り、ウェブ・ブラウザ発信通信に対応する元のHTTPデータ・ストリームを再構築する。この再構築されたHTTPデータ・ストリームは次にウェブ・サーバ20に転送される。ウェブ・サーバ20はインターネット・ウェブ・サーバの通常の方式でHTTPデータ・ストリームに応答する。当業者ならわかるように、ウェブ・サーバ20は複数のブラウザがインターネットに接続することができるようにするプロキシとすることもできる。
【0033】
たとえば特定のURLホーム・ページを求めるブラウザ要求に応答してウェブ・サーバ20がウェブ・ブラウザ10に送る情報を受け取ると、ウェブ・サーバ20はウェブ・ブラウザ10に送る通信に対応するHTTPデータ・ストリームを出力する。このウェブ・サーバ発信通信はサーバ側インタセプト・モジュール40によってインタセプトされ、クライアント/サーバ固有データ・ストリームに変換される。次に、ウェブ・サーバ発信通信に対応するクライアント/サーバ固有データ・ストリームは外部通信リンク35で第2のコンピュータから第1のコンピュータに送られる。このクライアント/サーバ固有データ・ストリームをクライアント側インタセプト・モジュール30が受け取り、ウェブ・サーバ発信通信に対応するHTTPデータ・ストリームが再構築され、ウェブ・ブラウザ10に供給される。
【0034】
本発明の特定の実施例では、外部通信リンク35は無線通信リンクである。その場合、ユーザにとって受容可能なシステム・パフォーマンスを得るために、外部通信リンク35を介する通信量を、通信リンク35を介して伝送しなければならい通信の頻度と情報量の両方について減らすことが望ましい。したがって、本発明はキャッシング技法と、差分計算技法と、プロトコル縮小技法とを使用して、外部通信リンク35を介する必要通信量を最小限にする。これらの技法は、HTTPのステートレスまたは確率論的プロトコルを、クライアントおよびサーバに固有の情報を使用するクライアント/サーバ固有プロトコルに変換して通信の量と頻度を減らすことによって実現される。
【0035】
本発明について、単一のウェブ・ブラウザ・アプリケーションと単一のウェブ・サーバ・アプリケーションに関して説明するが、当業者ならわかるように、本発明の利便および利点は、単一のウェブ・サーバに関連づけられた複数のウェブ・ブラウザを使用した場合にも得ることができる。したがって、本発明の方法、装置、およびプログラム製品は、各ブラウザがクライアント側インタセプト・モジュールと通信する複数のブラウザと共に使用することもでき、その場合それらのクライアント側インタセプト・モジュールはウェブ・サーバまたはウェブ・プロキシのサーバ側インタセプト・モジュールと通信することになる。
【0036】
本発明の一実施例では、クライアント側インタセプト・モジュール30とサーバ側インタセプト・モジュール40の情報がキャッシュ格納機能を有する。第1のコンピュータにあるクライアント・キャッシュには、ウェブ・ブラウザ発信通信に応答してウェブ・ブラウザが受け取るHTTPデータ・ストリームが格納される。第2のコンピュータにあるサーバ・キャッシュには、ブラウザ発信通信に応答してウェブ・サーバから受け取るHTTPデータ・ストリームが格納される。
【0037】
当業者ならわかるように、第1のコンピュータまたは第2のコンピュータにあるキャッシュは、コンピュータの特定のハードウェア構成に基づく任意の容量とすることができる。これらのキャッシュには、各通信について、通信のURL、巡回冗長検査(CRC)などの通信内容に基づく、固有識別子、キャッシュ項目作成またはリフレッシュが行われた時刻を示すデータ格納時刻(SDT)、および通信のデータを含む情報が格納される。したがって、キャッシュに格納されている各通信についてキャッシュ項目のディレクトリを作成することができる。さらに、所与のハードウェア構成で使用可能な資源は限れているため、第1のコンピュータおよび第2のコンピュータにあるキャッシュを維持するために当業者に周知の任意の数のキャッシング技法を使用することができる。したがって、たとえば、新しい項目の追加によってユーザ定義キャッシュサイズを超える場合、キャッシュは最も古いディレクトリ項目を無効化し、無効化された項目の代わりに新しい項目を追加することができる。さらに、ウェブ・ブラウザ・アプリケーションまたはウェブ・サーバ・アプリケーションの複数のインスタンスにわたって、あるいは第1または第2のコンピュータの電源投入サイクルについてさえもキャッシュ項目を維持して持続キャッシュを作成することができる。
【0038】
以下に、クライアント側インタセプト・モジュール30とサーバ側インタセプト・モジュール40の動作を示すフローチャートである第3図ないし第6図を参照しながら本発明の一態様によるキャッシング構造について説明する。
【0039】
具体的に第3図を参照すると、ブロック100はクライアント側インタセプト・モジュール30がウェブ・ブラウザ10から要求を受け取ったことを示している。この要求は、HTTPデータ・ストリームの形式をとることができる。ブロック105に示すように、クライアント側インタセプト・モジュール30は着信した要求のユニフォーム・リソース・ロケータ(URL)を検査する。クライアント側インタセプト・モジュール30はURLから、ウェブ・ブラウザ発信要求に対応する情報が前に第1のコンピュータにある第1のクライアント・キャッシュに格納されているかどうかを判断する。
【0040】
URLに対応する情報が前にクライアント・キャッシュに格納されていなかった場合、ブロック106に示す操作がクライアント側インタセプト・モジュールによって行われる。クライアント側インタセプト・モジュール30は外部通信リンク35でサーバ側インタセプト・モジュール40に要求を送る。
【0041】
しかし、ブロック105に示すようにウェブ・ブラウザ発信通信に問い合わせたときに、ウェブ・ブラウザ発信通信に対応するクライアント・キャッシュ項目が存在する場合、最も単純な実施例では、その情報がHTTPデータ・ストリームとしてウェブ・ブラウザに供給される。しかし、第3図に示すように、本発明の好ましい実施例は、ウェブ・ブラウザ発信通信に対応するキャッシュ項目に対して本明細書でコヒーレンシ間隔検査と呼ぶ操作を行う。この操作は第3図のブロック110に示されている。
【0042】
クライアント側インタセプト・モジュールのコヒーレンシ間隔はユーザ定義とすることができ、キャッシュ項目が陳腐化し、存在はしていてもウェブ・サーバに対してウェブ・ブラウザ発信通信に対応する情報を要求することによって最新化しなければならなくなるまでのキャッシュ項目が存在することができる時間の長さである。ブロック110に示すコヒーレンシ間隔検査は、現在日時をウェブ・ブラウザ発信通信に対応するキャッシュ項目のSDTとユーザによって指定されたコヒーレンシ間隔との和と比較することによって行うことができる。現在日時がこの和より大きい場合、ウェブ・ブラウザ発信通信に対応するキャッシュ内に格納されている情報は陳腐化しており、ブロック110の「No」に分岐する。しかし、現在日時がSDTにユーザ定義コヒーレンシ間隔を足した和よりも小さい場合は、ブロック110で「Yes」に分岐し、ブロック111に示すように、そのキャッシュ項目がHTTPデータ・ストリームとしてブラウザに供給される。したがって、第3図のブロック100でクライアント側インタセプト・モジュール30が受け取ったブラウザ発信通信が完了する。
【0043】
ブロック110に示すコヒーレンシ間隔検査によって、第1のコンピュータにあるキャッシュ項目が陳腐化していると判断された場合、サーバ側インタセプト・モジュール40に対して要求を行い、第2のコンピュータにあるキャッシュ項目のコヒーレンシを検査する。この操作は第3図のブロック112に示されている。これは、外部通信リンク35を介してサーバ側インタセプト・モジュール40に、特定のクライアント側インタセプト・モジュール30のコヒーレンシ間隔と、ウェブ・ブラウザ10によって発信されたHTTP要求と、ウェブ・ブラウザ発信通信のURLに対応するクライアント・キャッシュの内容を示す固有の標識を供給することによって行われる。好ましい実施例では、この固有の標識はキャッシュ項目の巡回冗長検査(CRC)である。
【0044】
次に第5図を参照すると、外部通信リンク35を介してクライアント側インタセプト・モジュール30から受け取った情報に応答したサーバ側インタセプト・モジュール操作が示されている。サーバ側インタセプト・モジュール40がクライアント側インタセプト・モジュールから要求を受け取ると、サーバ側インタセプト・モジュール40は所定のクライアント・コヒーレンシ時間間隔と、クライアント・キャッシュ項目のCRC値と、ウェブ・ブラウザによって発信されたHTTP要求を受け取る。この情報の受信は、第5図のブロック120に示されている。
【0045】
クライアント側インタセプト・モジュール30から情報を受け取った後、サーバ側インタセプト・モジュール40は第2のコンピュータにあるそのサーバ・キャッシュを検査して、ウェブ・ブラウザによって発信されたHTTP要求のURLに対応するサーバ・キャッシュ項目が存在するかどうかを判断する。ブロック125に示すようにウェブ・ブラウザ発信通信に問い合わせた後、サーバ側インタセプト・モジュール40が、ウェブ・ブラウザ発信通信によって要求された情報に対応するキャッシュ項目が存在すると判断した場合、ブロック125で「Yes」分岐をとる。次に、サーバ側インタセプト・モジュール40はSSIモジュール40の現在日時を、ウェブ・ブラウザ発信通信によって要求された情報に対応するサーバ・キャッシュ項目のSDTとクライアント側インタセプト・モジュールから受け取った所定のクライアント・コヒーレンシ時間間隔との和と比較する。
【0046】
現在日時がサーバ・キャッシュ項目のSDTとコヒーレンシ間隔との和より小さい場合、第5図のブロック130の「Yes」経路をとる。次にサーバ側インタセプト・モジュール40はサーバ・キャッシュ項目のCRCとクライアント・キャッシュのCRCとを比較して、その2つのキャッシュ項目が同じかどうかを判断する。2つのキャッシュ項目が同じ場合、ブロック135の「Yes」分岐をとり、ブロック136に示すように、「コヒーレント」応答がクライアント側インタセプト・モジュール30に送られる。
【0047】
ブロック135の条件で、CRCが等しくないと判断された場合、クライアント・キャッシュに入っている情報とサーバ・キャッシュに入っている情報は同じでなく、ブロック137に示すようにサーバ側インタセプト・モジュールは外部通信リンクを介して第1のコンピュータにサーバ・キャッシュ項目を送る。サーバ・キャッシュ項目をクライアント側インタセプト・モジュール30に送信する際に、サーバ側インタセプト・モジュールはその項目を、サーバ・キャッシュ項目のCRCと、サーバ・キャッシュ項目データと、サーバ・キャッシュ項目のエージとを含むクライアント固有通信プロトコルに変換する。サーバ・キャッシュ項目のエージは、現行日時からキャッシュ項目のSDTを引くことによって計算する。
【0048】
第5図に関して最後に、SDTに所定のクライアント・コヒーレンシ時間間隔を足した和が現在日時よりも小さいか、またはウェブ・ブラウザ発信通信のURLに対応する項目がない場合、それぞれブロック130の「No」経路またはブロック125の「No」経路がとられる。したがって、ブロック126の操作が行われ、サーバ側インタセプト・モージュール40がサーバにウェブ・ブラウザ発信通信をHTTPデータ・ストリームとして送ることになる。サーバ側インタセプト・モジュール40がウェブ・ブラウザ発信通信をサーバにHTTPデータ・ストリームとして送らなければならない場合、サーバ側インタセプト・モジュール40は第6図の操作を実行する。
【0049】
第6図のブロック140に示すように、ウェブ・ブラウザ発信通信に応答して、サーバ側インタセプト・モジュールがウェブ・サーバ20からHTTPデータ・ストリームを受け取る。HTTPデータ・ストリームを受け取ると、サーバ側インタセプト・モジュール40はHTTPデータ・ストリームのCRCを計算し、HTTPデータ・ストリームを一時的に格納する。次に、ブロック145に示すように、サーバ側インタセプト・モジュールはHTTPデータ・ストリームに問い合わせて、HTTPデータ・ストリームのURLに対応するサーバ・キャッシュ項目が存在するかどうかを判断する。そのような項目が存在しない場合、ブロック145の「Yes」経路が実行される。次にサーバ側インタセプト・モジュール40は、ブロック150に示すように、ウェブ・サーバ20から受け取ったHTTPデータ・ストリームの最も最近に計算されたCRCを、ウェブ・サーバ発信応答通信のURLに対応するサーバ・キャッシュ項目のCRCと比較する。CRCが同じ場合、ブロック150の「Yes」分岐が行われる。サーバ側インタセプト・モジュール40はブロック151に示すようにサーバ・キャッシュ項目のSDT項目を更新し、ブロック152に示すようにウェブ・サーバ20によって受信されたHTTPデータ・ストリームを一時格納域から除去する。
【0050】
CRC比較の結果によって、サーバ・キャッシュ項目がウェブ・サーバ20から受け取ったHTTPデータ・ストリームと異なることが示された場合、ブロック150の「No」経路が行われる。サーバ側インタセプト・モジュール40はブロック153に示すようにサーバ・キャッシュから既存のデータを除去し、次にブロック154に示すようにより新しい方の情報によってサーバ・キャッシュを更新する。ブロック154に示すように、この更新にはサーバ・キャッシュにウェブ・サーバ通信のCRCを格納するステップと、キャッシュ項目の一部として現在日時をキャッシュ項目のSDTとして格納するステップと、HTTPデータ・ストリームを格納するステップとが含まれる。サーバ・キャッシュ項目を更新するかどうか、またはサーバ・キャッシュ項目がウェブ・サーバ20から受け取ったHTTPデータ・ストリームと同じであることが判明したかどうかを問わず、いずれの場合もサーバ側インタセプト・モジュールは次にサーバ・キャッシュ項目がウェブ・ブラウザ発信通信に対応するクライアント・キャッシュ項目と同じかどうかを判断する。この操作をブロック155に示す。
【0051】
サーバ側インタセプト・モジュール40が、ウェブ・サーバ20から受け取った応答に対応するキャッシュ項目が存在しないと判断した場合、ブロック145の「No」経路がとられる。ブロック146に示すように、ウェブ・サーバからの応答のURLを格納し、ウェブ・サーバからの応答のCRCを格納し、HTTPデータ・ストリームを格納し、SDTとして現在日時を格納することによって、サーバ・キャッシュ項目が作成される。ウェブ・ブラウザ発信通信に対応するキャッシュ項目を作成した後、サーバ側インタセプト・モジュール40は次に、ブロック155に示すように、再度、このサーバ・キャッシュ項目のCRCを対応するクライアント・キャッシュのCRCと比較する。
【0052】
サーバ・キャッシュ項目とクライアント・キャッシュ項目との比較の結果によって、キャッシュ項目が同じであることがわかった場合、ブロック155の「Yes」分岐がとられ、ブロック156の操作が行われる。ブロック156に示すように、サーバ側インタセプト・モジュール40がクライアント側インタセプト・モジュール30に応答を送る。サーバ側インタセプト・モジュール40は、クライアント側インタセプト・モジュールにコヒーレント応答を送り、ゼロのエージを送ることによって、サーバ要求キャッシュ項目をクライアント/サーバ固有データ・ストリームに変形する。
【0053】
サーバ側インタセプト・モジュール40が、クライアント・キャッシュ項目がウェブ・ブラウザ発信通信に対応するサーバ・キャッシュ項目と同じではないと判断した場合、ブロック155の「No」分岐がとられ、ブロック157の操作が行われる。ブロック157に示すように、サーバ側インタセプト・モジュール40は、サーバ・キャッシュ項目をクライアント/サーバ固有データ・ストリームに変換または変形する。このデータ・ストリームには、サーバ・キャッシュ項目のCRCと、サーバ・キャッシュ項目HTTPデータ・ストリームと、キャッシュ項目のゼロに設定されたエージとが含まれる。このクライアント/サーバ固有通信は次に外部通信リンク35を介してクライアント側インタセプト・モジュール30に送信される。
【0054】
サーバ側インタセプト・モジュールから通信を受け取ったときのクライアント側インタセプト・モジュール30の機能について、第4図を参照しながら以下に説明する。ブロック160に示すように、クライアント側インタセプト・モジュール30は外部通信リンク35を介して送信されたクライアント/サーバ固有データ・ストリームを受信または入手する。クライアント側インタセプト・モジュールは次に、ブロック165に示すように、サーバ側インタセプト・モジュール40からどのようなタイプの応答を受け取ったかを判断する。サーバ側インタセプト・モジュール40が、クライアントがクライアント・キャッシュ項目がコヒーレントであること、すなわちサーバ・キャッシュ項目とクライアント・キャッシュ項目が同じであることを示している場合、ブロック166に示す操作が行われる。ブロック166に示すように、クライアント側インタセプト・モジュール30は、現在日時とサーバ側インタセプト・モジュール40から受け取ったエージとの差を使用してウェブ・ブラウザ発信通信に対応するクライアント・キャッシュ項目のSDTを更新する。したがって、本発明は、第1のコンピュータ5と第2のコンピュータ6の2つのクロックの同期をとらずに、第1のコンピュータのキャッシュ項目のコヒーレンシ時間を更新して第2のコンピュータの新しい方のデータを反映させたことになる。ウェブ・ブラウザ発信通信に対応するクライアント・キャッシュ項目のSDTを更新した後、クライアント側インタセプト・モジュール30はクライアント・キャッシュ項目をウェブ・ブラウザ10にHTTPデータ・ストリームとして転送する。この操作をブロック174に示す。
【0055】
しかし、クライアント側インタセプト・モジュール30が応答のタイプがデータまたはデータ・ストリーム応答であると判断した場合は、ブロック165から「ストリーム」経路をとり、ブロック167の操作が行われる。クライアント側インタセプト・モジュール30はHTTPデータ・ストリームを受け取り、そのデータを一時的に格納する。次に、第4図のブロック170に示すように、クライアント側インタセプト・モジュール30は、ウェブ・ブラウザ発信通信に対応するキャッシュ項目が存在するかどうかを判断する。キャッシュ項目が存在する場合、ブロック170の「Yes」経路をとって、ブロック171に示すように、既存のキャッシュ項目がフラッシュされる。クライアント側インタセプト・モジュールは次に、サーバ側インタセプト・モジュール40から受け取ったHTTPデータ・ストリームのCRCを格納し、現在日時とサーバ側インタセプト・モジュール40から受け取ったエージとの差をSDTとして格納し、HTTPデータ・ストリームを格納することによって、ウェブ・ブラウザ発信通信に対応するクライアント・キャッシュ項目を更新する。この操作をブロック172に示す。
【0056】
ウェブ・ブラウザ発信通信に対応するキャッシュ項目が存在しない場合、ブロック170の「No」経路が取られる。ブロック173に示す操作を行うことによってクライアント・キャッシュ項目が作成される。ブロック173に示すように、クライアント側インタセプト・モジュール30は、サーバ側インタセプト・モジュール40から受け取ったHTTPデータ・ストリームのURLを格納し、サーバ側インタセプト・モジュール40から受け取ったHTTPデータ・ストリームのCRCを格納し、HTTPデータ・ストリームを格納することによって、クライアント・キャッシュ項目を作成する。また、クライアント側インタセプト・モジュール30は、サーバ側インタセプト・モジュール40から外部通信リンク35を介して受け取ったエージSDTを現在日時から引くことによって、SDTを更新または格納する。
【0057】
しかし、ブロック166、172、173のいずれの操作によってクライアント・キャッシュ項目が作成されるかを問わず、クライアント側インタセプト・モジュールはクライアント・キャッシュ項目をHTTPデータ・ストリームとしてウェブ・ブラウザ10に転送または供給する。これらの操作は第4図のブロック174に示されている。
【0058】
当業者ならわかるように、クライアント・キャッシュとサーバ・キャッシュは、メモリによって、またはハード・ディスク、読書きCD−ROM、光ディスク、その他の格納技法などの大容量格納装置によって実装することができる。さらに、当業者ならわかるように、クライアント側インタセプト・モジュールとサーバ側インタセプト・モジュールは、ソフトウェア、ハードウェア、またはその組合せによって実装することができる。
【0059】
特定の第1または第2のコンピュータにあるキャッシュについて言及したが、当業者ならわかるように、本発明の利点は、キャッシュが第1のコンピュータにではなく、単に外部通信リンクの第1のコンピュータと同じ側にある場合でも得られる。したがって、ハードウェア・キャッシュをクライアント・キャッシュとして機能する第1のコンピュータの外部に実装し、高速通信によって第1のコンピュータに接続することもでき、しかもその場合でも、キャッシュが外部通信リンクの第1のコンピュータと同じ側にある限り、本発明の利点が得られる。
【0060】
本発明の他の実施例では、サーバ側インタセプト・モジュール40は、ウェブ・サーバ20から受け取ったHTTPデータ・ストリームのコピーを維持せず、単にその通信のディレクトリ項目を維持するに過ぎない。このディレクトリ項目には、通信のURLと、HTTPデータ・ストリームのために計算されたCRCと、HTTPデータ・ストリームをウェブ・サーバから受け取った時刻と、その通信のSDTとが含まれ、このSDTはCRCを計算した時刻に設定することができる。このような場合、クライアント側インタセプト・モジュール30はサーバ側インタセプト・モジュール40に対して、サーバ側インタセプト・モジュールがCRCとSDTを維持していたURLに対応する通信を求める要求を送り、次にサーバ側インタセプト・モジュール30はクライアント側インタセプト・モジュール30から受け取ったCRCを検査して、それが指定されたURLの最新のHTTPデータ・ストリームに対応しているかどうかを判断する。一致している場合、クライアント側インタセプト・モジュールにコヒーレント応答が送られる。一致していない場合、サーバ側インタセプト・モジュールは、クライアント側インタセプト・モジュールから受け取ったHTTPデータ・ストリームをウェブ・サーバ20に送り、ウェブ・サーバ20から受け取った応答をクライアント側インタセプト・モジュール30に返す。
【0061】
第7図、第8図、第9図、および第10図に、本発明の他の態様においてクライアント側インタセプト・モジュール30とサーバ側インタセプト・モジュール40によって行われる操作を示す。この態様は、差分計算を使用して、外部通信リンク35を介して伝送されるデータを削減する。第7図を参照すると、ブロック200にクライアント側インタセプト・モジュール30によるウェブ・ブラウザ10からのHTTP要求の受信が示されている。ブロック205に示すように、クライアント側インタセプト・モジュール30はウェブ・ブラウザ10からのインタセプトしたHTTP要求に問い合わせて、その要求が共通ゲートウェイ・インタフェース(CGI)に送るものかどうかを判断する。要求が共通ゲート・インタフェースに送るものでない場合、クライアント側インタセプト・モジュール30は、第3図ないし第6図に示し、第7図のブロック206に図示するように、その要求をサーバ側インタセプト・モジュールに渡す。
【0062】
しかし、ウェブ・ブラウザ発信通信がCGI要求に対応する場合、ブロック205の「Yes」経路がとられる。ブロック210に示すように、クライアント/サーバ・インタセプト・モジュール30は、対応するCGI要求に応答して前にウェブ・ブラウザに供給されていたHTTPデータ・ストリームに対応するクライアント・ベース・キャッシュ項目が存在するかどうかを判断する。このCGI要求の問い合わせは、ウェブ・ブラウザ発信通信のURLをクライアント・ベース・キャッシュに格納されているURLと比較することによって行うことができる。
【0063】
クライアント・ベース・キャッシュは、所与のURLについてウェブ・ブラウザ10に供給するクライアント側インタセプト・モジュール30が受信した最初のHTTPデータ・ストリームを格納することによって初期設定することができる。このベース・キャッシュ項目は、ウェブ・ブラウザ10の多くのインスタンスまたはセッションにわたって維持することができる。クライアント・ベース・キャッシュ項目は、第7図、第8図、第9図、および第10図に示すように更新することができる。ウェブ・ブラウザ発信通信のURLに対応するクライアント・ベース・キャッシュ項目が存在する場合、第7図のブロック211に示すように、外部通信リンク35を介してサーバ側インタセプト・モジュール40に送るCRCが、クライアント・ベース・キャッシュ項目のCRCに等しく設定される。クライアント・ベース・キャッシュ項目がない場合、第7図のブロック210から「No」経路をとり、外部通信リンク35を介してサーバ側インタセプト・モジュール40に送る要求のCRCがナルにされる。この操作は第7図のブロック212に示されている。
【0064】
ブロック213に、CGI要求を外部通信リンクを介してサーバ側インタセプト・モジュール40送る操作を示す。ブロック213に示すように、クライアント側インタセプト・モジュール30がHTTP要求と要求CRCを送る。要求CRCは、CGI要求のURLのクライアント・ベース・キャッシュ項目が存在しない場合にはナルに設定されており、クライアント・ベース・キャッシュ項目が存在する場合にはその項目のCRCに設定されている。したがって、クライアント側インタセプト・モジュールは、CGI要求をクライアント/サーバ固有プロトコルに変換し、そのクライアント/サーバ固有通信を外部通信リンクを介して送信して、サーバ側インタセプト・モジュール40が受信するようにしたことになる。
【0065】
CGI要求を受け取るときのサーバ側インタセプト・モジュールの動作を第9図に示す。サーバ側インタセプト・モジュール40によるCGI要求の受信がブロック220に示されている。サーバ側インタセプト・モジュール40はCGI要求を受け取ると、CRC値とHTTP要求のコピーを保存する。ブロック221に示すように、サーバ側インタセプト・モジュール40はHTTP要求をウェブ・サーバ20に渡す。
【0066】
第10図のブロック230に示すように、サーバ側インタセプト・モジール40がウェブ・ブラウザ発信通信またはCGI要求に対応するHTTP要求に対する応答を受け取るとき、サーバ側インタセプト・モジュール40はこの応答をHTTPデータ・ストリームとして受け取る。ブロック230に示すように、サーバ側インタセプト・モジュール40は、HTTPデータ・ストリームを保存し、ウェブ・サーバ20から受け取ったHTTPデータ・ストリームのCRC値を計算する。また、サーバ側インタセプト・モジュール40は、差分値をナルにして差分データを初期設定する。次に、ブロック235に示すように、サーバ側インタセプト・モジュールは、ウェブ・サーバ発信通信として受け取った応答がCGI要求に対する応答であるかどうかを判断する。答えが否定の場合、第10図のブロック235から「No」経路をとり、ブロック236の操作を実行して、HTTPデータ・ストリームがクライアント側インタセプト・モジュールに送る。ブロック236に示すように、この操作には第3図ないし第6図で説明したキャッシング操作が必要な場合がある。ブロック230で受け取った応答がCGIに対する応答の場合、ブロック235の「Yes」経路をとり、サーバ側インタセプト・モジュールは次に、ブロック240に示すように、CGI応答のサーバ・ベース・キャッシュ項目が存在するかどうかを判断する。
【0067】
サーバ側インタセプト・モジュール40がCGI要求に対する応答を初めて受け取ったとき、サーバ・ベース・キャッシュ項目を作成することができる。この場合、ブロック240に示す条件の結果によって、ブロック240から「No」経路がとられる。次に、サーバ側インタセプト・モジュール40は、CGIのURLと、CGI要求に対する応答のHTTPデータ・ストリームと、HTTPデータ・ストリームのCRCとを格納することによって、サーバ・ベース・キャッシュ項目を作成する。この操作をブロック241に示す。第3図ないし第6図で説明したコヒーレント・キャッシュとの互換性を持たせるために、サーバ・ベース・キャッシュ項目にはSDTも組み込むことができる。本明細書では、サーバCGIベース書式という用語を使用して、ウェブ・ブラウザ10から受け取ったCGI要求に対応するサーバ・ベース・キャッシュ項目を指す。
【0068】
CGI要求に対応するサーバ・ベース・キャッシュ項目がある場合、ブロック240の「Yes」経路がとられる。サーバ側インタセプト・モジュールはサーバ・ベース・キャッシュ項目のCRCを、ウェブ・サーバ20から受け取った応答のCRCと比較する。これらの操作を第10図のブロック245に示す。CRCが同じ場合、サーバ側インタセプト・モジュールは、サーバ・ベース・キャッシュ項目のCRCがクライアント・ベース・キャッシュ項目のCRCに対応するかどうかを判断する。この2つのCRC値が同じ場合、クライアント・ベース・キャッシュ項目と、サーバ・ベース・キャッシュ項目と、ウェブ・サーバ20から受け取った応答のすべてがHTTPデータ・ストリームに入れられる。サーバ・ベース・キャッシュ項目とクライアント・ベース・キャッシュ項目との比較をブロック250に示す。
【0069】
2つのベース・キャッシュ項目が同じ場合、サーバ側インタセプト・モジュールはベース・キャッシュ項目をクライアント側インタセプト・モジュール30に送る必要がなく、したがって、ブロック251に示すように、クライアント側インタセプト・モジュール30に送るHTTPデータ・ストリーム・データをナルにする。次に、ブロック252に示すように、サーバ側インタセプト・モジュール40は、CGI要求に対応するサーバ・ベース・キャッシュに格納されているHTTPデータ・ストリームのCRCと、ナルにしたHTTPデータ・ストリームと、ナルにした差分データとを送信して、CGI要求がクライアント・ベース・キャッシュ項目と同じであったことを示すことによって、ウェブ・サーバ20から受け取ったHTTPデータ・ストリームをクライアント/サーバ固有通信プロトコルに変換する。
【0070】
ブロック245に戻って、CGI要求に対応するサーバ・ベース・キャッシュ項目のCRCが、ウェブ・ブラウザによって発信されたCGI要求に応答してウェブ・サーバから受け取った応答のCRCと異なる場合、ブロック245から「No」経路がとられる。次に、サーバ側インタセプト・モジュール40はブロック246に示す操作を行う。サーバ側インタセプト・モジュール40は、インタセプトしたCGI応答を、インタセプトしたCGIに対応するサーバ・ベース・キャッシュ項目すなわちサーバCGIベース書式と比較する。このインタセプトしたCGI応答とサーバCGIベース書式との比較によって、インタセプトしたCGI応答とサーバCGIベース書式との差分に対応するCGI差分データが得られる。
【0071】
差分計算は、ベース書式と修正済み書式との間の差分を求める当業者に周知の任意の方法で行うことができる。本発明で使用するのに適した差分計算の一方法は、コピーターズ(Coppieters)による″Cross-Platform Binary Diff″(Dr.Dobb's Journal 1995年5月号32〜36ページ)に記載されており、その開示は参照により、その全部が記載されているかのように本明細書に組み込まれる。差分データを求める際に使用することができるその他の方法には、″IBM Technical Disclosure Bulletin(Vol.22, No.8A、1980年1月)に記載されている方法が含まれ、これも参照によりその全部が記載されているかのように本明細書に組み込まれる。次に、ブロック247に示すように、サーバ側インタセプト・モジュール40はサーバCGIベース書式が更新を必要とするかどうかを判断。この判断は、インタセプトされたCGI応答とサーバCGIベース書式との平均差分データが所定のしきい値を超えているかどうかを判断することによって行うことができる。CGI要求に対応するサーバ・ベース・キャッシュ項目を更新する必要があるかどうかを判断する他の方法には、第3図ないし第6図で説明したような時間コヒーレンシ方式や、ベース変更を行って新しいベース・キャッシュ項目を作成すればシステム・パフォーマンスが向上するほど差分データが増加したかどうかを判断する当業者に周知のその他の方法が含まれる。
【0072】
サーバのベース変更計算が不要な場合、ブロック247から「No」経路がとられ、サーバ側インタセプト・モジュール40はブロック250の操作を行って、クライアント・ベース・キャッシュ項目のCRCがサーバ・ベース・キャッシュ項目のCRCと同じかどうか、またはサーバCGIベース書式が、ウェブ・ブラウザ発信通信のその特定のCGI要求に対応するサーバとクライアントのベース・キャッシュ項目であるクライアントCGIベース書式と同じかどうかを判断する。ベース書式が同じ場合、クライアントはベース変更を行う必要がなく、ブロック251に示すようにHTTPデータ・ストリーム情報がナルにされる。次に、サーバ側インタセプト・モジュール40は、CGI要求に対応するサーバ・ベース・キャッシュ項目のCRC(すなわちサーバCGIベース書式のCRC)を送り、ベース・データに対応するナルにしたHTTPデータ・ストリームを送り、ブロック246で求めた差分データを送ることによって、クライアント側インタセプト・モジュール30に差分応答を送る。これらの操作は第10図のブロック252として示されている。
【0073】
サーバ側インタセプト・モジュール40が、クライアントCGIベース書式とサーバCGIベース書式のCRCが同じでないと判断した場合、クライアントのベース変更計算を行う必要がある。クライアントのベース変更操作は、クライアント側インタセプト・モジュール30にサーバCGIベース書式を送るステップを含む。この操作を行うために、サーバ側インタセプト・モジュールはクライアント側インタセプト・モジュール30に送るHTTPデータ・ストリーム・データを、サーバCGIベース書式と等しく設定する。この操作をブロック253に示す。次に、サーバ側インタセプト・モジュール40は、ブロック252に示すように、サーバCGIベース書式のCRCと、サーバCGIベース書式に対応するHTTPデータ・ストリーム・データを送信し、CGIベース書式とウェブ・サーバから受け取った応答との差分データを送信することによって、ウェブ・サーバから受け取ったHTTPデータ・ストリームをクライアント/サーバ固有プロトコルに変換する。次にこの情報を外部通信リンク35を介してクライアント側インタセプト・モジュール30に送る。
【0074】
ブロック247に戻って、サーバのベース変更が必要な場合、ブロック247から「Yes」経路がとられる。ブロック248に示すように、サーバ側インタセプト・モジュールは、ウェブ・サーバから受け取ったHTTPデータ・ストリームを使用してブラウザ発信通信に対応するサーバ・ベース・キャッシュを更新する。応答のCRCも更新され、CGI差分データがナルにされる。次に、サーバ側インタセプト・モジュールは、ブロック250に示すように新しいサーバ側キャッシュ項目のCRCを比較し、前述のようにこの転送を完了する。
【0075】
サーバ側インタセプト・モジュール40から応答を受け取ったときのクライアント側インタセプト・モジュールの操作を第8図に示す。クライアント側インタセプト・モジュール30によるサーバ側インタセプト・モジュール40からの応答の受信は、ブロック260に示されている。ブロック265に示すように、クライアント側インタセプト・モジュール30は、応答がCGI要求に対する応答かどうかを判断する。応答がCGI要求に対する応答ではない場合、クライアント側インタセプト・モジュールはブロック267の操作を行う。この操作には、第3図ないし第6図に示すキャッシュ操作を組み込むことができる。しかし、応答がCGI要求に対する応答の場合、ブロック265から「Yes」経路がとられる。クライアント側インタセプト・モジュール30は、外部通信リンクを介して送信されたクライアント/サーバ固有データ・ストリームから入手した、HTTPデータ・ストリーム・データと、差分データと、CRCとを保管する。これらの操作は第8図のブロック266に示されている。
【0076】
次に、クライアント側インタセプト・モジュール30は、CGIベース書式を含むインタセプトされたCGI要求に対応するクライアント・ベース・キャッシュ項目が存在するかどうかを判断する。この問い合わせはブロック270に示されており、HTTP要求またはHTTP応答のURLを調べることによって行うことができる。クライアントCGIベース書式が存在する場合、ブロック270から「Yes」経路がとられる。次に、ブロック275に示すように、クライアント側インタセプト・モジュール30は外部通信リンクを介して受け取ったCRCを、クライアントCGIベース書式のCRCと比較する。CRCが異なる場合、ブロック275から「No」経路がとられ、クライアントは、ウェブ・ブラウザ発信通信にCGI要求のURLに対応するクライアント・ベース・キャッシュ項目を、外部通信リンク35を介してサーバ側インタセプト・モジュール40から受け取ったHTTPデータ・ストリーム・データに置き換えてCGIベース書式を更新することによって、ベース変更を行う。クライアント・ベース・キャッシュ項目も、HTTPデータ・ストリームのCRCを基準にして更新される。これらの操作は第8図のブロック276に示されている。
【0077】
外部通信リンク35を介して受け取ったCRCがGGIベース書式と同じ場合、サーバ側インタセプタ・モジュール・サーバCGIベース書式は、クライアント側インタセプト・モジュール・クライアントCGIベース書式と同じであり、ブロック275の「Yes」経路がとられる。
【0078】
ベース書式が同じであるかクライアントをベース変更するかを問わず、クライアント側インタセプタ・モジュール30によってブロック277に示す操作が行われる。ブロック277は、クライアント側インタセプタ・モジュール30が、クライアントCGIベース書式を外部通信リンク35を介して受け取ったCGI差分データと比較して、インタセプトしたCGI応答に対応するHTTPデータ・ストリームを作成することによって、外部通信リンク35を介して受け取ったクライアント/サーバ固有データ・ストリームから、ウェブ・サーバ20から受け取った通信に対応するHTTPデータ・ストリームを再構築する操作を示す。ブロック278に示すように、この応答は次にHTTPデータ・ストリームとしてウェブ・ブラウザ10に供給される。
【0079】
クライアントにCGI要求のURLに対応するCGIベース書式が存在しない場合、第8図のブロック270から「No」経路がとられる。ブロック271に示すように、クライアント側インタセプト・モジュール30は、URLと、サーバ側インタセプト・モジュール40から外部通信リンクを介して受信したHTTPデータ・ストリームのCRCと、実HTTPデータ・ストリーム・データとを格納することによってCGI要求のURLに対応するクライアント・ベース・キャッシュ項目を作成する。この情報を格納することによって、インタセプトされたCGI要求に対応するクライアント・ベース・キャッシュ項目が作成され、したがってクライアントCGIベース書式が作成される。次に、クライアント側インタセプト・モジュールは、クライアントCGIベース書式をCGI差分データ(ナル化されていることがある)と結合またはマージすることによって、HTTPデータ・ストリームを再構築することでブロック277の操作を行う。
【0080】
本発明の差分計算技法は非CGIデータにも適用可能である。その場合、サーバ側インタセプト・モジュール40は、ウェブ・サーバに接続されているウェブ・ブラウザのクライアント側インタセプト・モジュールが異なるベース書式を持っている可能性を見込んで、複数の世代のサーバ・ベース・キャッシュ項目を維持する必要がある。その場合、サーバ側インタセプト・モジュールは、一致するものが得られるまで、クライアント側インタセプト・モジュールから受け取ったCRCを各世代のサーバ・ベース書式のCRCと比較する。その際、サーバ側インタセプト・モジュール40は、任意選択でクライアント側インタセプト・モジュール30のベース変更を行うか、または単にクライアント側インタセプト・モジュール30に差分データを供給することができる。したがって、本明細書でCGI要求に関して説明した差分計算方法は、どのようなHTTP要求および応答にも等しく適用可能である。
【0081】
複数の世代のベース書式を維持する上述のシステムでは、非CGI要求について差分計算を使用することができるが、この方法はメモリまたは格納域を多用し、前述のキャッシング機能が十分に活用されない。メモリまたは格納域必要量を少なくし、前述のキャッシング方法を活用するために、非CGI要求に差分計算を使用する以下の好ましい方法を使用することできる。この好ましい実施態様では、サーバ側インタセプト・モジュールは、要求に対応するサーバ・ベース書式とウェブ・サーバからの応答のHTTPデータ・ストリームとの差分を計算する。次に、ベース書式をウェブ・サーバからの新しい応答で置き換えることによって、サーバ・ベース書式を更新する。これにはベース書式のCRCの更新も含まれる。しかし、古いCRCを廃棄するのではなく、前のベース書式のCRCは差分データとして格納する。次に、前の世代の差分データとCRCを、非CGI要求に対応するクライアント・ベースのCRCに基づいて選択的にクライアント側インタセプト・モジュールに送る。
【0082】
非CGI差分計算方法の一例として、サーバ側インタセプト・モジュールが非CGI要求を受け取った場合、その要求には非CGI要求のURLに対応するクライアント側インタセプト・モジュールにあるベース書式のCRCも付随していることになる。サーバ側インタセプト・モジュールは、ウェブ・サーバから応答を受け取ると、その応答のCRCを計算する。次に、サーバ側インタセプト・モジュールは応答とURLのサーバ・ベース書式との差分を計算し、その差分データを保管する。サーバ側インタセプト・モジュールは、応答データを使用してサーバ・ベース書式を更新し、前のベース書式のCRCと、応答と古いベース書式との間の差分データとをアーカイブする。次に、サーバ側インタセプト・モジュールは、クライアント・ベース書式のCRCをサーバ・ベース書式のCRCおよび格納またはアーカイブされているCRCと比較し、一致しているものがあるかどうかを判断する。一致が見つからない場合、その応答は単にクライアント側インタセプト・モジュールに送られる。
【0083】
一致が見つかった場合、一致するCRCに対応する差分データと、それ以降の、現行差分データを含む現行差分データまでの差分データがクライアント側インタセプト・モジュールに送られる。クライアント側インタセプト・モジュールは、その差分データをクライアント・ベース書式に適用して応答を再構築する。したがって、3世代古いベース書式のCRCについてCRC一致があった場合、3セットの差分データがクライアント側インタセプト・モジュールに送られることになり、3セットの連続した差分データをクライアント・ベース書式に適用することによって、応答の構築が行われることになる。しかし、応答を再構築するのに必要な差分データ・セットの数が多すぎるかまたは差分データ・セットの大きさが大き過ぎて、実応答を送信した方がデータ転送が少なくて済む場合、サーバ側インタセプト・モジュールは応答自体を送信することができる。いずれにしても、応答の再構築または受信の後、クライアント側インタセプト・モジュールは、要求のURLのクライアント・ベース書式を応答データによって更新し、CRCを要求のCRCで更新する。クライアント・ベース書式は特定のURLについて応答を受信するたびに更新されるため、非CGI要求に対して差分計算を使用した場合、上述のクライアント・キャッシュをクライアント・ベース書式のキャッシュとして使用することができ、それによってクライアント・ベース書式の別個のキャッシュを不要にすることができる。
【0084】
本発明の他の態様では、HTTPなどのステートレス通信プロトコルの冗長性に基づいて、通信をさらに節約することができる。そのようなプロトコルでは、クライアントは通信を開始するたびにクライアント自体に関する情報をサーバに送信する。同様に、サーバは応答を出すたびにサーバ自体に関する特定の情報をクライアントに伝達する。
【0085】
本発明の一実施例では、第1のコンピュータ5は第2のコンピュータ6に、第1のコンピュータの事前定義特性に対応するコンピュータ固有情報を伝達する。第2のコンピュータはこのコンピュータ固有情報を格納する。次に、第1のコンピュータはそれ以降のウェブ・ブラウザ発信通信からそのコンピュータ固有情報を除去してから外部通信リンク35で送信する。第2のコンピュータ6は、外部通信リンク35を介して受信したそれ以降の通信と格納しているコンピュータ固有情報とを組み合わせてHTTPデータ・ストリームを作成することによって、元のウェブ・ブラウザ発信通信を再構築する。
【0086】
ウェブ・ブラウザによって発信される通信からコンピュータ固有情報を除去するほかに、このコンピュータ固有情報をウェブ・サーバによって発信される通信からも除去することができる。その場合、第2図の第2のコンピュータ6は第1のコンピュータ5に外部通信リンク35を介して、第2のコンピュータ6の事前定義特性に対応するコンピュータ固有情報を供給する。第1のコンピュータ5はそのコンピュータ固有情報を格納して、サーバ・ヘッダ情報を備える。その後の通信の時には、第2のコンピュータ6はウェブ・サーバ発信通信からコンピュータ固有情報を除去し、ウェブ・サーバ発信通信の残りの部分を外部通信リンク35で送信する。第1のコンピュータ5は外部通信リンクでその通信を受信し、サーバ・ヘッダ情報を外部通信リンクを介して受信したクライアント/サーバ固有データ・ストリームと結合してHTTPデータ・ストリームを作成することによって、元のウェブ・サーバ発信通信を再構築する。どちらの場合も、操作が第1のコンピュータ5と第2のコンピュータ6のどちらで行われるかに応じて、コンピュータ固有情報を取り除き、その情報を格納してサーバ・ヘッダ情報またはクライアント・ヘッダ情報を作成する操作がクライアント側インタセプト・モジュール30またはサーバ側インタセプト・モジュール40によって行われる。
【0087】
本発明の一実施例では、ウェブ・ブラウザ10は伝送制御プロトコル/インターネット・プロトコル(TCP/IP)を使用してクライアント側インタセプト・モジュール30と通信する。TCPは、外部通信リンク35を介したクライアント側インタセプト・モジュール30とサーバ側インタセプト・モジュール40との間の通信にも使用することができる。最後に、TCPはサーバ側インタセプト・モジュール40とウェブ・サーバ20との間の通信にも使用することができる。TCPは本発明のシステムを構成する様々な構成要素間の通信に使用することができるが、HTTPプロトコルは外部通信リンクを介した通信にとって最も効率的な手段を提供するものではない。外部通信リンク35のパフォーマンスを向上させるために、本発明の一実施例は本明細書で「仮想ソケット」と呼ぶものを作成する。これは、ウェブ・ブラウザとクライアント側インタセプト・モジュール30の間の接続と、サーバ側インタセプト・モジュール40とウェブ・サーバ20との間の接続に使用される。これらの仮想ソケットの動作について、第11図ないし第17図を参照しながら以下に説明する。
【0088】
第11図は、仮想ソケットを使用する本発明の1つの可能な実施態様を示すブロック図である。第11図に示すように、第1のコンピュータ5と第2のコンピュータ6は外部通信リンク35を介して接続されている。ウェブ・ブラウザ10は、ウェブ・ブラウザ10をクライアント側インタセプト・モジュール30と接続する複数の実ソケットを有する。第11図に示すように、第1の実ソケットはウェブ・ブラウザ10上に65aとして図示され、それに対応するソケットはクライアント側インタセプト・モジュール30上の65bである。この第1の実ソケットは、それを介してウェブ・ブラ、ウザ10がクライアント側インタセプト・モジュール30に対してさらに接続を要求するTCPソケットである。
【0089】
ウェブ・ブラウザ10が新しいTCP接続を要求すると、実ソケット65aを介して通信が行われ、それが実ソケット65bによって受信される。次にクライアント側インタセプト・モジュール30は、ウェブ・ブラウザ10との通信のために別の実ソケットを作成する。第11図に示すように、ウェブ・ブラウザ10上で複数の実ソケットが作成され、それに対応する実ソケットがクライアント側インタセプト・モジュール30上で作成される。これらの実ソケットは、ウェブ・ブラウザ10上の60a〜64aおよびクライアント側インタセプト・モジュール30上の60b〜64bとして図示されている。これらの実ソケットは、ウェブ・ブラウザ10がそれを介してクライアント側インタセプト・モジュール30と通信するための手段である。実ソケット60a〜64aおよび60b〜64bを作成した後、これらのソケットを介した通信を多重化して実ソケット36aに送り、実ソケット36aはクライアント側インタセプト・モジュール30に外部通信リンク35へのアクセスを提供する。実ソケット36aおよび36bはコンピュータ5の実ソケット37aを介してコンピュータ6の実ソケット37bに要求を送るときに作成される。実ソケット37bが接続要求を受け取ると、実ソケット36aおよび36bが作成される。ソケット37aおよび37bは、クライアント側インタセプト・モジュールとサーバ側インタセプト・モジュールとの間の通信のための最初の実ソケットとして機能し、ソケット36aおよび36bによって示されているこの2つのモジュールの間の接続を確立するためにのみ使用することができる。これらの実ソケットのそれぞれは標準TCP/IPプロトコルの下で動作する。第2のコンピュータ6が外部通信リンク35を介して通信を受信するとき、それらの通信は実ソケット36bで受信される。次にサーバ側インタセプト・モジュール40は、ソケット36bで受信した通信を多重化解除し、それらをウェブ・サーバ20に送信するために適切なソケットに供給する。したがって、たとえば、特定のURLに対して情報を要求するためのソケット60aからソケット60bまでの通信は、ソケット36a上に多重化され、ソケット36bによって受信され、サーバ側インタセプト・モジュール40によって多重化解除され、ソケット60cからウェブ・サーバ20上のソケット60dに送られることになる。同様に、ソケット61aを介して行われる通信はソケット61bによって受信され、クライアント側インタセプト・モジュール30によって多重化され、ソケット36aからソケット36bに送られ、そこでサーバ側インタセプト・モジュール40がその通信を多重化解除してソケット61cからソケット61dに送る。したがって、ソケット60aと60b、61aと61b、62aと62b、63aと63b、64aと64bを介した通信は、サーバ側インタセプト・モジュール40とウェブ・サーバ20との間のソケット60cと60d、61cと61d、62cと62d、63cと63d、および64cと64dのうちのそれぞれの対応するソケットを介して送信される。
【0090】
同様に、ウェブ・サーバ20によるウェブ・ブラウザ10からの要求に対する応答も、ウェブ・サーバ20をサーバ側インタセプト・モジュール40に接続するソケットを介して送られ、外部通信リンク35を介してクライアント側インタセプト・モジュール30に送られた後、ウェブ・ブラウザ10に送られる。したがって、たとえばウェブ・サーバ20によって発信された応答はソケット60dから60cを介して送られ、サーバ側インタセプト・モジュール40によってソケット36bに多重化され、そこから外部通信リンク135を介してソケット36aに送られる。次にクライアント側インタセプト・モジュール30がその通信を多重化解除し、それをソケット60bに送り、それがウェブ・ブラウザ10上のソケット60aに送られる。ウェブ・ブラウザ10またはウェブ・サーバ20が使用する各ソケットについて同様の通信経路が確立される。当業者ならわかるように、本発明についてウェブ・ブラウザ10とウェブ・サーバ20との間の4ソケット通信に関して説明したが、ウェブ・ブラウザ10とウェブ・サーバ20との間の通信アクセスを実現するために任意の数のソケットを開くことができる。
【0091】
第12図は、クライアント側インタセプト・モジュール30とサーバ側インタセプト・モジュール40における仮想ソケット・システムの実施例を示すブロック図である。これらのモジュールの外部で、クライアント側インタセプト・モジュール30とウェブ・ブラウザ10およびサーバ側インタセプト・モジュール40とウェブ・サーバ20の間の実ソケットが、通常のTCP/IPソケットとして機能する。したがって、仮想ソケットの使用はウェブ・ブラウザ10およびウェブ・サーバ20には透過である。
【0092】
第12図のブロック図と第13図ないし第17図の流れ図を参照しながら本発明の特定の実施例について説明する。第13図は、第12図にブロック68として図示されているソケット・マネージャのフローチャートである。第13図を参照すると、ブロック300はクライアント側インタセプト・モジュール30の実ソケット・マネージャ68の作成を示している。実ソケット・マネージャ68が作成された後、実ソケット・マネージャは第12図にソケット65bとして図示されている第1の実ソケットを作成する。この第1の実ソケットの作成は第13図のブロック301として示されている。第1の実ソケット65bを作成した後、クライアント側インタセプト・モジュール30内にあるソケット・マネージャ68(本明細書ではクライアント・ソケット・マネージャとも呼ぶ)は、第13図のブロック302に示すように、第1の実ソケット65b上での事象を待つ。
【0093】
第1の実ソケット65b上で事象を受け取ると、第13図のブロック305に示すように実ソケット・マネージャ68はその事象を検査し、その検査に基づいて5通りの経路のうちの1つをとる。第1の実ソケット65bで受信した通信要求に応答して実ソケットが作成された場合は、第13図のブロック305から306までの経路に示すように、実ソケット・マネージャ68はその実ソケットを実事象リストに追加する。次に、実ソケット・マネージャはブロック307に示すようにシンプレックス仮想ソケット作成する。クライアント側インタセプト・モジュールの場合、実ソケット・マネージャは、第13図のブロック308に示すように、作成された仮想ソケットについてクライアント側インタセプト・モジュールの機能を実行するアプリケーション機能を開始する。
【0094】
本明細書では、「シンプレックス・ソケット」または「シンプレックス仮想ソケット」という用語は、単一のソケットまたは単一のアプリケーションに直接接続するソケットを指す。本明細書では、「マルチプレックス・ソケット」とは他の複数のソケットに接続するソケットを指す。したがって、マルチプレックス・ソケットは、多重化または多重化解除機能を実行し、シンプレックス・ソケットは1対1接続を行う。したがって、たとえば、第13図のブロック306から308までの機能を実行する際、クライアント・ソケット・マネージャ68は第1の実ソケット65bが受信した第1の接続要求に応答して、実ソケット60b、シンプレックス仮想ソケット70を作成し、アプリケーション80のクライアント側インタセプト機能を開始することになる。実ソケットが作成されたその後の事象の場合も同様に、実ソケット・マネージャは実ソケット61b、62b、63b、または64bとシンプレックス仮想ソケット71、72、73、または74を作成し、第12図でブロック81、82、83、または84として図示されている、作成された実ソケットおよび仮想ソケットに対応するCSI機能を開始する。
【0095】
以下に、クライアント側インタセプト機能の操作について、第12図に示す実ソケット60Bとシンプレックス仮想ソケット70とクライアント側インタセプト機能80とを参照しながら説明する。第14図のブロック325はクライアント側インタセプト機能80の作成を示している。作成されると、クライアント側インタセプト機能80はブロック326に示すようにシンプレックス仮想ソケット70上の事象を待つ。この待機操作は、第16−4図に示す仮想選択機能を実行することによって行われる。事象を受け取ると、ブロック330に示すようにその事象が検査される。事象が仮想ソケット閉鎖である場合、第14図のブロック349に示すようにクライアント側インタセプト機能80はシンプレックス仮想ソケット70を削除し、ブロック350に示すように終了する。
【0096】
事象がデータの受信である場合、ブロック330からブロック331への経路がとられ、クライアント側インタセプト機能80は第16−3図を参照しながら説明する仮想受信操作を実行することによって、シンプレックス仮想ソケット70からブラウザ発信通信を受け取る。次に、クライアント側インタセプト機能は前述のクライアント側インタセプト・モジュールの機能(たとえば第3図および第7図を参照)を実行する。これはブロック332に示されている。次にクライアント側インタセプト機能80は、クライアント側インタセプト・モジュール30内の実ソケット36aに接続されるマルチプレックス仮想ソケッ90を作成する。実ソケット36aはサーバ側インタセプト・モジュール40上の実ソケット36bに接続される。マルチプレックス仮想ソケットの作成は、第14図のブロック333に示されており、本明細書で第16−1図を参照しながら説明する仮想作成操作を実行することによって行われる。ブロック334は、ウェブ・ブラウザ発信通信のためにクライアント側インタセプト機能80が実行された後で、実ソケット60bとシンプレックス仮想ソケット70を介してウェブ・ブラウザから受け取った情報を送信する操作を示す。この通信は、第16−2図を参照しながら説明する仮想送信操作を実行することによってマルチプレックス仮想ソケット90の待ち行列に入れられる。クライアント側インタセプト機能80は、要求をマルチプレックス仮想ソケット90の待ち行列に入れた後、第14図のブロック335に示すようにマルチプレックス仮想ソケット90の待ち行列に入れられているデータをフラッシュし、次にブロック336に示すようにマルチプレックス仮想ソケット上の事象を待つ。仮想フラッシュ機能は、第17−1図を参照しながら説明する仮想フラッシュ操作を実行することによって行われ、マルチプレックス仮想ソケット待ち行列からデータを取り出してそのデータを実ソケット36aに供給する。待機機能は、第16−4図に示す仮想選択機能を実行することによって行うことができる。この時点で、クライアント側インタセプト・モジュールはウェブ・ブラウザ発信通信をインタセプトし、その通信を外部通信リンク35を介してサーバ側インタセプト・モジュールに送信し終わったことになる。
【0097】
第13図に戻ると、サーバ側インタセプト・モジュール40またはクライアント側インタセプト・モジュール30におけるソケット・マネージャのフローチャートが示されている。第12図のブロック69に示すように、サーバ側インタセプト・モジュール内の実ソケット・マネージャ、すなわちサーバ・ソケット・マネージャは、ブロック68に示すクライアント・ソケット・マネージャと同じ機能を実行する。ブロック301に示すように、第1の実ソケットを作成する際、サーバ側インタセプト・モジュール30は、サーバ側インタセプト・モジュール40に関連づけられたクライアント側インタセプト・モジュール30からのソケットの要求を受け取る「周知のポート」37bを作成する。サーバ側インタセプト・モジュール40の実ソケット36b上で実事象が発生すると、ブロック305に示すようにその事象が検査される。この場合、この事象は実ソケット36aからのデータの受信であり、したがって第13図のブロック305からブロック320までの経路がとられる。実ソケット36b上で受信したデータが検査され、この例ではデータはクライアント側インタセプト・モジュールによって送信されたウェブ・ブラウザ発信通信であるため、サーバ側インタセプト・モジュール40において新しい仮想ソケットを作成しなければならない。したがって、第13図のブロック320からブロック321への経路がとられる。次にサーバ・ソケット・マネージャ69は、第13図のブロック321、ブロック322、ブロック323、およびブロック324に示す操作を行う。サーバ・ソケット・マネージャ69はブロック321に示すようにマルチプレックス仮想ソケット95を作成し、ブロック322に示すようにマルチプレックス・ソケット活動タイマをキャンセルし、第13図のブロック323と第12図のブロック85に示すサーバ側インタセプト機能のアプリケーションを開始する。実ソケット36bで受け取ったデータは次にマルチプレックス仮想ソケット95の待ち行列に入れられ、仮想事象が通知される。
【0098】
ブロック323に示すサーバ側インタセプト機能の作成は、第15図のブロック360に示されている。サーバ側インタセプト機能85の作成後、この機能は、クライアント側インタセプト・モジュール30から送信され、ウェブ・ブラウザ発信通信に対応するデータを、マルチプレックス仮想ソケット95から受け取る。この操作は第15図のブロック361に示されている。クライアント側インタセプト・モジュールからデータを受け取った後、サーバ側インタセプト機能85は、そのデータを、サーバ側インタセプト・モジュールについて前述したように処理する。このサーバ側機能の実行はブロック362に示されている(たとえば第5図および第9図を参照)。情報を処理した後、サーバ側インタセプト機能85は仮想作成を行うことによってシンプレックス仮想ソケット75を作成する。この操作については本明細書で第16−1図を参照しながら説明する。この操作は第15図のブロック363に示されている。次に、サーバ側インタセプト機能85は、仮想送信を行うことによって、ブロック364に示すようにウェブ・ブラウザ発信通信をシンプレックス仮想ソケット75に送る。仮想送信の操作については本明細書で第16−2図を参照しながら説明する。次に、サーバ側インタセプト機能85は、仮想フラッシュを行ってシンプレックス仮想ソケット75の待ち行列に入っているデータをソケット60cにフラッシュし、シンプレックス仮想ソケット75上の事象を待つ。仮想フラッシュ操作については本明細書で第17−1図を参照しながら説明する。この送信操作とフラッシュ操作は第15図のブロック364および365に示されている。待機操作は、第16−4図で説明されている仮想選択機能を実行することによって行うことができる。サーバ側インタセプト機能85がシンプレックス仮想ソケット75を作成したとき、対応する実ソケット60cも作成されている。サーバ側インタセプト機能85は、ウェブ・ブラウザ発信通信をシンプレックス仮想ソケット75に送信することによって、ウェブ・ブラウザ発信通信をウェブ・サーバに転送した。
【0099】
サーバ側インタセプト・モジュール40が実ソケット60c上でウェブ・サーバからの応答を受信すると、実事象が発生し、サーバ・ソケット・マネージャ69は第13図のブロック302を終了して、ブロック305に示すように実ソケット60c上で発生した事象を検査する。この事例の場合、これは既存の仮想ソケットのデータであり、第13図のブロック320からブロック324までの経路がとられる。実ソケット60c上で受信したデータは仮想ソケット75の待ち行列に入れられ、仮想事象が通知される。仮想事象が通知されると、サーバ側インタセプト機能85は第15図のブロック366を終了し、ブロック370に示すようにその事象を検査する。事象がソケット閉鎖である場合、エラー条件が発生し、第15図のブロック375に示すように応答としてエラー・メッセージが作成される。しかし、事象がデータの受信の場合は、ブロック370からブロック371への経路をとり、サーバ側インタセプト機能85は、第16−3図を参照しながら説明するように仮想受信を実行して、ブロック371に示すようにシンプレックス仮想ソケット75から応答を入手する。次にサーバ側インタセプト機能85は、ブロック372に示し、第17−2図を参照しながら説明するように、シンプレックス仮想ソケット75の仮想閉鎖を実行し、サーバ側インタセプト・モジュールに関して前述し、ブロック373に示すように、その応答を処理する(たとえば第6図および第10図を参照)。
【0100】
第15図のブロック370の終了経路がブロック375へのエラー経路であるかブロック371へのデータ経路であるかを問わず、ブロック374でシンプレックス仮想ソケット75が削除される。
【0101】
次にサーバ側インタセプト機能は、ブロック376に示すようにマルチプレックス仮想ソケット95への仮想送信操作を行ってウェブ・サーバ発信通信をクライアント側インタセプト・モジュール30に送信する。サーバ側インタセプト機能85は次に、仮想フラッシュ操作を行って、マルチプレックス仮想ソケット95の待ち行列に入っているデータをフラッシュする。これらの操作はブロック377に示されている。次にサーバ側インタセプト機能85は、第15図のブロック378に示すように仮想閉鎖操作を行ってマルチプレックス仮想ソケット95を閉じる。最後に、サーバ側インタセプト機能85は、ブロック379および380に示すようにマルチプレックス仮想ソケットを削除して終了する。
【0102】
サーバ側インタセプト機能は、マルチプレックス仮想ソケット95への仮想送信操作とフラッシュ操作を行う。これらの操作によって、実ソケット36a上で事象がトリガされ、クライアント・ソケット・マネージャ68はブロック302を終了し、ブロック305に示すように事象を検査する。これは実ソケット36aでデータを受信し、第13図のブロック305からブロック320までの経路がとられ、データがマルチプレックス仮想ソケット90の待ち行列に入れられるためである。したがって、実ソケット36aが外部通信リンク35を介して実ソケット36bからウェブ・サーバ応答を受け取ると、その情報が多重化解除され、マルチプレックス仮想ソケットに供給される。データの受信によって、第13図のブロック324に示すように仮想事象が発生し、第14図のブロック336が終了してクライアント側インタセプト機能80は第14図のブロック340に示すようにその事象を検査することになる。
【0103】
事象がソケット閉鎖応答である場合、第14図のブロック340からブロック345への経路をとり、クライアント側インタセプト機能80はエラー・メッセージ応答を作成して第14図のブロック344に進む。この例の場合のように事象がデータ受信の場合、第14図のブロック340からブロック341の経路をとり、クライアント側インタセプト機能80は仮想受信操作を行ってマルチプレックス仮想ソケット90から応答を受信する。この受信操作は第14図のブロック341に示されている。マルチプレックス仮想ソケット90からデータを受信した後、クライアント側インタセプト機能80はブロック342に示すように仮想閉鎖操作を行ってマルチプレックス仮想ソケット90を閉じる。次にクライアント側インタセプト機能80は、ブロック343に示すように、クライアント側インタセプト・モジュールに関して前述したように応答を処理する(たとえば第4図および第8図を参照)。
【0104】
ブロック340を終了してどちらの経路をとる場合も、ブロック344の操作が行われる。クライアント側インタセプト機能80は、ブロック344に示すようにマルチプレックス仮想ソケットを削除し、次にブロック346に示すように仮想送信操作を行ってシンプレックス仮想ソケット70を介してブラウザに応答を送信する。この仮想送信操作が完了すると、クライアント側インタセプト機能80はブロック347に示すように仮想フラッシュ操作を行ってシンプレックス仮想ソケットの待ち行列に入っているデータを実ソケット60bにフラッシュし、次にブロック348に示すように仮想閉鎖操作を行ってシンプレックス仮想ソケットを閉じる。クライアント側インタセプト機能のシンプレックス仮想ソケットを閉じた後、第14図のブロック349および350に示すようにシンプレックス仮想ソケットが削除され、クライアント側インタセプト機能は終了する。
【0105】
当業者ならわかるように、本発明についてシンプレックス仮想ソケットおよびマルチプレックス仮想ソケットとクライアント側インタセプト機能およびサーバ側インタセプト機能の1つの特定のインスタンスに関して説明したが、単一のクライアント側インタセプト・モジュールまたはサーバ側インタセプト・モジュール内でこれらの機能を複数作成することができる。したがって、本発明によるクライアント側インタセプト・モジュールとサーバ側インタセプト・モジュールは、クライアント側インタセプト・モジュール30とサーバ側インタセプト・モジュール40との間にTCP/IP接続を作成し、次に、そのTCP/IP接続を維持しながらそのTCP/IP接続上で複数のウェブ・ブラウザ発信通信またはウェブ・サーバ発信通信を多重化することができる。
【0106】
クライアント・ソケット・マネージャとサーバ・ソケット・マネージャの残りの機能は、第16−1図ないし第16−4図と第17−1図および第17−2図を参照すれば最もよく理解できよう。これらの図では、第14図および第15図のフローチャートに示されているように仮想作成、仮想送信、仮想受信、仮想選択、仮想フラッシュ、または仮想閉鎖操作を実行するときに、クライアント側インタセプト・モジュールおよびサーバ側インタセプト・モジュールによって行われる操作が説明されている。第14図のブロック333および第15図のブロック363に示すような仮想作成操作を行う場合、第16−1図のブロック400から始まる操作を行う。ブロック405に示すように、ソケット・マネージャは、実ソケットが必要かどうかを判断する。作成操作によって既存の実ソケットに接続するマルチプレックス仮想ソケットを作成する場合などのように、実ソケットがすでに存在する場合は、ブロック405から「No」経路をとり、ブロック409に示すようにその仮想ソケットが実ソケットに接続される。しかし、実ソケットが必要な場合は、ブロック405から「Yes」経路をとる。ブロック406に示すように実ソケットを作成する。次に、第13図のブロック302に示す監視のために、ブロック408に示すようにその実ソケットを事象リストに追加する。実ソケットを作成し、接続を確立した後、ブロック409に示すように仮想ソケットを実ソケットに接続し、ブロック410に示すように作成操作が完了する。
【0107】
第14図のブロック334および346または第15図のブロック364および376に示す仮想送信操作を行う場合、第16−2図のブロック420から始まる操作が行われる。ブロック427に示すようにデータが仮想ソケット待ち行列に加えられ、完了すると、送信操作はブロック428に示すように終了する。
【0108】
第14図のブロック331および341と第15図のブロック361および371に示す仮想受信操作は、第16−3図のブロック430から始まる操作を行うことによって行われる。ブロック435に示すように、仮想ソケット待ち行列を調べて仮想ソケット待ち行列に何かデータが入っているか判断する。仮想ソケット待ち行列にデータがある場合、ブロック435の「Yes」経路をとり、ブロック436に示すように受信操作を呼び出した機能にそのデータが返される。仮想ソケット待ち行列にデータがなく、ソケットに閉鎖のマークが付けられていない場合、決定ブロック440の「No」経路をとり、ブロック441に示すように何も返されない。しかし、待ち行列にデータがなく、ソケットに閉鎖のマークが付けられている場合、ブロック440の「Yes」経路をとり、ブロック442に示すようにソケットに閉鎖のマークが付けられて、ブロック443に示すように、受信を要求する操作にソケット閉鎖応答が返される。
【0109】
第14図のブロック326および336と第15図のブロック366で行われる仮想選択操作は、第16−4図のブロック445から始まる操作を実行することによって行われる。ブロック446に示すように、まず、選択された仮想ソケットについてデータまたは仮想閉鎖操作が保留状態になっていないかどうかを判断する。保留状態のデータまたは仮想閉鎖がない場合、ブロック446の「No」経路をとり、プロセスはブロック447に示すように選択された仮想ソケット上の仮想ソケットを待ち、そのような事象を受け取った後でブロック448に示すように終了する。選択された仮想ソケットについてデータまたは仮想閉鎖が保留状態になっている場合、仮想事象がすでに発生しており、ブロック446の「Yes」経路をとって、ブロック448に示すようにプロセスが終了する。
【0110】
第14図のブロック335および347と第15図のブロック365および377で言及した仮想フラッシュ操作は、第17−1図のブロック450から始まる操作を実行することによって行われる。仮想フラッシュ操作が呼び出されると、決定ブロック455に示すように、フラッシュする仮想ソケット待ち行列にデータが入っているかどうかを調べる。仮想ソケット待ち行列にデータが入っていない場合、ブロック455の「No」経路が示すようにフラッシュ操作は単に終了して呼出し側機能に戻る。しかし、待ち行列にデータが入っている場合、ブロック455の「Yes」経路をとり、ブロック460に示すようにその仮想ソケット待ち行列がマルチプレックス・ソケットのものであるかどうかを判断する。マルチプレックス・ソケットである場合は、ブロック461に示すようにソケットの固有識別子と転送中のデータ量を示す3バイトから成るソケット・ヘッダが実ソケット・バッファに加えられる。マルチプレックス・ソケットであるかシンプレックス・ソケットであるかを問わず、いずれの場合もブロック462に示すように実ソケットのためのデータが実ソケット・バッファに移される。実ソケット・バッファがいっぱいの場合、ブロック465の「Yes」経路をとり、ブロック466に示すように実ソケット・バッファからデータが実ソケットに送られる。実バッファがいっぱいになっていない場合は、ブロック465の「No」経路をとる。次に、仮想フラッシュ機能は、他のいずれかのマルチプレックス仮想ソケット待ち行列に実ソケットに送るべき他のデータがあるかどうかを判断する。答えが肯定の場合、ブロック470の「Yes」経路をとり、実ソケット・バッファ内のデータは、他の仮想ソケット待ち行列の1つをフラッシュするために仮想フラッシュ操作が再び呼び出されるまで送られない。他のデータがない場合、または他のマルチプレックス仮想ソケットからデータを付加した後は、ブロック466の操作を行い、実ソケットバッファ内のデータを実ソケットに送る。仮想フラッシュ操作を呼び出した機能に対応する仮想ソケット待ち行列内のすべてのデータが実ソケットに送られた後、ブロック467に示すように仮想フラッシュ操作は終了する。
【0111】
第14図のブロック342および348と第15図のブロック372および378に示す仮想閉鎖操作は、第17−2図のブロック480から始まる操作を実行することによって行われる。仮想閉鎖操作が呼び出されると、まずブロック485に示すようにその仮想閉鎖がマルチプレックス仮想ソケットの閉鎖であるかどうかを判断する。マルチプレックス仮想ソケットである場合、ブロック485の「Yes」経路をとり、仮想ソケット待ち行列に「閉鎖」操作標識が付加される。仮想閉鎖がマルチプレックス仮想ソケットの閉鎖であるか否かを問わず、ブロック487に示すように仮想閉鎖操作によって仮想フラッシュ操作が呼び出され、ブロック488に示すように実ソケットとの接続を断つ。次に、ブロック490に示すように仮想閉鎖がシンプレックス仮想ソケットの閉鎖であるかどうかを調べ、そうでない場合は「No」経路をとってブロック495に進む。閉鎖はマルチプレックス仮想ソケットの閉鎖であるため、ブロック495でそれが最後のマルチプレックス仮想ソケットであるかどうかを判断し、最後のマルチプレックス仮想ソケットである場合は、ブロック496に示すようにマルチプレックス活動タイマをセットする。最後のマルチプレックス仮想ソケットでない場合は、ブロック496をスキップする。
【0112】
ブロック490に戻って、仮想閉鎖がシンプレックス仮想ソケットの閉鎖である場合、ブロック491に示すようにそれに対応する実ソケットを事象リストから除去し、ブロック492に示すように実ソケットを閉鎖し、削除する。ソケットがシンプレックスとマルチプレックスのどちらの仮想ソケットであるかを問わず、ブロック497に示すようにその仮想ソケットに閉鎖のマークを付け、ブロック498で閉鎖操作は終了する。
【0113】
次に、第16−1図ないし第16−4図および第17−1図ないし第17−2図に関連する第13図について説明する。実事象が発生すると、第13図のブロック302を終了し、ソケット・マネージャは事象がどのように生成されたかに基づいてその事象を調べる。事象が第17−2図のブロック496で設定されたマルチプレックス・ソケット活動タイマのタイム・アウトである場合、第13図のブロック305からブロック312までの経路がとられる。第13図に示すように、次にソケット・マネージャによってブロック312および313の操作が行われ、マルチプレックス実ソケットが閉じられ、クライアント側インタセプト・モジュールをサーバ側インタセプト・モジュールに接続するソケットに対応するマルチプレックス実ソケットが削除される。その後、ソケット・マネージャは次の実事象を待つ。ブロック322に示すように、このマルチプレックス事象タイマはマルチプレックス仮想ソケットの作成によってリセットされる。
【0114】
実ソケット上で発生した事象が、ウェブ・サーバがウェブ・サーバとサーバ側インタセプト・モジュールとの間のソケット接続に対する閉鎖操作を行う場合などの実ソケット閉鎖である場合、第13図のブロック305からブロック309への経路がとられる。ソケット・マネージャはブロック309に示すように実事象リストからその実ソケットを除去し、ブロック310に示すように1つの仮想ソケット(または複数のマルチプレックス・ソケットの場合は複数の仮想ソケット)をその1つの実ソケットまたは複数の実ソケットから切断する。次に、ソケット・マネージャはその仮想ソケットに閉鎖のマークを付け、仮想事象を通知する。この操作はブロック311に示されており、仮想ソケット待ち行列からすべてのデータが空にされると、仮想ソケットは閉じる。仮想ソケットに閉鎖のマークを付けた後、決定ブロック315に示すようにソケット・マネージャは閉じる実ソケットがシンプレックス・ソケットであるかどうかを判断する。閉じる実ソケットがシンプレックス・ソケットである場合、ブロック316に示すようにその実ソケットを閉じ、削除する。次にソケット・マネージャはブロック302に示すように次の実事象を待つ。
【0115】
閉じるソケットがシンプレックス実ソケットではない場合、ブロック315の「No」経路をとり、ソケット・マネージャは次の実事象を待つ。したがって、マルチプレックス実ソケット、すなわちクライアント側インタセプト・モジュールとサーバ側インタセプト・モジュールとを接続するソケットを、マルチプレックス・ソケット活動タイマのタイムアウトのみによって閉じることができる。これによって、ユーザ指定の所定時間の間、クライアント側インタセプト・モジュールとサーバ側インタセプト・モジュールとの間の接続を、モジュール間の最後の通信が行われた後でも維持することができる。マルチプレックス・ソケット活動タイマのタイムアウトの前にブラウザからその後の接続要求があった場合、クライアント側インタセプト・モジュールとサーバ側インタセプト・モジュールとの間に接続を再確立せずに通信を行うことができ、それによってそのような接続を再確立するオーバーヘッドが不要になる。
【0116】
第13図で説明する最後の経路は、実事象が発生し、その事象が第12図の1つまたは複数のマルチプレックス実ソケット36aまたは36b上でのデータの受信である場合である。マルチプレックス実ソケット上でデータを受信すると、そのデータは検査され、第17−2図のブロック486で仮想待ち行列に付加されるもののようにデータに閉鎖操作標識が含まれている場合は、仮想閉鎖操作が行われ、ブロック320からブロック310への経路がとられる。ソケット・マネージャは、ブロック310に示すように実ソケット上で受信したデータで識別されたマルチプレックス仮想ソケットを実ソケットから切断し、次にブロック311に示すように仮想ソケットに「閉鎖」のマークを付け、仮想事象を通知する。この閉鎖はマルチプレックス仮想ソケットの閉鎖であるため、ブロック315から「No」経路がとられ、ブロック302に示すようにソケット・マネージャは別の実事象を待つ。
【0117】
第13図ないし第17図で説明されている操作を行うことによって、本発明の特定の態様は外部通信リンクを介して第1のコンピュータと第2のコンピュータとの間に持続的接続を確立する。この持続的接続は、すべてのウェブ・ブラウザ発信通信が完了するまで維持され、持続的接続が維持されている間に複数のウェブ・ブラウザ発信通信がインタセプトされ、外部通信リンクに多重化されて送られる。次にクライアント/サーバ固有データ・ストリームを多重化解除して複数のHTTPデータ・ストリームを作成し、その複数のHTTPデータ・ストリームをウェブ・サーバに供給することができる。また、持続的接続は、すべてのウェブ・サーバ発信通信がインタセプト完了するまで維持される。持続的接続が維持されている間に、複数のウェブ・サーバ発信通信がインタセプトされ、外部通信リンクに多重化されて送られる。さらに、クライアント/サーバ固有データ・ストリームを多重化解除して複数のHTTPデータ・ストリーを作成し、その複数のHTTPデータ・ストリームをウェブ・サーバに供給することができる。
【0118】
図面および本明細書では、本発明の典型的な好ましい実施例を開示し、特定の用語を使用したが、これらの用語は総称および説明のためのものに過ぎず、請求の範囲に記載されている本発明の範囲を限定するためのものではない。
【図面の簡単な説明】
【図1】第1図は、典型的なウェブ・ブラウザ/ウェブ・サーバ・システムを示すブロック図である。
【図2】第2図は、クライアント・インタセプトとサーバ・インタセプトを使用する本発明の一実施態様によるウェブ・ブラウザ/ウェブ・サーバ・システムを示すブロック図である。
【図3】第3図は、コヒーレント・キャッシュ・システムを実施する本発明の好ましい実施例において、クライアント側インタセプト・モジュールによって行われる操作を図示する流れ図である。
【図4】第4図は、コヒーレント・キャッシュ・システムを実施する本発明の好ましい実施例において、クライアント側インタセプト・モジュールによって行われる操作を図示する流れ図である。
【図5】第5図は、コヒーレント・キャッシュ・システムを実施する本発明の好ましい実施例において、サーバ側インタセプト・モジュールによって行われる操作を図示する流れ図である。
【図6】第6図は、コヒーレント・キャッシュ・システムを実施する本発明の好ましい実施例において、サーバ側インタセプト・モジュールによって行われる操作を図示する流れ図である。
【図7】第7図は、差分計算データ転送システムを実施する本発明の好ましい実施例において、クライアント側インタセプト・モジュールによって行われる操作を図示する流れ図である。
【図8】第8図は、差分計算データ転送システムを実施する本発明の好ましい実施例において、クライアント側インタセプト・モジュールによって行われる操作を図示する流れ図である。
【図9】第9図は、差分計算データ転送システムを実施する本発明の好ましい実施例において、サーバ側インタセプト・モジュールによって行われる操作を図示する流れ図である。
【図10】第10図は、差分計算転送システムを実施する本発明の好ましい実施例において、サーバ側インタセプト・モジュールによって行われる操作を図示する流れ図である。
【図11】第11図は、仮想ソケットを使用する本発明の一態様を示すブロック図である。
【図12】第12図は、仮想ソケットを使用する本発明の一実施例による、クライアント側インタセプト・モジュールとサーバ側インタセプト・モジュールを示すブロック図である。
【図13】第13図は、仮想ソケットを使用する本発明の一実施例による、クライアント側インタセプト・モジュールまたはサーバ側インタセプト・モジュールのソケット・マネージャによって行われる操作を図示する流れ図である。
【図14】第14図は、仮想ソケットを使用する本発明の一実施例において、クライアント側インタセプト機能によって行われる操作を図示する流れ図である。
【図15】第15図は、仮想ソケットを使用する本発明の一実施例において、サーバ側インタセプト機能によって行われる操作を図示する流れ図である。
【図16−1】第16−1図は、仮想ソケットを使用する本発明の一実施例による、仮想作成操作を図示する流れ図である。
【図16−2】第16−2図は、仮想ソケットを使用する本発明の一実施例による仮想送信操作を図示する流れ図である。
【図16−3】第16−3図は、仮想ソケットを使用する本発明の一実施例による仮想受信操作を図示する流れ図である。
【図16−4】第16−4図は、仮想ソケットを使用する本発明の一実施例による仮想選択操作を図示する流れ図である。
【図17−1】第17−1図は、仮想ソケットを使用する本発明の一実施例による仮想フラッシュ操作を図示する流れ図である。
【図17−2】第17−2図は、仮想ソケットを使用する本発明の一実施例による仮想クローズ操作を図示する流れ図である。
Claims (73)
- 第1のコンピュータ上に常駐しかつ第1のコンピュータからは遠隔にある第2のコンピュータ上に常駐するウェブ・サーバ・アプリケーションとハイパーテキスト転送プロトコル(HTTP)を使用して通信するウェブ・ブラウザ・アプリケーションのパフォーマンスを向上する方法であって、前記第1のコンピュータ内のウェブ・ブラウザ・アプリケーションと前記第2のコンピュータ内のウェブ・サーバ・アプリケーションとの間の通信が外部通信リンクを介して行われ、
前記方法は、
前記ウェブ・ブラウザによって発信された通信に対応するHTTPデータ・ストリームを、前記外部通信リンクでHTTPデータ・ストリームを送信する前にインタセプトするステップと、
前記ウェブ・ブラウザによって発信された前記HTTPデータ・ストリームを、前記HTTPプロトコルからクライアント/サーバ固有通信プロトコルに変換するステップと、
前記外部通信リンクを介して、前記変換されたウェブ・ブラウザ発信通信を前記第2のコンピュータに前記クライアント/サーバ固有データ・ストリームとして送信するステップと、
前記外部通信リンクを介して送信されたクライアント/サーバ固有データ・ストリームを受信するステップと、
前記クライアント/サーバ固有通信プロトコルで受信した前記クライアント/サーバ固有データ・ストリームをHTTPデータ・ストリームに変換することによって、前記ウェブ・ブラウザからの通信に対応する前記HTTPデータ・ストリームを、前記外部通信リンクを介して受信した前記クライアント/サーバ固有データ・ストリームから再構築するステップと、
前記ウェブ・ブラウザによって発信された前記通信を、前記ウェブ・サーバにHTTPデータ・ストリームとして供給するステップと
を含み、
前記ウェブ・ブラウザ発信通信が、共通ゲートウェイ・インタフェース(CGI)要求に対応し、
前記方法が、
前記インタセプトされたCGI要求に問い合わせて、前記インタセプトされたCGI要求に対応するクライアント・ベース・キャッシュ項目が存在するかどうかを判断し、クライアントCGIベース書式を供給するステップと、
前記インタセプトされたCGI要求に問い合わせて、前記インタセプトされたCGI要求に対応するサーバ・ベース・キャッシュ項目が存在するかどうかを判断し、サーバCGIベース書式を供給するステップと、
共通ゲートウェイ・インタフェース(CGI)に対する要求であるブラウザ発信通信に応答して前記ウェブ・サーバから受信したHTTPデータ・ストリームを前記第2のコンピュータにあるキャッシュに格納して、サーバ・ベース・キャッシュ項目を作成するステップと、
CGIに対する要求であるブラウザ発信通信に応答して前記ウェブ・ブラウザに供給されるべきHTTPデータ・ストリームを前記第1のコンピュータにあるキャッシュに格納して、クライアント・ベース・キャッシュ項目を作成するステップと、
前記インタセプトされたCGI要求に応答して前記ウェブ・サーバによって発信された前記通信に対応する前記HTTPデータ・ストリームを、前記外部通信リンクで前記HTTPデータ・ストリームを送信する前にインタセプトするステップと、
前記インタセプトされたCGI要求を前記サーバCGIベース書式と比較して、前記インタセプトされたCGI応答とサーバCGIベース書式との差分に対応するCGI差分データ供給するステップと、
前記ウェブ・ブラウザに対するCGI差分データを前記外部通信リンクを介して前記第1のコンピュータに、クライアント/サーバ固有データ・ストリームとして送信するステップと、
前記第2のコンピュータによって送信された前記外部通信リンクを介して伝送された前記クライアント/サーバ固有データ・ストリームを入手するステップと
をさらに含み、
前記再構築するステップが、前記クライアントCGIベース書式を前記外部通信リンクを介して受信したCGI差分データと結合して前記インタセプトされたCGI応答に対応するHTTPデータ・ストリームを作成することによって、ウェブ・サーバからの通信に対応するHTTPデータ・ストリームを、前記外部通信リンクを介して受信した前記クライアント/サーバ固有データ・ストリームから再構築するステップを含み、
前記供給するステップが、前記ウェブ・サーバによって発信された前記通信を前記ウェブ・ブラウザにHTTPデータ・ストリームとして供給する、方法。 - 前記送信するステップが、前記変換されたウェブ・ブラウザ発信通信を、無線通信リンクを介して送信するステップをさらに含む、請求項1に記載の方法。
- 前記ウェブ・サーバとのウェブ・ブラウザ発信通信に応答して、前記ウェブ・ブラウザによって受信されるべきHTTPデータ・ストリームを前記第1のコンピュータ内にあるキャッシュに格納して、前記ウェブ・サーバとの前記ウェブ・ブラウザ発信通信に対応するクライアント・キャッシュ項目を作成するステップと、
前記ウェブ・ブラウザ発信通信に問い合わせて、前記ウェブ・ブラウザ発信通信に対応するクライアント・キャッシュ項目が存在するかどうかを判断するステップと
をさらに含み、
前記ウェブ・ブラウザ発信通信に対応するクライアント・キャッシュ項目が存在する場合には、前記変換するステップ、前記送信するステップ、前記受信するステップ、前記再構築するステップ、および前記供給するステップの代わりに、
前記ウェブ・ブラウザ発信通信に応答して前記ウェブ・ブラウザに前記クライアント・キャッシュ項目をHTTPデータ・ストリームとして供給するステップを行う、請求項1に記載の方法。 - 前記第1のコンピュータ内にある前記ユーザ定義情報を提供するために、特定のウェブ・ブラウザ情報要求に関連づけられたユーザ定義情報を格納するステップと、
前記ウェブ・ブラウザ発信通信に問い合わせて、前記ウェブ・ブラウザによって要求された前記情報が、ユーザ定義情報が格納されている要求に対応しているかどうかを判断するステップと、
をさらに含み、
前記問い合わせするステップによって前記ウェブ・ブラウザ通信がユーザ定義情報が格納されている要求に対応すると判断された場合に、前記供給するステップが、前記ウェブ・ブラウザ発信通信に応答して前記ユーザ定義格納情報を前記ウェブ・ブラウザにHTTPデータ・ストリームとして供給するステップを含み、
前記ユーザ定義格納情報がウェブ・ブラウザに供給される場合に、前記送信するステップ、前記受信するステップ、および前記再構築するステップの代わりに前記問い合わせするステップが行われる、請求項1に記載の方法。 - 前記通信リンクを介して、前記第1のコンピュータから前記ユーザ定義情報を受信するステップをさらに含む、請求項4に記載の方法。
- 前記格納するステップが、クライアント・キャッシュ項目の作成時刻を格納して、クライアント・キャッシュ項目時間レコードを作成するステップをさらに含み、
前記問い合わせするステップが、前記クライアント・キャッシュ項目時間レコードを評価して、前記ウェブ・ブラウザ・ブラウザ発信通信に対応する前記クライアント・キャッシュ項目が、前記ウェブ・ブラウザが前記情報を要求する前の所定のクライアント・コヒーレンシ時間間隔内に作成されたかどうかを判断するステップをさらに含み、
前記供給するステップが、前記判断するステップによってクライアント・キャッシュ項目が前記ウェブ・ブラウザが前記情報を要求する前に所定のクライアント・コヒーレンシ時間間隔内に作成されたと判断された場合、前記ウェブ・ブラウザ発信通信に応答して前記ウェブ・ブラウザに前記クライアント・キャッシュ項目をHTTPデータ・ストリームとして供給するステップを含む、請求項3に記載の方法。 - 前記ウェブ・ブラウザの複数のインスタンスにわたってクライアント・キャッシュ項目を維持するステップをさらに含む、請求項6に記載の方法。
- 前記ブラウザ発信通信に応答して前記ウェブ・サーバから受信した前記HTTPデータ・ストリームを前記第2のコンピュータにあるキャッシュに格納して、サーバ要求キャッシュ項目を作成するステップと、
前記ウェブ・ブラウザ発信通信に問い合わせて、前記ブラウザ発信通信に対応するサーバ要求キャッシュ項目が前記キャッシュに前に格納されているかどうかを判断するステップと、
前記ブラウザ発信通信に関連づけられた前記サーバ要求キャッシュ項目をクライアント/サーバ固有通信プロトコルに変換するステップと、
前記変換されたサーバ要求キャッシュ項目を前記外部通信リンクを介して前記第1のコンピュータにクライアント/サーバ固有データ・ストリームとして送信するステップと、及び
前記外部通信リンクを介して送信された前記クライアント/サーバ固有データ・ストリームを入手するステップと
をさらに含み、
前記再構築するステップが、前記クライアント/サーバ固有通信プロトコルで受信した前記クライアント/サーバ固有データ・ストリームをHTTPデータ・ストリームに変換することによって、前記サーバ要求キャッシュ項目に対応する前記HTTPデータ・ストリームを、前記外部通信リンクを介して受信した前記クライアント/サーバ固有データ・ストリームから再構築するステップを含み、
前記供給するステップが、前記ウェブ・ブラウザによって要求された前記情報に対応する前記サーバ要求キャッシュ項目を前記ウェブ・ブラウザにHTTPデータ・ストリームとして供給するステップを含む、請求項1に記載の方法。 - ブラウザ発信通信に応答して前記ウェブ・サーバから受信した前記HTTPデータ・ストリームを前記第2のコンピュータ内にあるキャッシュに格納して、サーバ要求キャッシュ項目を作成するステップと、
前記ウェブ・ブラウザ発信通信を評価して、前記ウェブ・ブラウザ発信通信に対応するサーバ要求キャッシュ項目が存在するかどうかを判断するステップと、
前記ブラウザ発信通信に対応する前記サーバ要求キャッシュ項目をクライアント/サーバ固有通信プロトコルに変換するステップと、
前記外部通信リンクでクライアント/サーバ固有データ・ストリームを送信することによって、前記外部通信リンクを介して前記第1のコンピュータに前記サーバ要求キャッシュ項目を送信するステップと、
前記第2のコンピュータによって前記外部通信リンクを介して送信された前記クライアント/サーバ特定データを入手するステップと
をさらに含み、
前記再構築するステップが、前記クライアント/サーバ固有通信プロトコルで受信した前記クライアント/サーバ固有データ・ストリームをHTTPデータ・ストリームに変換することによって、サーバ・キャッシュ項目に対応する前記HTTPデータ・ストリームを、前記外部通信リンクを介して受信した前記クライアント/サーバ固有データ・ストリームから再構築するステップを含み、
前記供給するステップが、前記ウェブ・ブラウザによって要求された前記情報に対応する前記サーバ要求キャッシュ項目を前記ウェブ・ブラウザにHTTPデータ・ストリームとして転送するステップを含む、請求項6に記載の方法。 - 前記ウェブ・ブラウザ発信通信に対応するサーバ要求キャッシュ項目が、前記第2のコンピュータが前記ウェブ・ブラウザ発信通信を受信する前に所定のクライアント・コヒーレンシ時間間隔内に作成されたかどうかを判断するステップをさらに含み、
前記変換するステップが、前記判断するステップによって前記サーバ要求キャッシュ項目が前記所定のクライアント・コヒーレンシ時間間隔内に作成されたと判断された場合に、前記ウェブ・ブラウザ発信通信に対応する前記サーバ要求キャッシュ項目をクライアント/サーバ固有通信プロトコルに変換するステップを含む、請求項9に記載の方法。 - 前記ウェブ・ブラウザ発信通信に対応するサーバ・キャッシュ項目と同じ前記ウェブ・ブラウザ発信通信に対応するクライアント・キャッシュ項目が存在するかどうかを判断するステップをさらに含み、
前記変換するステップが、前記第2のコンピュータが前記ウェブ・ブラウザ発信通信を受信した時点とウェブ・ブラウザ発信通信に対応するサーバ要求キャッシュ項目が作成された時点との間の間隔を計算して項目エージ・データを供給するステップを含み、
前記送信するステップが、前記ウェブ・ブラウザ発信通信に対応する前記サーバ・キャッシュ項目の前記項目エージ・データを含むコヒーレント項目応答を前記クライアント/サーバ固有プロトコルとして前記外部通信リンクを介して前記第1のコンピュータに送信するステップを含み、
前記再構築するステップが、前記第1のコンピュータの現在時刻からコヒーレント項目応答から受け取った項目エージ・データを引くことによって、前記ウェブ・ブラウザ発信通信に対応する前記クライアント・キャッシュ項目時間レコードを更新するステップを含み、
前記供給するステップが、前記外部通信リンクからコヒーレント項目応答を受け取った場合に、前記ウェブ・ブラウザ発信通信に対応する前記クライアント・キャッシュ項目として格納されたHTTPデータ・ストリームをウェブ・ブラウザにHTTPデータ・ストリームとして転送するステップを含む、請求項9に記載の方法。 - 前記サーバCGIベース書式が前記クライアントCGIベース書式と同じかどうかを判断するステップをさらに含み、
前記送信するステップが、前記サーバCGIベース書式を送信し、かつ前記CGI差分データを前記外部通信回線を介して前記ウェブ・ブラウザにクライアント/サーバ固有データ・ストリームとして送信するステップを含み、
前記再構築するステップが、前記サーバCGIベース書式を外部通信回線を介して受信したCGI差分データと結合して前記インタセプトされたCGI応答に対応するHTTPデータ・ストリームを作成することによって、前記ウェブ・サーバからの前記通信に対応する前記HTTPデータ・ストリームを、前記外部通信リンクを介して受信した前記クライアント/サーバ固有データ・ストリームから再構築するステップを含み、
前記受信したサーバCGIベース書式を前記CGI要求に対応する前記クライアント・ベース・キャッシュ項目として格納することによって、前記CGI要求に対応する前記クライアントCGIベース書式を更新するステップをさらに含む、請求項1に記載の方法。 - 前記サーバCGIベース書式と前記CGI応答との前記差分が事前定義差分しきい値より大きいかどうかを判断するステップと、
前記サーバCGIベース書式とCGI応答との間の差分が事前定義差分しきい値より大きいと前記判断するステップにおいて判断した場合、前記ウェブ・サーバから受信した前記CGI応答を前記CGI要求に対応する前記サーバ・ベース・キャッシュ項目として格納することによって、前記CGI要求に対応する前記サーバCGIベース書式を更新するステップとをさらに含み、
前記比較することおよび前記送信するステップが、更新されたサーバCGIベース書式を使用する、請求項12に記載の方法。 - 前記外部通信リンクを介して前記第1のコンピュータと前記第2のコンピュータとの間に持続的接続を確立するステップと、
すべてのウェブ・ブラウザ発信通信が完了するまで前記持続的接続を維持するステップと
をさらに含み、
前記インタセプト・ステップが、複数のウェブ・ブラウザ発信通信をインタセプトするステップと、及び前記持続的接続を維持している間にそれらのウェブ・ブラウザ発信通信を前記外部通信リンクに多重化するステップとを含む、請求項1に記載の方法。 - 前記再構築するステップが、前記クライアント/サーバ固有データ・ストリームを多重化解除して、複数のHTTPデータ・ストリームを作成するステップを含み、
前記供給するステップが、前記複数のHTTPデータ・ストリームを前記ウェブ・サーバに供給するステップを含む、請求項14に記載の方法。 - 前記外部通信リンクを介して前記第2のコンピュータに前記第1のコンピュータの事前定義特性に対応するコンピュータ固有情報を供給するステップと、
前記第1のコンピュータの事前定義特性に対応するコンピュータ固有情報を格納してブラウザ・ヘッダ情報を供給するステップと
をさらに含み、
前記変換するステップが、前記ウェブ・ブラウザ発信通信から前記コンピュータ固有情報を取り除くステップを含み、
前記再構築するステップが、前記ブラウザ・ヘッダ情報を前記クライアント/サーバ固有データ・ストリームと結合してHTTPデータ・ストリームを作成するステップを含む、請求項1に記載の方法。 - 前記ウェブ・サーバによって発信された通信に対応する前記HTTPデータ・ストリームを、前記外部通信リンクで送信する前に、キャプチャするステップと、
前記ウェブ・サーバによって発信された前記HTTPデータ・ストリームを前記HTTPプロトコルからクライアント/サーバ固有通信プロトコルに変換するステップと、
前記変換されたウェブ・サーバ発信通信を前記外部通信リンクを介してクライアント/サーバ固有データ・ストリームとして前記ウェブ・ブラウザに送信するステップと、
前記外部通信リンクを介して送信された前記クライアント/サーバ固有データ・ストリームを入手するステップと、
前記クライアント/サーバ固有通信プロトコルで受信したクライアント/サーバ固有データ・ストリームをHTTPデータ・ストリームに変換することによって、前記外部通信リンクを介して受信した前記クライアント/サーバ固有データ・ストリームから、前記ウェブ・サーバからの通信に対応する前記HTTPデータ・ストリームを再構築するステップと、及び
前記ウェブ・サーバによって発信された前記通信を前記ウェブ・ブラウザにHTTPデータ・ストリームとして供給するステップと
をさらに含む、請求項1に記載の方法。 - 前記外部通信リンクを介して前記第1のコンピュータに、前記第2のコンピュータの事前定義特性に対応するコンピュータ固有情報を提供するステップと、
第2のコンピュータの前記事前定義特性に対応する前記コンピュータ固有情報を格納して、サーバ・ヘッダ情報を供給するステップと
をさらに含み、
前記変換するステップが前記ウェブ・サーバ発信通信から前記コンピュータ固有情報を取り除くステップを含み、
前記再構築するステップが、前記サーバ・ヘッダ情報を前記クライアント/サーバ固有データ・ストリームと結合して、HTTPデータ・ストリームを作成するステップを含む、請求項17に記載の方法。 - 前記第1のコンピュータと前記第2のコンピュータの間に前記外部通信リンクを介して持続的接続を確立するステップと、
すべてのウェブ・サーバ発信通信が完了するまで前記持続的接続を維持するステップと
をさらに含み、
前記キャプチャするステップが、複数のウェブ・サーバ発信通信をインタセプトし、かつ前記持続的接続を維持している間にそれらのウェブ・サーバ発信通信を前記外部通信リンクに多重化するステップとを含む、請求項17に記載の方法。 - 第1のコンピュータ上に常駐しかつ第1のコンピュータからは遠隔にある第2のコンピュータ上に常駐するウェブ・サーバ・アプリケーションとハイパーテキスト転送プロトコル(HTTP)を使用して通信するウェブ・ブラウザ・アプリケーションのパフォーマンスを向上する方法であって、前記第1のコンピュータ内のウェブ・ブラウザ・アプリケーションと前記第2のコンピュータ内のウェブ・サーバ・アプリケーションとの間の通信が外部通信リンクを介して行われ、
前記方法は、
前記ウェブ・ブラウザによって発信された通信に対応するHTTPデータ・ストリームを、前記外部通信リンクでHTTPデータ・ストリームを送信する前にインタセプトするステップと、
前記ウェブ・ブラウザによって発信された前記HTTPデータ・ストリームを、前記HTTPプロトコルからクライアント/サーバ固有通信プロトコルに変換するステップと、
前記外部通信リンクを介して、前記変換されたウェブ・ブラウザ発信通信を前記ウェブ・サーバに前記クライアント/サーバ固有データ・ストリームとして送信するステップと
を含み、
前記ウェブ・ブラウザ発信通信が、共通ゲートウェイ・インタフェース(CGI)要求に対応し、
前記方法が、
前記インタセプトされたCGI要求に問い合わせて、前記インタセプトされたCGI要求に対応するクライアント・ベース・キャッシュ項目が存在するかどうかを判断し、クライアントCGIベース書式を供給するステップと、
CGIに対する要求であるブラウザ発信通信に応答して前記ウェブ・ブラウザに供給されるべきHTTPデータ・ストリームを、第1のコンピュータ内にあるキャッシュに格納して、クライアント・ベース・キャッシュ項目を作成するステップと、
前記クライアントCGIベース書式を外部通信リンクを介して受信したCGI差分データと結合してHTTPデータ・ストリームを作成することによって、前記ウェブ・サーバからの通信に対応する前記HTTPデータ・ストリームを、前記外部通信リンクを介して受信した前記クライアント/サーバ固有データ・ストリームから再構築するステップと、
前記ウェブ・サーバによって発信された前記通信をウェブ・ブラウザにHTTPデータ・ストリームとして供給するステップと
をさらに含む、方法。 - 前記送信するステップが、前記変換されたウェブ・ブラウザ発信通信を無線通信リンクを介して送信するステップを含む、請求項20に記載の方法。
- 前記ウェブ・サーバとのウェブ・ブラウザ発信通信に応答して、前記ウェブ・ブラウザによって受信されるべきHTTPデータ・ストリームを前記第1のコンピュータ内にあるキャッシュに格納して、前記ウェブ・サーバとの前記ウェブ・ブラウザ発信通信に対応するクライアント・キャッシュ項目を作成するステップと、
前記ウェブ・ブラウザ発信通信に問い合わせて、前記ウェブ・ブラウザ発信通信に対応するクライアント・キャッシュ項目が存在するかどうかを判断するステップと
をさらに含み、
前記ウェブ・ブラウザ発信通信に対応するクライアント・キャッシュ項目が存在する場合には、前記変換するステップおよび前記送信するステップの代わりに、
前記ウェブ・ブラウザ発信通信に応答して前記ウェブ・ブラウザに前記クライアント・キャッシュ項目をHTTPデータ・ストリームとして供給するステップを行う、請求項20に記載の方法。 - 前記第1のコンピュータ内にある前記ユーザ定義情報が提供するために、固有のウェブ・ブラウザ情報に関連づけられたユーザ定義情報を格納するステップと、
前記ウェブ・ブラウザ発信通信に問い合わせて、前記ウェブ・ブラウザによって要求された情報が、ユーザ定義情報が格納されている要求に対応しているかどうかを判断するステップと、
前記問い合わせするステップによって前記ウェブ・ブラウザ通信がユーザ定義情報が格納されている要求に対応していると判断された場合に、前記ウェブ・ブラウザ発信通信に応答して前記ユーザ定義格納情報を前記ウェブ・ブラウザにHTTPデータ・ストリームとして供給するステップとをさらに含み、
前記ユーザ定義格納情報を前記ウェブ・ブラウザに供給する場合、前記問い合わせするステップおよび前記供給するステップの代わりに前記送信するステップが行われる、請求項20に記載の方法。 - 前記通信リンクを介して前記第1のコンピュータから前記ユーザ定義情報を受信するステップをさらに含む、請求項23に記載の方法。
- 前記格納するステップが、クライアント・キャッシュ項目の作成時刻を格納して、クライアント・キャッシュ項目時間レコードを作成するステップをさらに含み、
前記問い合わせするステップが、前記クライアント・キャッシュ項目時間レコードを評価して、前記ウェブ・ブラウザ発信通信に対応する前記クライアント・キャッシュ項目が前記ウェブ・ブラウザが前記情報を要求する前に所定のクライアント・コヒーレンシ時間間隔内に作成されたかどうかを判断するステップをさらに含み、
前記供給するステップが、前記判断するステップによってクライアント・キャッシュ項目が前記ウェブ・ブラウザが情報を要求する前に所定のクライアント・コヒーレンシ時間間隔内に作成されたと判断された場合に、前記ウェブ・ブラウザ発信通信に応答してクライアント・キャッシュ項目を前記ウェブ・ブラウザにHTTPデータ・ストリームとして供給するステップを含む、請求項22に記載の方法。 - 前記ウェブ・ブラウザの複数のインスタンスにわたってクライアント・キャッシュ項目を維持するステップをさらに含む、請求項25に記載の方法。
- 前記再構築するステップが、前記外部通信リンクを介して受信したCGIベース書式を前記外部通信リンクを介して受信したCGI差分データと結合して前記インタセプトされたCGI応答に対応するHTTPデータ・ストリームを作成することによって、前記ウェブ・サーバからの通信に対応する前記HTTPデータ・ストリームを、前記外部通信リンクを介して受信した前記クライアント/サーバ固有データ・ストリームから再構築するステップを含み、
前記受信したサーバCGIベース書式を前記CGI要求に対応する前記クライアント・ベース・キャッシュ項目として格納することによって、前記CGI要求に対応する前記クライアントCGIベース書式を更新するステップをさらに含む、請求項20に記載の方法。 - 前記外部通信リンクを介して前記第1のコンピュータと前記第2のコンピュータの間に持続的接続を確立するステップと、
すべてのウェブ・ブラウザ発信通信が完了するまで前記持続的接続を維持するステップとをさらに含み、
前記インタセプト・ステップが、複数のウェブ・ブラウザ発信通信をインタセプトするステップと、及び前記持続的接続を維持している間にそれらの複数のウェブ・ブラウザ発信通信を前記外部通信リンクに多重化するステップを含む、請求項20に記載の方法。 - 前記外部通信リンクを介して前記第2のコンピュータからクライアント/サーバ固有データ・ストリームを受信するステップと、
前記ウェブ・ブラウザに前記複数のHTTPデータ・ストリームを供給するためにクライアント/サーバ固有データ・ストリームを多重化解除して複数のHTTPデータ・ストリームを作成するステップと、
前記複数のHTTPデータ・ストリームを前記ウェブ・ブラウザに供給するステップとをさらに含む、請求項28に記載の方法。 - 前記外部通信リンクを介して前記第2のコンピュータに前記第1のコンピュータの事前定義特性に対応するコンピュータ固有情報を供給するステップをさらに含み、
前記変換するステップが、ウェブ・ブラウザ発信通信からコンピュータ固有情報を取り除くステップを含む、請求項20に記載の方法。 - 第1のコンピュータ上に常駐しかつ第1のコンピュータからは遠隔にある第2のコンピュータ上に常駐するウェブ・サーバ・アプリケーションとハイパーテキスト転送プロトコル(HTTP)を使用して通信するウェブ・ブラウザ・アプリケーションのパフォーマンスを向上する方法であって、前記第1のコンピュータ内のウェブ・ブラウザ・アプリケーションと前記第2のコンピュータ内のウェブ・サーバ・アプリケーションとの間の通信が外部通信リンクを介して行われ、
前記方法は、
前記ウェブ・サーバによって発信された通信に対応するHTTPデータ・ストリームを、前記外部通信リンクでHTTPデータ・ストリームを送信する前にインタセプトするステップと、
前記ウェブ・サーバによって発信された前記HTTPデータ・ストリームを、前記HTTPプロトコルからクライアント/サーバ固有通信プロトコルに変換するステップと、
前記外部通信リンクを介して、前記変換されたウェブ・サーバ発信通信を前記ウェブ・ブラウザに前記クライアント/サーバ固有データ・ストリームとして送信するステップと
を含み、
前記ウェブ・ブラウザ発信通信が、共通ゲートウェイ・インタフェース(CGI)要求に対応し、
前記方法が、
前記インタセプトされたCGI要求に問い合わせて、前記インタセプトされたCGI要求に対応するサーバ・ベース・キャッシュ項目が存在するかどうかを判断し、サーバCGIベース書式を提供するステップと、
共通ゲートウェイ・インタフェース(CGI)に対する要求であるブラウザ発信通信に応答して前記ウェブ・サーバから受信したHTTPデータ・ストリームを前記第2のコンピュータ内にあるキャッシュに格納して、サーバ・ベース・キャッシュ項目を作成するステップと
をさらに含み、
前記インタセプトするステップが、前記インタセプトされたCGI要求に応答して前記ウェブ・サーバによって発信された前記通信に対応する前記HTTPデータ・ストリームを、前記外部通信リンクで送信する前にインタセプトするステップと、
前記インタセプトされたCGI応答を前記サーバCGIベース書式と比較して、前記インタセプトされたCGI応答と前記サーバCGIベース書式との差分に対応するCGI差分データを提供するステップとを含み、
前記送信するステップが、前記CGI差分データを前記外部通信リンクを介してクライアント/サーバ固有データ・ストリームとして前記ウェブ・ブラウザに送信するステップを含む、方法。 - ブラウザ発信通信に応答して前記ウェブ・サーバから受信した前記HTTPデータ・ストリームを前記第2のコンピュータ内にあるキャッシュに格納して、サーバ要求キャッシュ項目を作成するステップと、
前記ウェブ・ブラウザ発信通信をインタセプトして、前記ブラウザ発信通信に対応するサーバ要求キャッシュ項目がキャッシュに前に格納されているかどうかを判断するステップとをさらに含み、
前記変換するステップが、前記ブラウザ発信通信に関連づけられた前記サーバ要求キャッシュ項目をクライアント/サーバ固有通信プロトコルに変換するステップを含み、
前記送信するステップが、前記変換されたサーバ要求キャッシュ項目を前記外部通信リンクを介して前記第1のコンピュータにクライアント/サーバ固有データ・ストリームとして送信するステップを含む、請求項31に記載の方法。 - 前記ウェブ・ブラウザ発信通信に対応するサーバ要求キャッシュ項目が、前記第2のコンピュータが前記ウェブ・ブラウザ発信通信を受信する前に所定のクライアント・コヒーレンシ時間間隔内に作成されたかどうかを判断するステップをさらに含み、
前記変換するステップが、前記判断するステップによって前記サーバ要求キャッシュ項目が前記所定のクライアント・コヒーレンシ時間間隔で作成されたと判断された場合に前記ウェブ・ブラウザ発信通信に対応する前記サーバ要求キャッシュ項目をクライアント/サーバ固有通信プロトコルに変換するステップを含む、請求項32に記載の方法。 - 前記ウェブ・ブラウザ発信通信に対応するサーバ・キャッシュ項目と同じ前記ウェブ・ブラウザ発信通信に対応するクライアント・キャッシュ項目が存在するかどうかを判断するステップをさらに含み、
前記変換するステップが、前記第2のコンピュータが前記ウェブ・ブラウザ発信通信を受信した時点と前記ウェブ・ブラウザ発信通信に対応するサーバ要求キャッシュ項目が作成された時点との間の時間間隔を計算して項目エージ・データを供給するステップを含み、
前記送信するステップが、前記ウェブ・ブラウザ発信通信に対応する前記サーバ・キャッシュ項目の前記項目エージ・データを含むコヒーレント項目応答を前記クライアント/サーバ固有プロトコルとして外部通信リンクを介して第1のコンピュータに送信するステップを含む、請求項32に記載の方法。 - 前記サーバCGIベース書式が前記CGI要求に対応するクライアントCGIベース書式と同じかどうかを判断するステップをさらに含み、
前記送信するステップが、前記サーバCGIベース書式を送信し、かつ前記CGI差分データを前記外部通信リンクを介してクライアント/サーバ固有データ・ストリームとして前記ウェブ・ブラウザに送信するステップを含む、請求項31に記載の方法。 - 前記サーバCGIベース書式と前記CGI応答との前記差分が事前定義差分しきい値より大きいかどうかを判断するステップと、
前記判断するステップによってサーバCGIベース書式とCGI応答との間の差分が事前定義差分しきい値より大きいと判断された場合、前記CGI要求に対応する前記サーバ・ベース・キャッシュ項目として前記ウェブ・サーバから前記受信したCGI応答を格納することによって、前記CGI要求に対応する前記サーバCGIベース書式を更新するステップとをさらに含み、
前記比較することおよび前記送信するステップが、前記更新されたサーバCGIベース書式を使用する、請求項31に記載の方法。 - 前記外部通信リンクを介して前記第1のコンピュータと前記第2のコンピュータの間に持続的接続を確立するステップと、
すべてのウェブ・ブラウザ発信通信が完了するまで前記持続的接続を維持するステップと
をさらに含み、
前記インタセプト・ステップが、複数のウェブ・サーバ発信通信をインタセプトするステップと、及び前記持続的接続を維持している間にそれらのウェブ・サーバ発信通信を前記外部通信リンクに多重化するステップとを含む、請求項31に記載の方法。 - 第1のコンピュータ上に常駐しかつ第1のコンピュータからは遠隔にある第2のコンピュータ上に常駐するウェブ・サーバ・アプリケーションとハイパーテキスト転送プロトコル(HTTP)を使用して通信するウェブ・ブラウザ・アプリケーションのパフォーマンスを向上させる装置であって、前記第1のコンピュータ内のウェブ・ブラウザ・アプリケーションと前記第2のコンピュータ内のウェブ・サーバ・アプリケーションとの間の通信が外部通信リンクを介して行われ、
前記装置は、
前記ウェブ・ブラウザによって発信された通信に対応するHTTPデータ・ストリームを、前記外部通信リンクでHTTPデータ・ストリームを送信する前にインタセプトする手段と、
前記ウェブ・ブラウザによって発信された前記HTTPデータ・ストリームを、前記HTTPプロトコルからクライアント/サーバ固有通信プロトコルに変換する手段と、
前記外部通信リンクを介して、前記変換されたウェブ・ブラウザ発信通信を前記第2のコンピュータに前記クライアント/サーバ固有データ・ストリームとして送信する手段と、
前記外部通信リンクを介して送信されたクライアント/サーバ固有データ・ストリームを受信する手段と、
前記クライアント/サーバ固有通信プロトコルで受信した前記クライアント/サーバ固有データ・ストリームをHTTPデータ・ストリームに変換することによって、前記ウェブ・ブラウザからの通信に対応する前記HTTPデータ・ストリームを、前記外部通信リンクを介して受信した前記クライアント/サーバ固有データ・ストリームから再構築する手段と、
前記ウェブ・ブラウザによって発信された前記通信を、前記ウェブ・サーバにHTTPデータ・ストリームとして供給する手段と
を含み、
前記インタセプトされたウェブ・ブラウザ発信通信がインタセプトされたCGI要求であり、
前記インタセプトされたCGI要求に問い合わせて、前記インタセプトされたCGI要求に対応するクライアント・ベース・キャッシュ項目が存在するかどうかを判断し、クライアントCGIベース書式を供給する手段と、
前記インタセプトされたCGI要求に問い合わせて、前記インタセプトされたCGI要求に対応するサーバ・ベース・キャッシュ項目が存在するかどうかを判断し、サーバCGIベース書式を供給する手段と、
共通ゲートウェイ・インタフェース(CGI)に対する要求であるブラウザ発信通信に応答して前記ウェブ・サーバから受信したHTTPデータ・ストリームを前記第2のコンピュータにあるキャッシュに格納して、サーバ・ベース・キャッシュ項目を作成する手段と、
CGIに対する要求であるブラウザ発信通信に応答して前記ウェブ・ブラウザに供給されるべきHTTPデータ・ストリームを前記第1のコンピュータにあるキャッシュに格納して、クライアント・ベース・キャッシュ項目を作成する手段と、
前記インタセプトされたCGI要求に応答して前記ウェブ・サーバによって発信された前記通信に対応する前記HTTPデータ・ストリームを、前記外部通信リンクで前記HTTPデータ・ストリームを送信する前にインタセプトする手段と、
前記インタセプトされたCGI要求を前記サーバCGIベース書式と比較して、前記インタセプトされたCGI応答とサーバCGIベース書式との差分に対応するCGI差分データを供給する手段と、
前記ウェブ・ブラウザに対するCGI差分データを前記外部通信リンクを介して前記第1のコンピュータに、クライアント/サーバ固有データ・ストリームとして送信する手段と、
前記第2のコンピュータによって送信された前記外部通信リンクを介して伝送された前記クライアント/サーバ固有データ・ストリームを入手する手段と
をさらに含み、
前記再構築する手段が、前記クライアントCGIベース書式を前記外部通信リンクを介して受信したCGI差分データと結合して前記インタセプトされたCGI応答に対応するHTTPデータ・ストリームを作成することによって、ウェブ・サーバからの通信に対応するHTTPデータ・ストリームを、前記外部通信リンクを介して受信した前記クライアント/サーバ固有データ・ストリームから再構築する手段を含み、
前記供給する手段が、前記ウェブ・サーバによって発信された前記通信を前記ウェブ・ブラウザにHTTPデータ・ストリームとして供給する、装置。 - 前記送信する手段が、前記変換されたウェブ・ブラウザ発信通信を、無線通信リンクを介して送信する手段をさらに含む、請求項38に記載の装置。
- 前記ウェブ・サーバとのウェブ・ブラウザ発信通信に応答して、前記ウェブ・ブラウザによって受信されるべきHTTPデータ・ストリームを前記第1のコンピュータ内にあるキャッシュに格納して、前記ウェブ・サーバとの前記ウェブ・ブラウザ発信通信に対応するクライアント・キャッシュ項目を作成する手段と、
前記ウェブ発信通信に問い合わせて、前記ウェブ・ブラウザ発信通信に対応するクライアント・キャッシュ項目が存在するかどうかを判断する手段と、
ウェブ・ブラウザ発信通信に応答してウェブ・ブラウザにクライアント・キャッシュ項目をHTTPデータ・ストリームとして供給する手段と
を含む、請求項38に記載の装置。 - 前記第1のコンピュータ内にある前記ユーザ定義情報が提供するために、特定のウェブ・ブラウザ情報要求に関連づけられたユーザ定義情報を格納する手段と、
前記ウェブ・ブラウザ発信通信に問い合わせて、前記ウェブ・ブラウザによって要求された前記情報が、ユーザ定義情報が格納されている要求に対応しているかどうかを判断する手段と、
をさらに含み、
前記問い合わせする手段によって前記ウェブ・ブラウザ通信がユーザ定義情報が格納されている要求に対応すると判断された場合に、前記供給する手段が、前記ウェブ・ブラウザ発信通信に応答して前記ユーザ定義格納情報を前記ウェブ・ブラウザにHTTPデータ・ストリームとして供給する手段を含む、請求項38に記載の装置。 - 前記通信リンクを介して、前記第1のコンピュータから前記ユーザ定義情報を受信する手段をさらに含む、請求項41に記載の装置。
- 前記格納する手段が、クライアント・キャッシュ項目の作成時刻を格納して、クライアント・キャッシュ項目時間レコードを作成する手段をさらに含み、
前記問い合わせする手段が、前記クライアント・キャッシュ項目時間レコードを評価して、前記ウェブ・ブラウザ発信通信に対応する前記クライアント・キャッシュ項目が、前記ウェブ・ブラウザが前記情報を要求する前の所定のクライアント・コヒーレンシ時間間隔内に作成されたかどうかを判断する手段をさらに含み、
前記供給する手段が、前記判断する手段によってクライアント・キャッシュ項目が前記ウェブ・ブラウザが前記情報を要求する前に所定のクライアント・コヒーレンシ時間間隔内に作成されたと判断された場合、前記ウェブ・ブラウザ発信通信に応答して前記ウェブ・ブラウザに前記クライアント・キャッシュ項目をHTTPデータ・ストリームとして供給する手段を含む、請求項40に記載の装置。 - 前記ウェブ・ブラウザの複数のインスタンスにわたってクライアント・キャッシュ項目を維持する手段をさらに含む、請求項43に記載の装置。
- 前記ブラウザ発信通信に応答して前記ウェブ・サーバから受信した前記HTTPデータ・ストリームを前記第2のコンピュータにあるキャッシュに格納して、サーバ要求キャッシュ項目を作成する手段と、
前記ウェブ・ブラウザ発信通信に問い合わせて、前記ブラウザ発信通信に対応するサーバ要求キャッシュ項目が前記キャッシュに前に格納されているかどうかを判断する手段と、
前記ブラウザ発信通信に関連づけられた前記サーバ要求キャッシュ項目をクライアント/サーバ固有通信プロトコルに変換する手段と、
前記変換されたサーバ要求キャッシュ項目を前記外部通信リンクを介して前記第1のコンピュータにクライアント/サーバ固有データ・ストリームとして送信する手段と、及び
及び外部通信リンクを介して送信された及びクライアント/サーバ固有データ・ストリームを入手する手段と
をさらに含み、
前記再構築する手段が、前記クライアント/サーバ固有通信プロトコルで受信した前記クライアント/サーバ固有データ・ストリームをHTTPデータ・ストリームに変換することによって、前記サーバ要求キャッシュ項目に対応する前記HTTPデータ・ストリームを、前記外部通信リンクを介して受信した前記クライアント/サーバ固有データ・ストリームから再構築する手段を含み、
前記供給する手段が、前記ウェブ・ブラウザによって要求された前記情報に対応する前記サーバ要求キャッシュ項目を前記ウェブ・ブラウザにHTTPデータ・ストリームとして供給する手段と
を含む、請求項38に記載の装置。 - ブラウザ発信通信に応答して前記ウェブ・サーバから受信した前記HTTPデータ・ストリームを前記第2のコンピュータ内にあるキャッシュに格納して、サーバ要求キャッシュ項目を作成する手段と、
前記ウェブ・ブラウザ発信通信を評価して、前記ウェブ・ブラウザ発信通信に対応するサーバ要求キャッシュ項目が存在するかどうかを判断する手段と、
前記ブラウザ発信通信に対応する前記サーバ要求キャッシュ項目をクライアント/サーバ固有通信プロトコルに変換する手段と、
前記外部通信リンクでクライアント/サーバ固有データ・ストリームを送信することによって、前記外部通信リンクを介して前記第1のコンピュータに前記サーバ要求キャッシュ項目を送信する手段と、
前記第2のコンピュータによって前記外部通信リンクを介して送信された前記クライアント/サーバ固有データ・ストリームを入手する手段と
をさらに含み、
前記再構築する手段が、前記クライアント/サーバ固有通信プロトコルで受信した前記クライアント/サーバ固有データ・ストリームをHTTPデータ・ストリームに変換することによって、サーバ・キャッシュ項目に対応する前記HTTPデータ・ストリームを、前記外部通信リンクを介して受信した前記クライアント/サーバ固有データ・ストリームから再構築する手段を含み、
前記供給する手段が、前記ウェブ・ブラウザによって要求された前記情報に対応する前記サーバ要求キャッシュ項目を前記ウェブ・ブラウザにHTTPデータ・ストリームとして転送する手段と
を含む、請求項43に記載の装置。 - 前記ウェブ・ブラウザ発信通信に対応するサーバ要求キャッシュ項目が、前記第2のコンピュータがウェブ・ブラウザ発信通信を受信する前に所定のクライアント・コヒーレンシ時間間隔内に作成されたかどうかを判断する手段をさらに含み、
前記変換する手段が、前記判断する手段によって前記サーバ要求キャッシュ項目が前記所定のクライアント・コヒーレンシ時間間隔内に作成されたと判断された場合に、前記ウェブ・ブラウザ発信通信に対応する前記サーバ要求キャッシュ項目をクライアント/サーバ固有通信プロトコルに変換する手段をさらに含む、請求項46に記載の装置。 - 前記ウェブ・ブラウザ発信通信に対応するサーバ・キャッシュ項目と同じウェブ・ブラウザ発信通信に対応するクライアント・キャッシュ項目が存在するかどうかを判断する手段をさらに含み、
前記変換する手段が、前記第2のコンピュータが前記ウェブ・ブラウザ発信通信を受信した時点とウェブ・ブラウザ発信通信に対応するサーバ要求キャッシュ項目が作成された時点との間の時間の間隔を計算して項目エージ・データを供給する手段を含み、
前記送信する手段が、前記ウェブ・ブラウザ発信通信に対応する前記サーバ・キャッシュ項目の前記項目エージ・データを含むコヒーレント項目応答を前記クライアント/サーバ固有プロトコルとして前記外部通信リンクを介して前記第1のコンピュータに送信する手段を含み、
前記再構築する手段が、前記第1のコンピュータの現在時刻からコヒーレント項目応答から受け取った項目エージ・データを引くことによって、前記ウェブ・ブラウザ発信通信に対応する前記クライアント・キャシュ項目時間レコードを更新する手段を含み、
前記供給する手段が、前記外部通信リンクからコヒーレント項目応答を受け取った場合に、前記ウェブ・ブラウザ発信通信に対応する前記クライアント・キャッシュ項目として格納されたHTTPデータ・ストリームをウェブ・ブラウザにHTTPデータ・ストリームとして転送する手段を含む、請求項46に記載の装置。 - 前記サーバCGIベース書式がクライアントCGIベース書式と同じかどうかを判断する手段をさらに含み、
前記送信する手段が、前記サーバCGIベース書式を送信し、かつ前記CGI差分データを前記外部通信リンクを介して前記ウェブ・ブラウザにクライアント/サーバ固有データ・ストリームとして送信する手段を含み、
前記再構築する手段が、前記サーバCGIベース書式を外部通信リンクを介して受信したCGI差分データと結合して前記インタセプトされたCGI応答に対応するHTTPデータ・ストリームを作成することによって、前記ウェブ・サーバからの前記通信に対応する前記HTTPデータ・ストリームを、前記外部通信リンクを介して受信した前記クライアントサーバ固有データ・ストリームから再構築する手段を含み、
前記受信したサーバCGIベース書式を前記CGI要求に対応する前記クライアント・ベース・キャッシュ項目として格納することによって、前記CGI要求に対応する前記クライアントCGIベース書式を更新する手段をさらに含む、請求項38に記載の装置。 - 前記サーバCGIベース書式と前記CGI応答との前記差分が事前定義差分しきい値より大きいかどうかを判断する手段と、
前記サーバCGIベース書式とCGI応答との間の差分が事前定義差分しきい値より大きいと前記判断する手段が判断した場合、前記ウェブ・サーバから受信した前記CGI要求を前記CGI要求に対応する前記サーバ・ベース・キャッシュ項目として格納することによって、前記CGI要求に対応する前記サーバCGIベース書式を更新する手段とをさらに含み、
前記比較することおよび前記送信する手段が、更新されたサーバCGIベース書式を使用する、請求項49に記載の装置。 - 前記外部通信リンクを介して前記第1のコンピュータと前記第2のコンピュータとの間に持続的接続を確立する手段と、
すべてのウェブ・ブラウザ発信通信が完了するまで前記持続的接続を維持する手段と
をさらに含み、
前記インタセプトする手段が、複数のウェブ・ブラウザ発信通信をインタセプトする手段と、及び前記持続的接続を維持している間にそれらのウェブ・ブラウザ発信通信を前記外部通信リンクに多重化する手段とを含む、請求項38に記載の装置。 - 前記外部通信リンクを介して前記第2のコンピュータに前記第1のコンピュータの事前定義特性に対応するコンピュータ固有情報を供給する手段と、
前記第1のコンピュータの事前定義特性に対応するコンピュータ固有情報を格納してブラウザ・ヘッダ情報を供給する手段と
をさらに含み、
前記変換する手段が、前記ウェブ・ブラウザ発信通信から前記コンピュータ固有情報を取り除く手段を含み、
前記再構築する手段が、前記ブラウザ・ヘッダ情報を前記クライアント/サーバ固有データ・ストリームと結合してHTTPデータ・ストリームを作成する手段を含む、請求項38に記載の装置。 - 前記ウェブ・サーバによって発信された通信に対応する前記HTTPデータ・ストリームを、前記外部通信リンクで送信する前にキャプチャする手段と、
前記ウェブ・サーバによって発信された前記HTTPデータ・ストリームを前記HTTPプロトコルからクライアント/サーバ固有通信プロトコルに変換する手段と、
前記変換されたウェブ・サーバ発信通信を前記外部通信リンクを介してクライアント/サーバ固有データ・ストリームとして前記ウェブ・ブラウザに送信する手段と、
前記外部通信リンクを介して送信された前記クライアント/サーバ固有データ・ストリームを入手する手段と、
前記クライアント/サーバ固有通信プロトコルで受信したクライアント/サーバ固有データ・ストリームをHTTPデータ・ストリームに変換することによって、前記ウェブ・サーバからの通信に対応する前記HTTPデータ・ストリームを、前記外部通信リンクを介して受信した前記クライアント/サーバ固有データ・ストリームから再構築する手段と、及び
前記ウェブ・サーバによって発信された前記通信を前記ウェブ・ブラウザにHTTPデータ・ストリームとして供給する手段とをさらに含む、請求項38に記載の装置。 - 前記外部通信リンクを介して前記第1のコンピュータに、前記第2のコンピュータの事前定義特性に対応するコンピュータ固有情報を提供する手段と、
第2のコンピュータの前記事前定義特性に対応する前記コンピュータ固有情報を格納して、サーバ・ヘッダ情報を供給する手段と
をさらに含み、
前期変換する手段が前記ウェブ・サーバ発信通信から前記コンピュータ固有情報を取り除く手段を含み、
前記再構築する手段が、前記サーバ・ヘッダ情報を前記クライアント/サーバ固有データ・ストリームと結合して、HTTPデータ・ストリームを作成する手段を含む、請求項53に記載の装置。 - 前記第1のコンピュータと前記第2のコンピュータの間に前記外部通信リンクを介して持続的接続を確立する手段と、
すべてのウェブ・サーバ発信通信が完了するまで前記持続的接続を維持する手段と
をさらに含み、
前記キャプチャする手段が、複数のウェブ・サーバ発信通信をインタセプトし、かつ前記持続的接続を維持している間にそれらのウェブ・サーバ発信通信を前記外部通信リンクに多重化する手段とを含む、請求項53に記載の装置。 - 第1のコンピュータ上に常駐しかつ第1のコンピュータからは遠隔にある第2のコンピュータ上に常駐するウェブ・サーバ・アプリケーションとハイパーテキスト転送プロトコル(HTTP)を使用して通信するウェブ・ブラウザ・アプリケーションのパフォーマンスを向上させる装置であって、前記第1のコンピュータ内のウェブ・ブラウザ・アプリケーションと前記第2のコンピュータ内のウェブ・サーバ・アプリケーションとの間の通信が外部通信リンクを介して行われ、
前記装置は、
前記ウェブ・ブラウザによって発信された通信に対応するHTTPデータ・ストリームを、前記外部通信リンクリンクでHTTPデータ・ストリームを送信する前にインタセプトする手段と、
前記ウェブ・ブラウザによって発信され前記たHTTPデータ・ストリームを、前記HTTPプロトコルからクライアント/サーバ固有通信プロトコルに変換する手段と、
前記外部通信リンクを介して、前記変換されたウェブ・ブラウザ発信通信を前記ウェブ・サーバに前記クライアント/サーバ固有データ・ストリームとして送信する手段と
を含み、
前記ウェブ・ブラウザ発信通信が、共通ゲートウェイ・インタフェース(CGI)要求に対応し、
前記装置が、
前記インタセプトされたCGI要求に問い合わせて、前記インタセプトされたCGI要求に対応するクライアント・ベース・キャッシュ項目が存在するかどうかを判断し、クライアントCGIベース書式を供給する手段と、
CGIに対する要求であるブラウザ発信通信に応答してウェブ・ブラウザに供給されるべきHTTPデータ・ストリームを、第1のコンピュータ内にあるキャッシュに格納して、クライアント・ベース・キャッシュ項目を作成する手段と、
前記クライアントCGIベース書式を外部通信リンクを介して受信したCGI差分データと結合してHTTPデータ・ストリームを作成することによって、前記ウェブ・サーバからの通信に対応する前記HTTPデータ・ストリームを、前記外部通信リンクを介して受信した前記クライアント/サーバ固有データ・ストリームから再構築する手段と、
前記ウェブ・サーバによって発信された前記通信をウェブ・ブラウザにHTTPデータ・ストリームとして供給する手段と
をさらに含む、装置。 - 前記送信する手段が、前記変換されたウェブ・ブラウザ発信通信を無線通信リンクを介して送信する手段を含む、請求項56に記載の装置。
- 前記ウェブ・サーバとのウェブ・ブラウザ発信通信に応答して、前記ウェブ・ブラウザによって受信されるべきHTTPデータ・ストリームを前記第1のコンピュータ内にあるキャッシュに格納して、前記ウェブ・サーバとの前記ウェブ・ブラウザ発信通信に対応するクライアント・キャッシュ項目を作成する手段と、
前記ウェブ・ブラウザ発信通信に問い合わせて、前記ウェブ・ブラウザ発信通信に対応するクライアント・キャッシュ項目が存在するかどうかを判断する手段と、
前記ウェブ・ブラウザ発信通信に応答して前記ウェブ・ブラウザに前記クライアント・キャッシュ項目をHTTPデータ・ストリームとして供給する手段と
を含む、請求項56に記載の装置。 - 前記第1のコンピュータ内にある前記ユーザ定義情報が提供するために、固有のウェブ・ブラウザ情報要求に関連づけられたユーザ定義情報を格納する手段と、
前記ウェブ・ブラウザ発信通信に問い合わせて、前記ウェブ・ブラウザによって要求された情報が、ユーザ定義情報が格納されている要求に対応しているかどうかを判断する手段と、
前記問い合わせする手段によって前記ウェブ・ブラウザ通信がユーザ定義情報が格納されている要求に対応していると判断された場合に、前記ウェブ・ブラウザ発信通信に応答して前記ユーザ定義格納情報を前記ウェブ・ブラウザにHTTPデータ・ストリームとして供給する手段と
をさらに含む、請求項56に記載の装置。 - 前記通信リンクを介して前記第1のコンピュータから前記ユーザ定義情報を受信する手段をさらに含む、請求項59に記載の装置。
- 前記格納する手段が、クライアント・キャッシュ項目の作成時刻を格納してクライアント・キャッシュ項目時間レコードを作成する手段をさらに含み、
前記問い合わせ手段が、前記クライアント・キャッシュ項目時間レコードを評価して、前記ウェブ・ブラウザ発信通信に対応する前記クライアント・キャッシュ項目が前記ウェブ・ブラウザが前記情報を要求する前に所定のクライアント・コヒーレンシ時間間隔内に作成されたかどうかを判断する手段をさらに含み、
前記供給する手段が、前記判断する手段によってクライアント・キャッシュ項目が前記ウェブ・ブラウザが情報を要求する前に所定のクライアント・コヒーレンシ時間間隔内に作成されたと判断された場合に、前記ウェブ・ブラウザ発信通信に応答してクライアント・キャッシュ項目を前記ウェブ・ブラウザにHTTPデータ・ストリームとして供給する手段を含む、請求項56に記載の装置。 - 前記ウェブ・ブラウザの複数のインスタンスにわたってクライアント・キャッシュ項目を維持する手段をさらに含む、請求項61に記載の装置。
- 前記再構築する手段が、前記外部通信リンクを介して受信したサーバCGIベース書式を前記外部通信リンクを介して受信したCGI差分データと結合して前記インタセプトされたCGI応答に対応するHTTPデータ・ストリームを作成することによって、前記ウェブ・サーバからの通信に対応する前記HTTPデータ・ストリームを、前記外部通信リンクを介して受信した前記クライアント/サーバ固有データ・ストリームから再構築する手段を含み、
前記受信したサーバCGIベース書式を前記CGI要求に対応する前記クライアント・ベース・キャッシュ項目として格納することによって、前記CGI要求に対応する前記クライアントCGIベース書式を更新する手段をさらに含む、請求項56記載の装置。 - 前記外部通信リンクを介して前記第1のコンピュータと前記第2のコンピュータの間に持続的接続を確立する手段と、
すべてのウェブ・ブラウザ発信通信が完了するまで前記持続的接続を維持する手段とをさらに含み、
前記インタセプトする手段が、複数のウェブ・ブラウザ発信通信をインタセプトする手段と、及び前記持続的接続を維持している間にそれらの複数のウェブ・ブラウザ発信手段を外部通信リンクに多重化する手段を含む、請求項56に記載の装置 - 前記外部通信リンクを介して前記第2のコンピュータからクライアント/サーバ固有データ・ストリームを受信する手段と、
前記ウェブ・ブラウザに前記複数のHTTPデータ・ストリームを供給するためにクライアント/サーバ固有データ・ストリームを多重化解除して複数のHTTPデータ・ストリームを作成する手段と、
前記複数のHTTPデータ・ストリームを前記ウェブ・ブラウザに供給する手段とをさらに含む、請求項64に記載の装置。 - 前記外部通信リンクを介して前記第2のコンピュータに前記第1のコンピュータの事前定義特性に対応するコンピュータ固有情報を供給する手段をさらに含み、
前記変換する手段が、ウェブ・ブラウザ発信通信からコンピュータ固有情報を取り除く手段を含む、請求項56に記載の装置。 - 第1のコンピュータ上に常駐しかつ第1のコンピュータからは遠隔にある第2のコンピュータ上に常駐するウェブ・サーバ・アプリケーションとハイパーテキスト転送プロトコル(HTTP)を使用して通信するウェブ・ブラウザ・アプリケーションのパフォーマンスを向上する装置であって、前記第1のコンピュータ内のウェブ・ブラウザ・アプリケーションと前記第2のコンピュータ内のウェブ・サーバ・アプリケーションとの間の通信が外部通信リンクを介して行われ、
前記装置は、
前記ウェブ・サーバによって発信された通信に対応するHTTPデータ・ストリームを、前記外部通信リンクでHTTPデータ・ストリームを送信する前にインタセプトする手段と、
前記ウェブ・サーバによって発信された前記HTTPデータ・ストリームを、前記HTTPプロトコルからクライアント/サーバ固有通信プロトコルに変換する手段と、
前記外部通信リンクを介して、前記変換されたウェブ・サーバ発信通信を前記ウェブ・ブラウザに前記クライアント/サーバ固有データ・ストリームとして送信する手段と
を含み、
前記ウェブ・ブラウザ発信通信が、共通ゲートウェイ・インタフェース(CGI)要求に対応し、
前記装置が、
前記インタセプトされたCGI要求に問い合わせて、前記インタセプトされたCGI要求に対応するサーバ・ベース・キャッシュ項目が存在するかどうかを判断し、サーバCGIベース書式を提供する手段と、
共通ゲートウェイ・インタフェース(CGI)に対する要求であるブラウザ発信通信に応答して前記ウェブ・サーバから受信したHTTPデータ・ストリームを前記第2のコンピュータ内にあるキャッシュに格納して、サーバ・ベース・キャッシュ項目を作成する手段と
をさらに含み、
前記インタセプトする手段が、前記インタセプトされたCGI要求に応答して前記ウェブ・サーバによって発信された前記通信に対応する前記HTTPデータ・ストリームを、前記外部通信リンクで送信する前にインタセプトする手段と、
前記インタセプトされたCGI応答を前記サーバCGIベース書式と比較して、前記インタセプトされたCGI応答と前記サーバCGIベース書式との差分に対応するCGI差分データを提供する手段とを含み、
前記送信する手段が、前記CGI差分データを前記外部通信リンクを介してクライアント/サーバ固有データ・ストリームとして前記ウェブ・ブラウザに送信する手段を含む、装置。 - ブラウザ発信通信に応答して前記ウェブ・サーバから受信した前記HTTPデータ・ストリームを前記第2のコンピュータ内にあるキャッシュに格納してサーバ要求キャッシュ項目を作成する手段と、
前記ウェブ・ブラウザ発信通信をインタセプトして、前記ブラウザ発信通信に対応するサーバ要求キャッシュ項目がキャッシュに前に格納されているかどうかを判断する手段とをさらに含み、
前記変換する手段が、前記ブラウザ発信通信に関連づけられた前記サーバ要求キャッシュ項目をクライアント/サーバ固有通信プロトコルに変換する手段を含み、
前記送信する手段が、前記変換されたサーバ要求キャッシュ項目を前記外部通信リンクを介して前記第1のコンピュータにクライアント/サーバ固有データ・ストリームとして送信する手段を含む、請求項67に記載の装置。 - 前記ウェブ・ブラウザ発信通信に対応するサーバ要求キャッシュ項目が、前記第2のコンピュータがウェブ・ブラウザ発信通信を受信する前に所定のクライアント・コヒーレンシ時間間隔内に作成されたかどうかを判断する手段をさらに含み、
前記変換する手段が、前記判断する手段によって前記サーバと要求キャッシュ項目が前記所定のクライアント・コヒーレンシ時間間隔で作成されたと判断された場合に前記ウェブ・ブラウザ発信通信に対応する前記サーバ要求キャッシュ項目をクライアント/サーバ固有通信プロトコルに変換する手段を含む、請求項68に記載の装置。 - 前記ウェブ・ブラウザ発信通信に対応するサーバ・キャッシュ項目と同じ前記ウェブ・ブラウザ発信通信に対応するクライアント・キャッシュ項目が存在するかどうかを判断する手段をさらに含み、
前記変換する手段が、前記第2のコンピュータが前記ウェブ・ブラウザ発信通信を受信した時点と前記ウェブ・ブラウザ発信通信に対応するサーバ要求キャッシュ項目が作成された時点との間の時間間隔を計算して項目エージ・データを供給する手段を含み、
前記送信する手段が、前記ウェブ・ブラウザ発信通信に対応するサーバ・キャッシュ項目の前記項目エージ・データを含むコヒーレント項目応答を前記クライアント/サーバ固有プロトコルとして外部通信リンクを介して第1のコンピュータに送信する手段を含む、請求項68に記載の装置。 - 前記サーバCGIベース書式が前記CGI要求に対応するクライアントCGIベース書式と同じかどうかを判断する手段をさらに含み、
前記送信する手段が、前記サーバCGIベース書式を送信し、かつ前記CGI差分データを前記外部通信リンクを介してクライアント/サーバ固有データ・ストリームとして前記ウェブ・ブラウザに送信する手段とを含む、請求項67に記載の装置。 - 前記サーバCGIベース書式と前記CGI応答との前記差分が事前定義差分しきい値より大きいかどうかを判断する手段と、
前記判断する手段によってサーバCGIベース書式とCGI応答との間の差分が事前定義差分しきい値より大きいと判断された場合、前記CGI要求に対応する前記サーバ・ベース・キャッシュ項目として前記ウェブ・サーバから前記受信したCGI応答を格納することによって、前記CGI要求に対応する前記サーバCGIベース書式を更新する手段とをさらに含み、
前記比較することおよび前記送信する手段が、前記更新されたサーバCGIベース書式を使用する、請求項67に記載の装置。 - 前記外部通信リンクを介して前記第1のコンピュータと前記第2のコンピュータの間に持続的接続を確立する手段と、
すべてのウェブ・ブラウザ発信通信が完了するまで前記持続的接続を維持する手段と
をさらに含み、
前記インタセプトする手段が、複数のウェブ・サーバ発信通信をインタセプトする手段と、及び前記持続的接続を維持している間にそれらのウェブ・サーバ発信通信を前記外部通信リンクに多重化する手段とを含む、請求項67に記載の装置。
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US08/601,804 US5754774A (en) | 1996-02-15 | 1996-02-15 | Client/server communication system |
US08/601,804 | 1996-02-15 | ||
PCT/US1996/011551 WO1997030538A2 (en) | 1996-02-15 | 1996-07-11 | Client/server communication system |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2003364382A Division JP3962369B2 (ja) | 1996-02-15 | 2003-10-24 | ウェブ・ブラウザ・アプリケーションのパフォーマンスを向上する方法及び装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
JPH11500895A JPH11500895A (ja) | 1999-01-19 |
JP3953109B2 true JP3953109B2 (ja) | 2007-08-08 |
Family
ID=24408840
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP52931197A Expired - Lifetime JP3953109B2 (ja) | 1996-02-15 | 1996-07-11 | クライアント/サーバ通信システム |
JP2003364382A Expired - Lifetime JP3962369B2 (ja) | 1996-02-15 | 2003-10-24 | ウェブ・ブラウザ・アプリケーションのパフォーマンスを向上する方法及び装置 |
Family Applications After (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2003364382A Expired - Lifetime JP3962369B2 (ja) | 1996-02-15 | 2003-10-24 | ウェブ・ブラウザ・アプリケーションのパフォーマンスを向上する方法及び装置 |
Country Status (16)
Country | Link |
---|---|
US (2) | US5754774A (ja) |
EP (1) | EP0823170B1 (ja) |
JP (2) | JP3953109B2 (ja) |
KR (1) | KR100289520B1 (ja) |
CN (1) | CN1148927C (ja) |
AT (1) | ATE196707T1 (ja) |
CA (1) | CA2218169C (ja) |
CZ (1) | CZ287988B6 (ja) |
DE (1) | DE69610495T2 (ja) |
ES (1) | ES2151176T3 (ja) |
HK (1) | HK1017789A1 (ja) |
HU (1) | HUP9801295A3 (ja) |
MY (1) | MY122038A (ja) |
PL (1) | PL180570B1 (ja) |
TW (1) | TW297194B (ja) |
WO (1) | WO1997030538A2 (ja) |
Families Citing this family (342)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6026452A (en) * | 1997-02-26 | 2000-02-15 | Pitts; William Michael | Network distributed site cache RAM claimed as up/down stream request/reply channel for storing anticipated data and meta data |
US6418324B1 (en) * | 1995-06-01 | 2002-07-09 | Padcom, Incorporated | Apparatus and method for transparent wireless communication between a remote device and host system |
US20040264402A9 (en) * | 1995-06-01 | 2004-12-30 | Padcom. Inc. | Port routing functionality |
US5754774A (en) * | 1996-02-15 | 1998-05-19 | International Business Machine Corp. | Client/server communication system |
US6157946A (en) * | 1996-02-28 | 2000-12-05 | Netzero Inc. | Communication system capable of providing user with picture meeting characteristics of user and terminal equipment and information providing device used for the same |
US6194992B1 (en) * | 1997-04-24 | 2001-02-27 | Nomadix, Llc | Mobile web |
US5859972A (en) * | 1996-05-10 | 1999-01-12 | The Board Of Trustees Of The University Of Illinois | Multiple server repository and multiple server remote application virtual client computer |
US6049820A (en) * | 1996-06-03 | 2000-04-11 | International Business Machines Corporation | Multiplexing of clients and applications among multiple servers |
US5935207A (en) * | 1996-06-03 | 1999-08-10 | Webtv Networks, Inc. | Method and apparatus for providing remote site administrators with user hits on mirrored web sites |
US6091518A (en) * | 1996-06-28 | 2000-07-18 | Fuji Xerox Co., Ltd. | Image transfer apparatus, image transmitter, profile information transmitter, image receiver/reproducer, storage medium, image receiver, program transmitter, and image color correction apparatus |
JP2924817B2 (ja) * | 1996-09-13 | 1999-07-26 | 日本電気株式会社 | 情報サーバシステム |
US6052120A (en) * | 1996-10-01 | 2000-04-18 | Diamond Multimedia Systems, Inc. | Method of operating a portable interactive graphics display tablet and communications systems |
US6084584A (en) * | 1996-10-01 | 2000-07-04 | Diamond Multimedia Systems, Inc. | Computer system supporting portable interactive graphics display tablet and communications systems |
US6166734A (en) * | 1996-10-01 | 2000-12-26 | Diamond Multimedia Systems, Inc. | Portable interactive graphics display tablet and communications system |
US5931904A (en) * | 1996-10-11 | 1999-08-03 | At&T Corp. | Method for reducing the delay between the time a data page is requested and the time the data page is displayed |
GB2320112B (en) * | 1996-12-07 | 2001-07-25 | Ibm | High-availability computer server system |
US6901425B1 (en) | 1996-12-23 | 2005-05-31 | International Business Machines Corporation | Computer apparatus and method including a disconnect mechanism for communicating between software applications and computers on the world-wide web |
US6144990A (en) * | 1996-12-23 | 2000-11-07 | International Business Machines Corporation | Computer apparatus and method for communicating between software applications and computers on the world-wide web using universal variable handling |
US5898833A (en) | 1996-12-31 | 1999-04-27 | Intel Corporation | Method and apparatus for increasing the effective bandwidth of video sequences transmitted over a network by using cached data |
US6456974B1 (en) * | 1997-01-06 | 2002-09-24 | Texas Instruments Incorporated | System and method for adding speech recognition capabilities to java |
US7020700B1 (en) * | 1997-02-28 | 2006-03-28 | International Business Machines Corporation | Client side socks server for an internet client |
US6057854A (en) * | 1997-03-07 | 2000-05-02 | Micrografx, Inc. | System and method of providing interactive vector graphics over a network |
US5948066A (en) * | 1997-03-13 | 1999-09-07 | Motorola, Inc. | System and method for delivery of information over narrow-band communications links |
US6073173A (en) * | 1997-03-17 | 2000-06-06 | International Business Machines Corporation | Method and apparatus for optimal rebasing of web page transmission |
US6182122B1 (en) * | 1997-03-26 | 2001-01-30 | International Business Machines Corporation | Precaching data at an intermediate server based on historical data requests by users of the intermediate server |
US5996016A (en) * | 1997-04-15 | 1999-11-30 | International Business Machines Corporation | Reinitiation of bind calls for IP applications concurrently executing with alternate address |
US6273622B1 (en) * | 1997-04-15 | 2001-08-14 | Flash Networks, Ltd. | Data communication protocol for maximizing the performance of IP communication links |
US5907678A (en) | 1997-05-07 | 1999-05-25 | International Business Machines Corporation | Client/server system in which protocol caches for multiple sessions are selectively copied into a common checkpoint cache upon receiving a checkpoint request |
US6061714A (en) * | 1997-05-07 | 2000-05-09 | International Business Machines Corporation | Persistent cache synchronization and start up system |
US6184996B1 (en) * | 1997-06-18 | 2001-02-06 | Hewlett-Packard Company | Network printer with remote print queue control procedure |
US6105028A (en) * | 1997-06-26 | 2000-08-15 | Digital Equipment Corporation | Method and apparatus for accessing copies of documents using a web browser request interceptor |
US5991760A (en) * | 1997-06-26 | 1999-11-23 | Digital Equipment Corporation | Method and apparatus for modifying copies of remotely stored documents using a web browser |
US6044087A (en) | 1997-06-30 | 2000-03-28 | Sun Microsystems, Inc. | Interface for a highly integrated ethernet network element |
US6246680B1 (en) | 1997-06-30 | 2001-06-12 | Sun Microsystems, Inc. | Highly integrated multi-layer switch element architecture |
US6049528A (en) | 1997-06-30 | 2000-04-11 | Sun Microsystems, Inc. | Trunking ethernet-compatible networks |
US6115378A (en) * | 1997-06-30 | 2000-09-05 | Sun Microsystems, Inc. | Multi-layer distributed network element |
US6081512A (en) | 1997-06-30 | 2000-06-27 | Sun Microsystems, Inc. | Spanning tree support in a high performance network device |
US6088356A (en) | 1997-06-30 | 2000-07-11 | Sun Microsystems, Inc. | System and method for a multi-layer network element |
US6081522A (en) | 1997-06-30 | 2000-06-27 | Sun Microsystems, Inc. | System and method for a multi-layer network element |
US6119196A (en) | 1997-06-30 | 2000-09-12 | Sun Microsystems, Inc. | System having multiple arbitrating levels for arbitrating access to a shared memory by network ports operating at different data rates |
US6016310A (en) | 1997-06-30 | 2000-01-18 | Sun Microsystems, Inc. | Trunking support in a high performance network device |
US6021132A (en) * | 1997-06-30 | 2000-02-01 | Sun Microsystems, Inc. | Shared memory management in a switched network element |
US7058720B1 (en) * | 1997-06-30 | 2006-06-06 | Microsoft Corporation | Geographical client distribution methods, systems and computer program products |
US6094435A (en) | 1997-06-30 | 2000-07-25 | Sun Microsystems, Inc. | System and method for a quality of service in a multi-layer network element |
US6044418A (en) | 1997-06-30 | 2000-03-28 | Sun Microsystems, Inc. | Method and apparatus for dynamically resizing queues utilizing programmable partition pointers |
US6128666A (en) * | 1997-06-30 | 2000-10-03 | Sun Microsystems, Inc. | Distributed VLAN mechanism for packet field replacement in a multi-layered switched network element using a control field/signal for indicating modification of a packet with a database search engine |
US6219803B1 (en) * | 1997-07-01 | 2001-04-17 | Progress Software Corporation | Testing and debugging tool for network applications |
US6058425A (en) * | 1997-07-21 | 2000-05-02 | International Business Machines Corporation | Single server access in a multiple TCP/IP instance environment |
US6038601A (en) | 1997-07-21 | 2000-03-14 | Tibco, Inc. | Method and apparatus for storing and delivering documents on the internet |
US6324565B1 (en) * | 1997-07-28 | 2001-11-27 | Qwest Communications International Inc. | Dynamically generated document cache system |
ATE282922T1 (de) * | 1997-08-06 | 2004-12-15 | Tachyon Inc | Verteiltes system und verfahren zum objektvorabholen |
US5935212A (en) * | 1997-08-07 | 1999-08-10 | I-Planet, Inc. | Connection-oriented session emulation |
US6035324A (en) * | 1997-08-28 | 2000-03-07 | International Business Machines Corporation | Client-side asynchronous form management |
US6070184A (en) * | 1997-08-28 | 2000-05-30 | International Business Machines Corporation | Server-side asynchronous form management |
US6631424B1 (en) * | 1997-09-10 | 2003-10-07 | Fmr Corp. | Distributing information using a computer |
US20060193278A1 (en) | 1997-10-15 | 2006-08-31 | Wolfgang Theimer | Mobile telephone for Internet applications |
US6292835B1 (en) * | 1997-11-26 | 2001-09-18 | International Business Machines Corporation | Network bandwidth and object obsolescence sensitive scheduling method and apparatus for objects distributed broadcasting |
US6185617B1 (en) * | 1997-11-26 | 2001-02-06 | International Business Machines Corporation | Construction and usage of a pre-warmed cache for client-server emulator |
US6360257B1 (en) * | 1998-01-30 | 2002-03-19 | Telefonaktiebolaget L M Ericsson (Publ) | Managing group IP addresses in mobile end stations |
FI112897B (fi) | 1998-03-03 | 2004-01-30 | Nokia Corp | Menetelmä tiedonsiirtoverkossa ja tiedonsiirtolaite |
US6148340A (en) * | 1998-04-30 | 2000-11-14 | International Business Machines Corporation | Method and system for differencing container files |
GB2353923A (en) * | 1998-05-29 | 2001-03-07 | Palm Inc | Method and apparatus for communicating information over low bandwith communications networks |
US7025209B2 (en) * | 1998-05-29 | 2006-04-11 | Palmsource, Inc. | Method and apparatus for wireless internet access |
US6343318B1 (en) | 1998-05-29 | 2002-01-29 | Palm, Inc. | Method and apparatus for communicating information over low bandwidth communications networks |
US6185608B1 (en) * | 1998-06-12 | 2001-02-06 | International Business Machines Corporation | Caching dynamic web pages |
US6574618B2 (en) * | 1998-07-22 | 2003-06-03 | Appstream, Inc. | Method and system for executing network streamed application |
US6311221B1 (en) * | 1998-07-22 | 2001-10-30 | Appstream Inc. | Streaming modules |
US7197570B2 (en) * | 1998-07-22 | 2007-03-27 | Appstream Inc. | System and method to send predicted application streamlets to a client device |
US20010044850A1 (en) | 1998-07-22 | 2001-11-22 | Uri Raz | Method and apparatus for determining the order of streaming modules |
US7127493B1 (en) | 1998-08-20 | 2006-10-24 | Gautier Taylor S | Optimizing server delivery of content by selective inclusion of optional data based on optimization criteria |
US6535509B2 (en) * | 1998-09-28 | 2003-03-18 | Infolibria, Inc. | Tagging for demultiplexing in a network traffic server |
US6321250B1 (en) | 1998-10-01 | 2001-11-20 | Ericsson Inc. | Data communication system and method for transporting objects over a permanent connections |
EP0993163A1 (en) | 1998-10-05 | 2000-04-12 | Backweb Technologies Ltd. | Distributed client-based data caching system and method |
US6397253B1 (en) | 1998-10-06 | 2002-05-28 | Bull Hn Information Systems Inc. | Method and system for providing high performance Web browser and server communications |
US7136645B2 (en) * | 1998-10-09 | 2006-11-14 | Netmotion Wireless, Inc. | Method and apparatus for providing mobile and other intermittent connectivity in a computing environment |
US7293107B1 (en) | 1998-10-09 | 2007-11-06 | Netmotion Wireless, Inc. | Method and apparatus for providing mobile and other intermittent connectivity in a computing environment |
US8078727B2 (en) | 1998-10-09 | 2011-12-13 | Netmotion Wireless, Inc. | Method and apparatus for providing mobile and other intermittent connectivity in a computing environment |
US7778260B2 (en) * | 1998-10-09 | 2010-08-17 | Netmotion Wireless, Inc. | Method and apparatus for providing mobile and other intermittent connectivity in a computing environment |
US6546425B1 (en) | 1998-10-09 | 2003-04-08 | Netmotion Wireless, Inc. | Method and apparatus for providing mobile and other intermittent connectivity in a computing environment |
US8060656B2 (en) | 1998-10-09 | 2011-11-15 | Netmotion Wireless, Inc. | Method and apparatus for providing mobile and other intermittent connectivity in a computing environment |
US6230165B1 (en) * | 1998-10-16 | 2001-05-08 | Cerulean | Method for encoding and transporting database objects over bandwidth constrained networks |
US6279041B1 (en) | 1998-11-13 | 2001-08-21 | International Business Machines Corporation | Methods, systems and computer program products for differencing data communications using a message queue |
EP1003114A1 (en) * | 1998-11-17 | 2000-05-24 | International Business Machines Corporation | Method of interconnecting computers and computer network |
US8266266B2 (en) | 1998-12-08 | 2012-09-11 | Nomadix, Inc. | Systems and methods for providing dynamic network authorization, authentication and accounting |
US6813640B1 (en) | 1998-12-08 | 2004-11-02 | Macrovision Corporation | System and method for controlling the editing by user action of digital objects created in a document server application |
US8713641B1 (en) | 1998-12-08 | 2014-04-29 | Nomadix, Inc. | Systems and methods for authorizing, authenticating and accounting users having transparent computer access to a network using a gateway device |
US7194554B1 (en) | 1998-12-08 | 2007-03-20 | Nomadix, Inc. | Systems and methods for providing dynamic network authorization authentication and accounting |
US6973300B1 (en) | 1998-12-23 | 2005-12-06 | Nortel Networks Limited | Intelligent wireless terminal with virtual memory |
US6266678B1 (en) * | 1998-12-31 | 2001-07-24 | Computer Associates Think, Inc. | System and method for dynamically viewing contents of a data file |
EP1166525A1 (en) * | 1999-04-02 | 2002-01-02 | Infolibria Inc. | Connection pass-through to optimize server performance |
US6651103B1 (en) * | 1999-04-20 | 2003-11-18 | At&T Corp. | Proxy apparatus and method for streaming media information and for increasing the quality of stored media information |
US6484212B1 (en) | 1999-04-20 | 2002-11-19 | At&T Corp. | Proxy apparatus and method for streaming media information |
US7882247B2 (en) | 1999-06-11 | 2011-02-01 | Netmotion Wireless, Inc. | Method and apparatus for providing secure connectivity in mobile and other intermittent computing environments |
US6510458B1 (en) | 1999-07-15 | 2003-01-21 | International Business Machines Corporation | Blocking saves to web browser cache based on content rating |
US6430739B1 (en) * | 1999-07-16 | 2002-08-06 | Acceleration Software International Corporation | Software execution contingent on home page setting |
US6507891B1 (en) * | 1999-07-22 | 2003-01-14 | International Business Machines Corporation | Method and apparatus for managing internal caches and external caches in a data processing system |
US6658462B1 (en) | 1999-08-26 | 2003-12-02 | International Business Machines Corporation | System, method, and program for balancing cache space requirements with retrieval access time for large documents on the internet |
US6779042B1 (en) | 1999-09-10 | 2004-08-17 | Ianywhere Solutions, Inc. | System, method, and computer program product for enabling on-device servers, offline forms, and dynamic ad tracking on mobile devices |
US7392308B2 (en) * | 1999-09-10 | 2008-06-24 | Ianywhere Solutions, Inc. | System, method, and computer program product for placement of channels on a mobile device |
US8595308B1 (en) | 1999-09-10 | 2013-11-26 | Ianywhere Solutions, Inc. | System, method, and computer program product for server side processing in a mobile device environment |
US7987420B1 (en) | 1999-09-10 | 2011-07-26 | Ianywhere Solutions, Inc. | System, method, and computer program product for a scalable, configurable, client/server, cross-platform browser for mobile devices |
US20020052781A1 (en) * | 1999-09-10 | 2002-05-02 | Avantgo, Inc. | Interactive advertisement mechanism on a mobile device |
US20010047394A1 (en) * | 1999-09-10 | 2001-11-29 | Kloba David D. | System, method, and computer program product for executing scripts on mobile devices |
US6757717B1 (en) * | 1999-09-16 | 2004-06-29 | Proxyconn, Inc. | System and method for data access |
US8108245B1 (en) | 1999-09-17 | 2012-01-31 | Cox Communications, Inc. | Method and system for web user profiling and selective content delivery |
US6801927B1 (en) | 1999-09-24 | 2004-10-05 | Akamba Corporation | Network adaptor card with reverse proxy and cache and method implemented therewith |
US6308238B1 (en) | 1999-09-24 | 2001-10-23 | Akamba Corporation | System and method for managing connections between clients and a server with independent connection and data buffers |
US6877036B1 (en) | 1999-09-24 | 2005-04-05 | Akamba Corporation | System and method for managing connections between a client and a server |
FR2803706B1 (fr) * | 1999-09-27 | 2002-03-08 | Bull Cp8 | Procede et architecture de pilotage a distance d'une station d'utilisateur via un reseau de type internet et leur application a un demonstrateur de carte a puce |
US7089300B1 (en) * | 1999-10-18 | 2006-08-08 | Apple Computer, Inc. | Method and apparatus for administering the operating system of a net-booted environment |
US6721780B1 (en) * | 1999-11-09 | 2004-04-13 | Fireclick, Inc. | Predictive pre-download of network objects |
US6864904B1 (en) * | 1999-12-06 | 2005-03-08 | Girafa.Com Inc. | Framework for providing visual context to www hyperlinks |
US6708217B1 (en) | 2000-01-05 | 2004-03-16 | International Business Machines Corporation | Method and system for receiving and demultiplexing multi-modal document content |
US6983315B1 (en) | 2000-01-18 | 2006-01-03 | Wrq, Inc. | Applet embedded cross-platform caching |
US7693981B2 (en) * | 2001-01-24 | 2010-04-06 | Telecommunication Systems, Inc. | System and method to publish information from servers to remote monitor devices |
US8090856B1 (en) | 2000-01-31 | 2012-01-03 | Telecommunication Systems, Inc. | Intelligent messaging network server interconnection |
US7970898B2 (en) | 2001-01-24 | 2011-06-28 | Telecommunication Systems, Inc. | System and method to publish information from servers to remote monitor devices |
US7003571B1 (en) | 2000-01-31 | 2006-02-21 | Telecommunication Systems Corporation Of Maryland | System and method for re-directing requests from browsers for communication over non-IP based networks |
US7418498B2 (en) * | 2001-01-24 | 2008-08-26 | Telecommunication Systems, Inc. | System and method to publish information from servers to remote monitor devices |
US8370435B1 (en) | 2000-01-31 | 2013-02-05 | Telecommunication Systems, Inc. | System and method for servers to send alerts to connectionless devices |
US6435164B1 (en) | 2000-12-07 | 2002-08-20 | Ford Global Technologies, Inc. | Fuel weathering method for vehicle evaporative emission system |
US7689696B2 (en) * | 2000-01-31 | 2010-03-30 | Telecommunication Systems, Inc. | System and method for re-directing requests from browsers for communications over non-IP based networks |
US7096418B1 (en) * | 2000-02-02 | 2006-08-22 | Persistence Software, Inc. | Dynamic web page cache |
US6820133B1 (en) | 2000-02-07 | 2004-11-16 | Netli, Inc. | System and method for high-performance delivery of web content using high-performance communications protocol between the first and second specialized intermediate nodes to optimize a measure of communications performance between the source and the destination |
US6947440B2 (en) | 2000-02-15 | 2005-09-20 | Gilat Satellite Networks, Ltd. | System and method for internet page acceleration including multicast transmissions |
US7028251B2 (en) * | 2000-03-02 | 2006-04-11 | Iora, Ltd. | System and method for reducing the size of data difference representations |
US6789128B1 (en) * | 2000-03-11 | 2004-09-07 | Oracle International Corporation | System and method for reducing network traffic between two computing devices |
US7020719B1 (en) | 2000-03-24 | 2006-03-28 | Netli, Inc. | System and method for high-performance delivery of Internet messages by selecting first and second specialized intermediate nodes to optimize a measure of communications performance between the source and the destination |
AUPQ653800A0 (en) * | 2000-03-28 | 2000-04-20 | Sharinga Networks Inc. | A data delivery process |
US7187947B1 (en) | 2000-03-28 | 2007-03-06 | Affinity Labs, Llc | System and method for communicating selected information to an electronic device |
US6654794B1 (en) | 2000-03-30 | 2003-11-25 | International Business Machines Corporation | Method, data processing system and program product that provide an internet-compatible network file system driver |
AU2000263270A1 (en) | 2000-04-13 | 2001-10-30 | Worldlink Information Technology Systems Limited | Apparatus and a method for supplying information |
US20110128972A1 (en) * | 2000-04-17 | 2011-06-02 | Randy Thornton | Peer to peer dynamic network link acceleration |
AU2001259075A1 (en) | 2000-04-17 | 2001-10-30 | Circadence Corporation | System and method for web serving |
US8996705B2 (en) | 2000-04-17 | 2015-03-31 | Circadence Corporation | Optimization of enhanced network links |
US7979880B2 (en) * | 2000-04-21 | 2011-07-12 | Cox Communications, Inc. | Method and system for profiling iTV users and for providing selective content delivery |
US7013340B1 (en) | 2000-05-18 | 2006-03-14 | Microsoft Corporation | Postback input handling by server-side control objects |
US6990526B1 (en) * | 2000-05-22 | 2006-01-24 | Pointred Technologies, Inc. | Method and apparatus for web caching |
US7062475B1 (en) * | 2000-05-30 | 2006-06-13 | Alberti Anemometer Llc | Personalized multi-service computer environment |
FI20001617A (fi) * | 2000-07-06 | 2002-01-07 | Nokia Mobile Phones Ltd | Tiedonsiirtomenetelmõ ja -jõrjestely |
FR2811504B1 (fr) * | 2000-07-06 | 2003-07-04 | Centre Nat Etd Spatiales | Dispositif serveur de realisation multi-utilisateur en libre-service et de diffusion d'emissions de television et reseau de television |
US6704024B2 (en) * | 2000-08-07 | 2004-03-09 | Zframe, Inc. | Visual content browsing using rasterized representations |
AU2001283464A1 (en) * | 2000-08-31 | 2002-03-13 | Padcom, Inc. | Method and apparatus for routing data over multiple wireless networks |
US7051315B2 (en) | 2000-09-26 | 2006-05-23 | Appstream, Inc. | Network streaming of multi-application program code |
US6757894B2 (en) | 2000-09-26 | 2004-06-29 | Appstream, Inc. | Preprocessed applications suitable for network streaming applications and method for producing same |
US7801978B1 (en) * | 2000-10-18 | 2010-09-21 | Citrix Systems, Inc. | Apparatus, method and computer program product for efficiently pooling connections between clients and servers |
US7283805B2 (en) * | 2000-11-20 | 2007-10-16 | Cingular Wireless Ii, Llc | Methods and systems for providing application level presence information in wireless communication |
US20020196793A1 (en) * | 2000-11-29 | 2002-12-26 | Quikcat.Com, Inc. | End-user communication systems access network |
US7269784B1 (en) | 2001-01-22 | 2007-09-11 | Kasriel Stephane | Server-originated differential caching |
US7174305B2 (en) * | 2001-01-23 | 2007-02-06 | Opentv, Inc. | Method and system for scheduling online targeted content delivery |
US7195923B2 (en) * | 2001-01-31 | 2007-03-27 | Scripps Laboratories, Inc. | Ratiometric determination of glycated protein |
US7665115B2 (en) * | 2001-02-02 | 2010-02-16 | Microsoft Corporation | Integration of media playback components with an independent timing specification |
US20020138331A1 (en) * | 2001-02-05 | 2002-09-26 | Hosea Devin F. | Method and system for web page personalization |
US6963930B2 (en) * | 2001-02-15 | 2005-11-08 | Centric Software, Inc. | Automatic transfer and expansion of application-specific data for display at a website |
US6968553B1 (en) * | 2001-03-01 | 2005-11-22 | Alcatel | Element manager common gateway architecture system and method |
US7380250B2 (en) * | 2001-03-16 | 2008-05-27 | Microsoft Corporation | Method and system for interacting with devices having different capabilities |
US20020156900A1 (en) * | 2001-03-30 | 2002-10-24 | Brian Marquette | Protocol independent control module |
US7185094B2 (en) * | 2001-03-30 | 2007-02-27 | Sandcherry, Inc. | Media session framework using a control module to direct and manage application and service servers |
US20020184363A1 (en) * | 2001-04-20 | 2002-12-05 | Steven Viavant | Techniques for server-controlled measurement of client-side performance |
US7031314B2 (en) * | 2001-05-16 | 2006-04-18 | Bytemobile, Inc. | Systems and methods for providing differentiated services within a network communication system |
EP1564960B1 (en) * | 2001-05-16 | 2007-03-28 | Bytemobile, Inc. | System and methods for providing differentiated services within a network communication system |
US6965765B2 (en) * | 2001-05-17 | 2005-11-15 | Palmsource, Inc. | Transactional message-queue communication for wirelessly networked devices system and method |
EP1393497B1 (en) * | 2001-05-18 | 2006-11-02 | Bytemobile, Inc. | Dual mode service platform within network communication system |
US7493397B1 (en) | 2001-06-06 | 2009-02-17 | Microsoft Corporation | Providing remote processing services over a distributed communications network |
US6915454B1 (en) | 2001-06-12 | 2005-07-05 | Microsoft Corporation | Web controls validation |
US7562146B2 (en) * | 2003-10-10 | 2009-07-14 | Citrix Systems, Inc. | Encapsulating protocol for session persistence and reliability |
US20050198379A1 (en) * | 2001-06-13 | 2005-09-08 | Citrix Systems, Inc. | Automatically reconnecting a client across reliable and persistent communication sessions |
US7185063B1 (en) | 2001-06-22 | 2007-02-27 | Digital River, Inc. | Content delivery network using differential caching |
US7165112B2 (en) * | 2001-06-22 | 2007-01-16 | Motorola, Inc. | Method and apparatus for transmitting data in a communication system |
US20020198956A1 (en) * | 2001-06-25 | 2002-12-26 | International Business Machines Corporation | Method and apparatus for managing a cache |
US7548875B2 (en) | 2001-06-27 | 2009-06-16 | John Mikkelsen | Media delivery platform |
US7594001B1 (en) * | 2001-07-06 | 2009-09-22 | Microsoft Corporation | Partial page output caching |
US7092997B1 (en) | 2001-08-06 | 2006-08-15 | Digital River, Inc. | Template identification with differential caching |
US7188214B1 (en) | 2001-08-07 | 2007-03-06 | Digital River, Inc. | Efficient compression using differential caching |
US7822843B2 (en) * | 2001-08-13 | 2010-10-26 | Cox Communications, Inc. | Predicting the activities of an individual or group using minimal information |
US7099957B2 (en) * | 2001-08-23 | 2006-08-29 | The Directtv Group, Inc. | Domain name system resolution |
US7644171B2 (en) * | 2001-09-12 | 2010-01-05 | Netmotion Wireless, Inc. | Mobile networking system and method using IPv4 and IPv6 |
WO2003032201A1 (en) * | 2001-10-09 | 2003-04-17 | Wildblue Communications, Inc. | Performance enhancing proxy for high latency data |
US7000238B2 (en) * | 2001-10-10 | 2006-02-14 | Borland Software Corporation | Development system providing extensible remoting architecture |
JP2003205483A (ja) * | 2001-11-07 | 2003-07-22 | Sony Corp | ロボットシステム及びロボット装置の制御方法 |
US7428725B2 (en) | 2001-11-20 | 2008-09-23 | Microsoft Corporation | Inserting devices specific content |
US20030106057A1 (en) * | 2001-12-05 | 2003-06-05 | Predictive Networks, Inc. | Television navigation program guide |
EP1318461A1 (en) * | 2001-12-07 | 2003-06-11 | Sap Ag | Method and computer system for refreshing client-data |
US7296051B1 (en) | 2002-02-19 | 2007-11-13 | Digital River, Inc. | Predictive predownload of templates with delta encoding |
US7487261B1 (en) | 2002-02-22 | 2009-02-03 | Digital River, Inc. | Delta caching service |
US7984157B2 (en) * | 2002-02-26 | 2011-07-19 | Citrix Systems, Inc. | Persistent and reliable session securely traversing network components using an encapsulating protocol |
US7661129B2 (en) * | 2002-02-26 | 2010-02-09 | Citrix Systems, Inc. | Secure traversal of network components |
US7263562B2 (en) * | 2002-03-21 | 2007-08-28 | Microsoft Corporation | Method and system for describing uploaded files statement regarding federally-sponsored research or development |
US20030182424A1 (en) * | 2002-03-22 | 2003-09-25 | Steve Odendahl | Scriptable proxy server |
US7111038B2 (en) * | 2002-04-03 | 2006-09-19 | International Business Machines Corporation | Enhancing application server performance by relocating performance-degrading processing |
EP1355238A1 (en) * | 2002-04-19 | 2003-10-22 | Sap Ag | Method and computer system for delta-handling in server-pages |
US7703015B2 (en) * | 2002-04-30 | 2010-04-20 | Sap Aktiengesellschaft | Delta-handling in server-pages |
AU2003239385A1 (en) * | 2002-05-10 | 2003-11-11 | Richard R. Reisman | Method and apparatus for browsing using multiple coordinated device |
US6996584B2 (en) * | 2002-05-14 | 2006-02-07 | Pervasive Software, Inc. | System and method of maintaining functional client side data cache coherence |
US7434163B2 (en) * | 2002-05-31 | 2008-10-07 | Sap Aktiengesellschaft | Document structures for delta handling in server pages |
US9357013B2 (en) * | 2002-07-26 | 2016-05-31 | International Business Machines Corporation | Client-side script to application communication system |
US7765255B2 (en) * | 2002-07-30 | 2010-07-27 | Sap Ag | Extended web infrastructure for business applications |
US8255454B2 (en) | 2002-09-06 | 2012-08-28 | Oracle International Corporation | Method and apparatus for a multiplexed active data window in a near real-time business intelligence system |
US7272660B1 (en) | 2002-09-06 | 2007-09-18 | Oracle International Corporation | Architecture for general purpose near real-time business intelligence system and methods therefor |
US7941542B2 (en) | 2002-09-06 | 2011-05-10 | Oracle International Corporation | Methods and apparatus for maintaining application execution over an intermittent network connection |
US7899879B2 (en) | 2002-09-06 | 2011-03-01 | Oracle International Corporation | Method and apparatus for a report cache in a near real-time business intelligence system |
US7912899B2 (en) | 2002-09-06 | 2011-03-22 | Oracle International Corporation | Method for selectively sending a notification to an instant messaging device |
US8165993B2 (en) | 2002-09-06 | 2012-04-24 | Oracle International Corporation | Business intelligence system with interface that provides for immediate user action |
US7945846B2 (en) | 2002-09-06 | 2011-05-17 | Oracle International Corporation | Application-specific personalization for data display |
US7243124B1 (en) | 2002-09-06 | 2007-07-10 | Oracle International Corporation | Architecture for general purpose near real-time business intelligence system with client devices and methods therefor |
US7454423B2 (en) | 2002-09-06 | 2008-11-18 | Oracle International Corporation | Enterprise link for a software database |
US7412481B2 (en) | 2002-09-16 | 2008-08-12 | Oracle International Corporation | Method and apparatus for distributed rule evaluation in a near real-time business intelligence system |
US7668917B2 (en) * | 2002-09-16 | 2010-02-23 | Oracle International Corporation | Method and apparatus for ensuring accountability in the examination of a set of data elements by a user |
US7426059B2 (en) | 2002-09-16 | 2008-09-16 | Oracle International Corporation | Data presentation methods and apparatus to facilitate printing and reviewing |
US7401158B2 (en) | 2002-09-16 | 2008-07-15 | Oracle International Corporation | Apparatus and method for instant messaging collaboration |
US7730155B1 (en) * | 2002-10-01 | 2010-06-01 | Apple Inc. | Method and apparatus for dynamically locating resources |
US7574653B2 (en) | 2002-10-11 | 2009-08-11 | Microsoft Corporation | Adaptive image formatting control |
US6667700B1 (en) | 2002-10-30 | 2003-12-23 | Nbt Technology, Inc. | Content-based segmentation scheme for data compression in storage and transmission including hierarchical segment representation |
US7650416B2 (en) | 2003-08-12 | 2010-01-19 | Riverbed Technology | Content delivery for client-server protocols with user affinities using connection end-point proxies |
US8364815B2 (en) | 2005-03-18 | 2013-01-29 | Riverbed Technology, Inc. | Reliability and availability of distributed servers |
US8069225B2 (en) * | 2003-04-14 | 2011-11-29 | Riverbed Technology, Inc. | Transparent client-server transaction accelerator |
US7120666B2 (en) | 2002-10-30 | 2006-10-10 | Riverbed Technology, Inc. | Transaction accelerator for client-server communication systems |
US8176186B2 (en) * | 2002-10-30 | 2012-05-08 | Riverbed Technology, Inc. | Transaction accelerator for client-server communications systems |
ATE380431T1 (de) * | 2002-11-15 | 2007-12-15 | Ibm | Steuerung von netzwerkverkehr in einer peer-to- peer umgebung |
JP2004240650A (ja) * | 2003-02-05 | 2004-08-26 | Brother Ind Ltd | 通信システム、スイッチ操作部材、端末装置およびプログラム |
US20040170181A1 (en) * | 2003-02-27 | 2004-09-02 | Padcom, Inc. | Prioritized alternate port routing |
US7904823B2 (en) * | 2003-03-17 | 2011-03-08 | Oracle International Corporation | Transparent windows methods and apparatus therefor |
CA2520117A1 (en) * | 2003-03-25 | 2004-10-14 | Sedna Patent Services, Llc | Generating audience analytics |
US7113964B1 (en) | 2003-06-05 | 2006-09-26 | Iteration Software, Inc. | Method and apparatus for archiving data in a relational database system |
WO2004114529A2 (en) * | 2003-06-16 | 2004-12-29 | Mentat Inc. | Pre-fetch communication systems and methods |
US7882510B2 (en) * | 2003-08-06 | 2011-02-01 | Microsoft Corporation | Demultiplexer application programming interface |
US7853699B2 (en) | 2005-03-15 | 2010-12-14 | Riverbed Technology, Inc. | Rules-based transaction prefetching using connection end-point proxies |
US7873353B2 (en) * | 2003-09-30 | 2011-01-18 | Ianywhere Solutions, Inc. | Method and system for accessing applications and data, and for tracking of key indicators on mobile handheld devices |
US7472254B2 (en) * | 2003-10-10 | 2008-12-30 | Iora, Ltd. | Systems and methods for modifying a set of data objects |
US7774774B1 (en) * | 2003-10-22 | 2010-08-10 | Apple Inc. | Software setup system |
US20050091226A1 (en) * | 2003-10-23 | 2005-04-28 | Yun Lin | Persistent caching directory level support |
US7441011B2 (en) * | 2003-10-23 | 2008-10-21 | Microsoft Corporation | Truth on client persistent caching |
US7890604B2 (en) | 2004-05-07 | 2011-02-15 | Microsoft Corproation | Client-side callbacks to server events |
US9026578B2 (en) | 2004-05-14 | 2015-05-05 | Microsoft Corporation | Systems and methods for persisting data between web pages |
US7464386B2 (en) | 2004-05-17 | 2008-12-09 | Microsoft Corporation | Data controls architecture |
US8135803B2 (en) * | 2004-08-23 | 2012-03-13 | Ianywhere Solutions, Inc. | Method, system, and computer program product for offline advertisement servicing and cycling |
US20060064470A1 (en) * | 2004-09-23 | 2006-03-23 | Sargent Antony J | Method, system, and computer program product for improved synchronization efficiency for mobile devices, including database hashing and caching of web access errors |
WO2006042155A2 (en) * | 2004-10-08 | 2006-04-20 | E-Klone, Inc. | Floating vector scrambling methods and apparatus |
US7908397B1 (en) | 2005-02-28 | 2011-03-15 | Adobe Systems Incorporated | Application server gateway technology |
US20060248194A1 (en) | 2005-03-18 | 2006-11-02 | Riverbed Technology, Inc. | Connection forwarding |
US20060224702A1 (en) * | 2005-03-31 | 2006-10-05 | Patrick Schmidt | Local workflows in a business process management system |
US8943304B2 (en) | 2006-08-03 | 2015-01-27 | Citrix Systems, Inc. | Systems and methods for using an HTTP-aware client agent |
US9692725B2 (en) * | 2005-05-26 | 2017-06-27 | Citrix Systems, Inc. | Systems and methods for using an HTTP-aware client agent |
WO2007016236A2 (en) | 2005-07-28 | 2007-02-08 | Riverbed Technology, Inc. | Automatic framing selection |
US8171238B1 (en) | 2007-07-05 | 2012-05-01 | Silver Peak Systems, Inc. | Identification of data stored in memory |
US8370583B2 (en) * | 2005-08-12 | 2013-02-05 | Silver Peak Systems, Inc. | Network memory architecture for providing data based on local accessibility |
US8392684B2 (en) | 2005-08-12 | 2013-03-05 | Silver Peak Systems, Inc. | Data encryption in a network memory architecture for providing data based on local accessibility |
US8095774B1 (en) | 2007-07-05 | 2012-01-10 | Silver Peak Systems, Inc. | Pre-fetching data into a memory |
US8929402B1 (en) | 2005-09-29 | 2015-01-06 | Silver Peak Systems, Inc. | Systems and methods for compressing packet data by predicting subsequent data |
US8489562B1 (en) | 2007-11-30 | 2013-07-16 | Silver Peak Systems, Inc. | Deferred data storage |
US8811431B2 (en) | 2008-11-20 | 2014-08-19 | Silver Peak Systems, Inc. | Systems and methods for compressing packet data |
US7805670B2 (en) * | 2005-12-16 | 2010-09-28 | Microsoft Corporation | Partial rendering of web pages |
US7924884B2 (en) | 2005-12-20 | 2011-04-12 | Citrix Systems, Inc. | Performance logging using relative differentials and skip recording |
US20070203973A1 (en) * | 2006-02-28 | 2007-08-30 | Microsoft Corporation | Fuzzing Requests And Responses Using A Proxy |
CN101043522B (zh) * | 2006-03-22 | 2013-11-13 | 腾讯科技(深圳)有限公司 | 一种基于Web服务器的通信方法及系统 |
US8140618B2 (en) * | 2006-05-04 | 2012-03-20 | Citrix Online Llc | Methods and systems for bandwidth adaptive N-to-N communication in a distributed system |
WO2008005629A2 (en) * | 2006-05-26 | 2008-01-10 | Riverbed Technology, Inc. | Throttling of predictive acks in an accelerated network communication system |
WO2007149687A2 (en) | 2006-05-30 | 2007-12-27 | Riverbed Technology, Inc. | Selecting proxies from among autodiscovered proxies |
KR100765785B1 (ko) * | 2006-06-05 | 2007-10-12 | 삼성전자주식회사 | 무선 usb를 이용한 단일 무선장치와 다수의 호스트 간의접속 방법 및 시스템 |
US20070300243A1 (en) * | 2006-06-22 | 2007-12-27 | Sap Portals Israel Ltd. | Modular caching method and system for enabling offline functionality of server-client systems |
US7941560B1 (en) * | 2006-07-14 | 2011-05-10 | Intuit Inc. | Client caching of target addresses for network requests |
US8885632B2 (en) | 2006-08-02 | 2014-11-11 | Silver Peak Systems, Inc. | Communications scheduler |
US8755381B2 (en) | 2006-08-02 | 2014-06-17 | Silver Peak Systems, Inc. | Data matching using flow based packet data storage |
US8312120B2 (en) * | 2006-08-22 | 2012-11-13 | Citrix Systems, Inc. | Systems and methods for providing dynamic spillover of virtual servers based on bandwidth |
US8493858B2 (en) | 2006-08-22 | 2013-07-23 | Citrix Systems, Inc | Systems and methods for providing dynamic connection spillover among virtual servers |
TR200606833A2 (tr) * | 2006-12-01 | 2007-10-22 | B�Lmed B�Lg�Sayar Ve Yazilim A.�. | Web tarayıcı tabanlı uygulamalarda performans arttırma yöntemi |
US7733910B2 (en) * | 2006-12-29 | 2010-06-08 | Riverbed Technology, Inc. | Data segmentation using shift-varying predicate function fingerprinting |
CN101242337B (zh) * | 2007-02-08 | 2010-11-10 | 张永敏 | 一种计算机网络的内容发布方法及系统 |
US8533310B2 (en) * | 2007-03-09 | 2013-09-10 | Riverbed Technology, Inc. | Method and apparatus for acceleration by prefetching associated objects |
CN101272442B (zh) * | 2007-03-21 | 2010-05-26 | 杭州波导软件有限公司 | 数字图像无损压缩方法和装置、解析方法及图像译码器 |
EP2153340A4 (en) * | 2007-05-08 | 2015-10-21 | Riverbed Technology Inc | HYBRID SEGMENT ORIENTED FILE SERVER, AND WAN ACCELERATOR |
US20090097470A1 (en) * | 2007-10-12 | 2009-04-16 | Collier David S | Methods and systems for communicating data |
US8190876B2 (en) * | 2007-11-19 | 2012-05-29 | Red Hat, Inc. | Renegotiating SSL/TLS connections with client certificates on post requests |
US8307115B1 (en) * | 2007-11-30 | 2012-11-06 | Silver Peak Systems, Inc. | Network memory mirroring |
US8635361B2 (en) * | 2007-12-03 | 2014-01-21 | Riverbed Technology, Inc. | Transaction acceleration using application-specific locking |
US8775550B2 (en) * | 2008-02-08 | 2014-07-08 | Microsoft Corporation | Caching HTTP request and response streams |
US8442052B1 (en) | 2008-02-20 | 2013-05-14 | Silver Peak Systems, Inc. | Forward packet recovery |
US8463941B1 (en) * | 2008-06-16 | 2013-06-11 | Riverbed Technology, Inc. | Cross-session protocol acceleration and its application to storage area network file systems |
US8743683B1 (en) | 2008-07-03 | 2014-06-03 | Silver Peak Systems, Inc. | Quality of service using multiple flows |
US9717021B2 (en) | 2008-07-03 | 2017-07-25 | Silver Peak Systems, Inc. | Virtual network overlay |
US10164861B2 (en) | 2015-12-28 | 2018-12-25 | Silver Peak Systems, Inc. | Dynamic monitoring and visualization for network health characteristics |
US10805840B2 (en) | 2008-07-03 | 2020-10-13 | Silver Peak Systems, Inc. | Data transmission via a virtual wide area network overlay |
US8793339B2 (en) * | 2008-08-29 | 2014-07-29 | Red Hat, Inc. | Facilitating client server interaction |
US8793398B2 (en) * | 2008-08-29 | 2014-07-29 | Red Hat, Inc. | Facilitating client server interaction |
US8925034B1 (en) | 2009-06-30 | 2014-12-30 | Symantec Corporation | Data protection requirements specification and migration |
US8387047B1 (en) | 2009-08-03 | 2013-02-26 | Symantec Corporation | Method of virtualizing file extensions in a computer system by determining an association between applications in virtual environment and a file extension |
US8352937B2 (en) * | 2009-08-03 | 2013-01-08 | Symantec Corporation | Streaming an application install package into a virtual environment |
US8090744B1 (en) | 2009-08-26 | 2012-01-03 | Symantec Operating Corporation | Method and apparatus for determining compatibility between a virtualized application and a base environment |
US8473444B1 (en) | 2009-08-28 | 2013-06-25 | Symantec Corporation | Management of actions in multiple virtual and non-virtual environments |
US8438555B1 (en) | 2009-08-31 | 2013-05-07 | Symantec Corporation | Method of using an encapsulated data signature for virtualization layer activation |
US8458310B1 (en) | 2009-09-14 | 2013-06-04 | Symantec Corporation | Low bandwidth streaming of application upgrades |
US8566297B1 (en) | 2010-01-14 | 2013-10-22 | Symantec Corporation | Method to spoof data formats from image backups |
US8290912B1 (en) | 2010-01-29 | 2012-10-16 | Symantec Corporation | Endpoint virtualization aware backup |
US8707296B2 (en) | 2010-04-27 | 2014-04-22 | Apple Inc. | Dynamic retrieval of installation packages when installing software |
US10142157B2 (en) | 2010-06-10 | 2018-11-27 | Blackberry Limited | Method and system for reducing transmission of redundant data |
US8495625B1 (en) | 2010-07-27 | 2013-07-23 | Symantec Corporation | Method and system for creation of streamed files on-demand |
US9549030B2 (en) * | 2011-02-04 | 2017-01-17 | Riverbed Technology, Inc. | Correlating input and output requests between client and server components in a multi-tier application |
US9094090B2 (en) | 2011-09-23 | 2015-07-28 | Gilat Satellite Networks Ltd. | Decentralized caching system |
US9130991B2 (en) | 2011-10-14 | 2015-09-08 | Silver Peak Systems, Inc. | Processing data packets in performance enhancing proxy (PEP) environment |
US9626224B2 (en) | 2011-11-03 | 2017-04-18 | Silver Peak Systems, Inc. | Optimizing available computing resources within a virtual environment |
US9084058B2 (en) | 2011-12-29 | 2015-07-14 | Sonos, Inc. | Sound field calibration using listener localization |
US20130212227A1 (en) * | 2012-02-09 | 2013-08-15 | Cogent Real-Time Systems Inc. | System and method for streaming data via http |
US9274870B2 (en) | 2012-02-10 | 2016-03-01 | Empire Technology Development Llc | Monitoring connection quality |
US9106192B2 (en) | 2012-06-28 | 2015-08-11 | Sonos, Inc. | System and method for device playback calibration |
US9219460B2 (en) | 2014-03-17 | 2015-12-22 | Sonos, Inc. | Audio settings based on environment |
US9542172B2 (en) | 2013-02-05 | 2017-01-10 | Apple Inc. | Automatic updating of applications |
US9880776B1 (en) | 2013-02-22 | 2018-01-30 | Veritas Technologies Llc | Content-driven data protection method for multiple storage devices |
JP6088853B2 (ja) * | 2013-02-27 | 2017-03-01 | 株式会社東芝 | 通信装置、通信方法および通信プログラム |
US9264839B2 (en) | 2014-03-17 | 2016-02-16 | Sonos, Inc. | Playback device configuration based on proximity detection |
US9613158B1 (en) * | 2014-05-13 | 2017-04-04 | Viasat, Inc. | Cache hinting systems |
US9948496B1 (en) | 2014-07-30 | 2018-04-17 | Silver Peak Systems, Inc. | Determining a transit appliance for data traffic to a software service |
US9875344B1 (en) * | 2014-09-05 | 2018-01-23 | Silver Peak Systems, Inc. | Dynamic monitoring and authorization of an optimization device |
US9952825B2 (en) | 2014-09-09 | 2018-04-24 | Sonos, Inc. | Audio processing algorithms |
CN105491078B (zh) | 2014-09-15 | 2019-01-22 | 阿里巴巴集团控股有限公司 | Soa系统中的数据处理方法及装置、soa系统 |
EP3012739A1 (en) | 2014-10-20 | 2016-04-27 | TISOFT Wojciech Jedrzejewski | System for synchronizing web browsers |
CN108028985B (zh) | 2015-09-17 | 2020-03-13 | 搜诺思公司 | 用于计算设备的方法 |
US9693165B2 (en) | 2015-09-17 | 2017-06-27 | Sonos, Inc. | Validation of audio calibration using multi-dimensional motion check |
US9743207B1 (en) | 2016-01-18 | 2017-08-22 | Sonos, Inc. | Calibration using multiple recording devices |
US11106423B2 (en) | 2016-01-25 | 2021-08-31 | Sonos, Inc. | Evaluating calibration of a playback device |
US10003899B2 (en) | 2016-01-25 | 2018-06-19 | Sonos, Inc. | Calibration with particular locations |
US9864574B2 (en) | 2016-04-01 | 2018-01-09 | Sonos, Inc. | Playback device calibration based on representation spectral characteristics |
US9860662B2 (en) | 2016-04-01 | 2018-01-02 | Sonos, Inc. | Updating playback device configuration information based on calibration data |
US9763018B1 (en) | 2016-04-12 | 2017-09-12 | Sonos, Inc. | Calibration of audio playback devices |
US10432484B2 (en) | 2016-06-13 | 2019-10-01 | Silver Peak Systems, Inc. | Aggregating select network traffic statistics |
US9794710B1 (en) | 2016-07-15 | 2017-10-17 | Sonos, Inc. | Spatial audio correction |
US10372406B2 (en) | 2016-07-22 | 2019-08-06 | Sonos, Inc. | Calibration interface |
US10459684B2 (en) | 2016-08-05 | 2019-10-29 | Sonos, Inc. | Calibration of a playback device based on an estimated frequency response |
US9967056B1 (en) | 2016-08-19 | 2018-05-08 | Silver Peak Systems, Inc. | Forward packet recovery with constrained overhead |
US10361997B2 (en) | 2016-12-29 | 2019-07-23 | Riverbed Technology, Inc. | Auto discovery between proxies in an IPv6 network |
US10771394B2 (en) | 2017-02-06 | 2020-09-08 | Silver Peak Systems, Inc. | Multi-level learning for classifying traffic flows on a first packet from DNS data |
US11044202B2 (en) | 2017-02-06 | 2021-06-22 | Silver Peak Systems, Inc. | Multi-level learning for predicting and classifying traffic flows from first packet data |
US10257082B2 (en) | 2017-02-06 | 2019-04-09 | Silver Peak Systems, Inc. | Multi-level learning for classifying traffic flows |
US10892978B2 (en) | 2017-02-06 | 2021-01-12 | Silver Peak Systems, Inc. | Multi-level learning for classifying traffic flows from first packet data |
US11212210B2 (en) | 2017-09-21 | 2021-12-28 | Silver Peak Systems, Inc. | Selective route exporting using source type |
CN117544884A (zh) | 2017-10-04 | 2024-02-09 | 谷歌有限责任公司 | 基于房间特性自动均衡音频输出的方法和系统 |
KR102274055B1 (ko) * | 2017-12-26 | 2021-07-06 | 삼성에스디에스 주식회사 | 메시지 시스템 및 애플리케이션 활성화 방법과 이를 수행하기 위한 사용자 단말 |
US10637721B2 (en) | 2018-03-12 | 2020-04-28 | Silver Peak Systems, Inc. | Detecting path break conditions while minimizing network overhead |
US11206484B2 (en) | 2018-08-28 | 2021-12-21 | Sonos, Inc. | Passive speaker authentication |
US10299061B1 (en) | 2018-08-28 | 2019-05-21 | Sonos, Inc. | Playback device calibration |
US10868892B1 (en) * | 2019-05-31 | 2020-12-15 | Micro Focus Llc | Replacement code implementing full-duplex communication channel protocol for message interception |
US10734965B1 (en) | 2019-08-12 | 2020-08-04 | Sonos, Inc. | Audio calibration of a portable playback device |
US11968417B2 (en) * | 2021-12-30 | 2024-04-23 | Comcast Cable Communications, Llc | Systems, methods, and apparatuses for buffer management |
Family Cites Families (33)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4438511A (en) * | 1980-11-10 | 1984-03-20 | Telebit Corporation | Packetized ensemble modem |
US5021949A (en) * | 1988-02-29 | 1991-06-04 | International Business Machines Corporation | Method and apparatus for linking an SNA host to a remote SNA host over a packet switched communications network |
US4893307A (en) * | 1988-02-29 | 1990-01-09 | International Business Machines Corporation | Method and apparatus for linking SNA terminals to an SNA host over a packet switched communications network |
US5473772A (en) * | 1991-04-02 | 1995-12-05 | International Business Machines Corporation | Automatic update of static and dynamic files at a remote network node in response to calls issued by or for application programs |
US5193162A (en) * | 1989-11-06 | 1993-03-09 | Unisys Corporation | Cache memory with data compaction for use in the audit trail of a data processing system having record locking capabilities |
US5220501A (en) * | 1989-12-08 | 1993-06-15 | Online Resources, Ltd. | Method and system for remote delivery of retail banking services |
JP2511591B2 (ja) * | 1990-10-29 | 1996-06-26 | インターナショナル・ビジネス・マシーンズ・コーポレイション | 無線光通信システムの動作方法および光通信システム |
US5224098A (en) * | 1991-07-17 | 1993-06-29 | International Business Machines Corporation | Compensation for mismatched transport protocols in a data communications network |
US5481721A (en) * | 1991-07-17 | 1996-01-02 | Next Computer, Inc. | Method for providing automatic and dynamic translation of object oriented programming language-based message passing into operation system message passing using proxy objects |
DE4131133B4 (de) * | 1991-09-19 | 2005-09-08 | Robert Bosch Gmbh | Verfahren und Vorrichtung zum Austausch von Daten in Datenverarbeitungsanlagen |
US5442633A (en) * | 1992-07-08 | 1995-08-15 | International Business Machines Corporation | Shortcut network layer routing for mobile hosts |
US5737536A (en) * | 1993-02-19 | 1998-04-07 | Borland International, Inc. | System and methods for optimized access in a multi-user environment |
US5511208A (en) * | 1993-03-23 | 1996-04-23 | International Business Machines Corporation | Locating resources in computer networks having cache server nodes |
JPH06324928A (ja) * | 1993-05-14 | 1994-11-25 | Mitsubishi Electric Corp | ログ生成装置とファイルの異なるバージョンの調停のための装置及び異なる場所にあるコンピュータファイルの異なるバージョンを調停するための装置 |
US5446736A (en) * | 1993-10-07 | 1995-08-29 | Ast Research, Inc. | Method and apparatus for connecting a node to a wireless network using a standard protocol |
US5412654A (en) * | 1994-01-10 | 1995-05-02 | International Business Machines Corporation | Highly dynamic destination-sequenced destination vector routing for mobile computers |
US5446888A (en) * | 1994-01-14 | 1995-08-29 | Pyne; Charles F. | Remote file transfer method and apparatus |
US5574906A (en) * | 1994-10-24 | 1996-11-12 | International Business Machines Corporation | System and method for reducing storage requirement in backup subsystems utilizing segmented compression and differencing |
US5572528A (en) * | 1995-03-20 | 1996-11-05 | Novell, Inc. | Mobile networking method and apparatus |
US5581558A (en) * | 1995-03-29 | 1996-12-03 | Lucent Technologies Inc. | Apparatus for bridging non-compatible network architectures |
US5829023A (en) * | 1995-07-17 | 1998-10-27 | Cirrus Logic, Inc. | Method and apparatus for encoding history of file access to support automatic file caching on portable and desktop computers |
US5850517A (en) * | 1995-08-31 | 1998-12-15 | Oracle Corporation | Communication link for client-server having agent which sends plurality of requests independent of client and receives information from the server independent of the server |
US5737619A (en) * | 1995-10-19 | 1998-04-07 | Judson; David Hugh | World wide web browsing with content delivery over an idle connection and interstitial content display |
US5878213A (en) * | 1996-02-15 | 1999-03-02 | International Business Machines Corporation | Methods, systems and computer program products for the synchronization of time coherent caching system |
US5859971A (en) * | 1996-02-15 | 1999-01-12 | International Business Machines Corp. | Differencing client/server communication system for use with CGI forms |
US5754774A (en) * | 1996-02-15 | 1998-05-19 | International Business Machine Corp. | Client/server communication system |
US5867661A (en) * | 1996-02-15 | 1999-02-02 | International Business Machines Corporation | Method and apparatus of using virtual sockets for reducing data transmitted over a wireless communication link between a client web browser and a host web server using a standard TCP protocol |
US5673322A (en) * | 1996-03-22 | 1997-09-30 | Bell Communications Research, Inc. | System and method for providing protocol translation and filtering to access the world wide web from wireless or low-bandwidth networks |
JPH09270794A (ja) * | 1996-03-29 | 1997-10-14 | Mitsubishi Electric Corp | ネットワーク管理装置 |
US5764910A (en) * | 1996-04-02 | 1998-06-09 | National Semiconductor Corporation | Method and apparatus for encoding and using network resource locators |
US5857201A (en) * | 1996-06-18 | 1999-01-05 | Wright Strategies, Inc. | Enterprise connectivity to handheld devices |
US5870558A (en) * | 1996-06-25 | 1999-02-09 | Mciworldcom, Inc. | Intranet graphical user interface for SONET network management |
US5774660A (en) * | 1996-08-05 | 1998-06-30 | Resonate, Inc. | World-wide-web server with delayed resource-binding for resource-based load balancing on a distributed resource multi-node network |
-
1996
- 1996-02-15 US US08/601,804 patent/US5754774A/en not_active Expired - Lifetime
- 1996-05-01 TW TW085105226A patent/TW297194B/zh not_active IP Right Cessation
- 1996-07-11 DE DE69610495T patent/DE69610495T2/de not_active Expired - Lifetime
- 1996-07-11 AT AT96923748T patent/ATE196707T1/de not_active IP Right Cessation
- 1996-07-11 JP JP52931197A patent/JP3953109B2/ja not_active Expired - Lifetime
- 1996-07-11 PL PL96327294A patent/PL180570B1/pl unknown
- 1996-07-11 KR KR1019970707261A patent/KR100289520B1/ko not_active IP Right Cessation
- 1996-07-11 CA CA002218169A patent/CA2218169C/en not_active Expired - Lifetime
- 1996-07-11 EP EP96923748A patent/EP0823170B1/en not_active Expired - Lifetime
- 1996-07-11 CN CNB96193946XA patent/CN1148927C/zh not_active Expired - Lifetime
- 1996-07-11 CZ CZ19973542A patent/CZ287988B6/cs not_active IP Right Cessation
- 1996-07-11 HU HU9801295A patent/HUP9801295A3/hu unknown
- 1996-07-11 ES ES96923748T patent/ES2151176T3/es not_active Expired - Lifetime
- 1996-07-11 WO PCT/US1996/011551 patent/WO1997030538A2/en active IP Right Grant
-
1997
- 1997-02-04 MY MYPI97000417A patent/MY122038A/en unknown
- 1997-10-03 US US08/939,724 patent/US6003087A/en not_active Expired - Fee Related
-
1998
- 1998-12-03 HK HK98112736A patent/HK1017789A1/xx not_active IP Right Cessation
-
2003
- 2003-10-24 JP JP2003364382A patent/JP3962369B2/ja not_active Expired - Lifetime
Also Published As
Publication number | Publication date |
---|---|
WO1997030538A2 (en) | 1997-08-21 |
HK1017789A1 (en) | 1999-11-26 |
KR100289520B1 (ko) | 2001-05-02 |
HUP9801295A3 (en) | 1998-10-28 |
MY122038A (en) | 2006-03-31 |
ES2151176T3 (es) | 2000-12-16 |
US6003087A (en) | 1999-12-14 |
CN1148927C (zh) | 2004-05-05 |
CA2218169A1 (en) | 1997-08-21 |
DE69610495D1 (de) | 2000-11-02 |
JPH11500895A (ja) | 1999-01-19 |
PL180570B1 (pl) | 2001-02-28 |
CN1195443A (zh) | 1998-10-07 |
KR19980703861A (ko) | 1998-12-05 |
ATE196707T1 (de) | 2000-10-15 |
CZ287988B6 (cs) | 2001-03-14 |
PL327294A1 (en) | 1998-12-07 |
HUP9801295A2 (hu) | 1998-08-28 |
CA2218169C (en) | 2004-12-14 |
JP3962369B2 (ja) | 2007-08-22 |
CZ354297A3 (cs) | 1998-03-18 |
JP2004164630A (ja) | 2004-06-10 |
EP0823170B1 (en) | 2000-09-27 |
US5754774A (en) | 1998-05-19 |
WO1997030538A3 (en) | 1998-04-30 |
DE69610495T2 (de) | 2001-05-10 |
EP0823170A2 (en) | 1998-02-11 |
TW297194B (en) | 1997-02-01 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP3953109B2 (ja) | クライアント/サーバ通信システム | |
JP4608195B2 (ja) | データ・キャッシュ方法 | |
JP3491011B2 (ja) | 差分化通信システム | |
JP3483892B2 (ja) | オーバヘッドの少ないtcp通信システム | |
CZ354197A3 (cs) | Způsob zachycování dat přijatých od druhé aplikace, zařízení a počítačový programový produkt k jeho provádění |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A911 | Transfer to examiner for re-examination before appeal (zenchi) |
Free format text: JAPANESE INTERMEDIATE CODE: A911 Effective date: 20031225 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20040127 |
|
A912 | Re-examination (zenchi) completed and case transferred to appeal board |
Free format text: JAPANESE INTERMEDIATE CODE: A912 Effective date: 20040129 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20040310 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20070314 Free format text: JAPANESE INTERMEDIATE CODE: A821 Effective date: 20070314 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A821 Effective date: 20070413 |
|
RD14 | Notification of resignation of power of sub attorney |
Free format text: JAPANESE INTERMEDIATE CODE: A7434 Effective date: 20070413 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20070424 |
|
R150 | Certificate of patent or registration of utility model |
Free format text: JAPANESE INTERMEDIATE CODE: R150 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20110511 Year of fee payment: 4 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20110511 Year of fee payment: 4 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20120511 Year of fee payment: 5 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20120511 Year of fee payment: 5 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20130511 Year of fee payment: 6 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20140511 Year of fee payment: 7 |
|
EXPY | Cancellation because of completion of term |