JP4800968B2 - デルタパッチを利用してファイルをアップデートするための方法 - Google Patents

デルタパッチを利用してファイルをアップデートするための方法 Download PDF

Info

Publication number
JP4800968B2
JP4800968B2 JP2006543792A JP2006543792A JP4800968B2 JP 4800968 B2 JP4800968 B2 JP 4800968B2 JP 2006543792 A JP2006543792 A JP 2006543792A JP 2006543792 A JP2006543792 A JP 2006543792A JP 4800968 B2 JP4800968 B2 JP 4800968B2
Authority
JP
Japan
Prior art keywords
update
computing device
file
client computing
delta
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.)
Active
Application number
JP2006543792A
Other languages
English (en)
Other versions
JP2007514232A5 (ja
JP2007514232A (ja
Inventor
ディ.マガイアー トーマス
ピー.メンジーズ デレク
ヴィー.スリガー マイケル
チェン デレク
モハンマド マツアール
ウィリアムズ ピーター
ヘンダーソン ガリー
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Microsoft Corp
Original Assignee
Microsoft Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Microsoft Corp filed Critical Microsoft Corp
Publication of JP2007514232A publication Critical patent/JP2007514232A/ja
Publication of JP2007514232A5 publication Critical patent/JP2007514232A5/ja
Application granted granted Critical
Publication of JP4800968B2 publication Critical patent/JP4800968B2/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • G06F8/65Updates
    • G06F8/658Incremental updates; Differential updates

Description

本発明は、ソフトウェアおよびコンピュータネットワークに関し、詳細には、本発明は、ソフトウェアアップデートを管理し伝えるためのシステムおよび方法に関する。
ほとんどの市販のソフトウェア製品は、継続的なリビジョンプロセスを受けて機能および/またはファンクションを修復し、またはアップグレードする。ソフトウェア製品またはソフトウェアコンポーネントの各リビジョンは、新しいファイルの追加および/または既存ファイルを新しいバージョンのファイルと置換することを必要とすることもある。ベンダが、ソフトウェア製品の問題を分離しその問題についての解決方法を作成した後に、ベンダは、その解決方法をアップデート中へと修正し、このアップデートを顧客に広く使用可能にしたいと望むはずである。ソフトウェアベンダは、ソフトウェアアップデートをできる限り速やかに、また問題なく顧客に対して配信すべきビジネスインセンティブ(business incentive)を有する。
インターネットは、顧客がソフトウェア製品についての最終アップデートを取得するための重要なチャネルを提供する。インターネットの使用の爆発的な増加は、ソフトウェア製品およびアップデートがオンラインでダウンロードするために提供されるという、顧客による一般的な期待を生み出してきている。インターネットを使用してアップデートを配信することを推進することは、それがソフトウェアベンダのコストを低減し、その修正版がダウンロードのために使用可能になるとすぐに顧客が識別された問題についてのその修正版を取得できるようになるので、ソフトウェアベンダのためにもなる。インターネット上のこれらのベンダサイトは、あるアプリケーションについてのアップデートファイルを見出し、その所在を突き止めることを非常に簡単にするように設計することが可能である。ファイルダウンロードの技術的側面は、ユーザの観点からはほとんど見えなくなってしまっており、今では一般にオペレーティングシステムによって処理される。
従来のアプローチでは、ソフトウェアベンダは、ソフトウェアアップデートをダウンロードのための「パッケージ」として構築する。このパッケージは、一般にその設定プログラムおよび各製品アップデートファイルが、埋め込まれ、このパッケージをより小さなパッケージにするために圧縮された自己展開(self−extracting、自己解凍)実行可能ファイルである。このパッケージのサイズは、一般に各変更ファイルの圧縮されたサイズとその抽出コードそれ自体のサイズを加えた合計である。実行すると、このパッケージは含まれている各ファイルを一時的なロケーションへと抽出し、次いでその設定プログラムを開始して各ファイルをシステムディレクトリ中の適切なロケーションにインストールする。圧縮形式で発送されたファイルは、ファイルがインストールされるときに伸張される。同じロケーション中の同じ名前の既存ファイルはどれも、この置換ファイルによって単に上書きされるはずである。
インターネットがソフトウェアアップデートの広範で速やかな配信を可能にしているにもかかわらず、ネットワーク伝送のその限られた帯域幅が問題を引き起こしてきている。大規模な一般のソフトウェアアプリケーションが、アップデートのダウンロードサイズを不当なほど大きくなるようにしてきている。通常は、製品の様々な問題についての多数の修正が、1つのアップデート中にグループ化されることになる。ベンダが定期的にソフトウェア製品をアップデートする場合、このアップデートパッケージのダウンロードサイズは、ユーザがすでに以前のアップデートからこれらのファイルを有しているという想定の下ではこのベンダがファイルを省略することができないので、増大し続けることになる。アップデートパッケージは、いくつかの全体ファイルを結合するので、たとえこれらのファイルが圧縮されている場合でさえ、非常に大きくなってしまうこともある。時には、最高速のモデム接続上でさえ、このダウンロードの帯域幅効率は低下する。
従来のダウンロードプロセスの時間を浪費する側面は、もちろん望ましくない。一部の場合においては、顧客は、これらのファイルのダウンロード中に長距離料金または接続時間料金を支払うこともある。接続時間のどのような短縮も、これらの顧客にとっての直接的な金銭的コストを低下させることになる。ベンダには一般に、ベンダが提供するダウンロードのサイズに関連した何らかの区別できるコストがあり、したがって、サイズを低減することは同様にベンダにとっても直接的な金銭的な利点をもたらす。ダウンロードのサイズを低減することは、その使用可能なネットワーク帯域幅を増大させることになり、ベンダは、既存のネットワークサーバ装置を用いて、より多くの顧客を満足させることができるようになる。
大規模なアップデートをダウンロードするためにかかる長い時間は、様々なネットワーク接続問題に対してこのダウンロードプロセスをよりぜい弱にもする。電話回線ノイズ、キャッチホン信号、および意図的ではないコマンドを含めて、インターネットセッションが時期尚早にも切断されてしまう可能性がある理由がいくつかある。一部のインターネットサービスプロバイダは、接続時間制限を強制し、ユーザが単一セッション中でオンラインとなることができる時間長が制限される。ネットワーク接続が遮断される場合にそのユーザが大規模なファイルをダウンロードしている場合には、ユーザは、初めからやり直す必要があり得る。ほとんどの一般のオペレーティングシステムおよびファイル転送プロトコルでは、このファイル転送を再開できるようにはなっておらず、したがって、任意の中間的進捗状況が失われてしまうはずであり、この転送は再開される必要がある。エラーの可能性は非常に多いので、多くのユーザには、オンラインでそのアップデートを取得することがほとんど不可能であることが分かる。アップデートパッケージのサイズがあまりにも大きすぎる場合には、ユーザが、アップデートパッケージを完全にダウンロードすることが決してできないこともある。
ソフトウェアアップデートのサイズを低減させ、帯域幅効率を増大させる1つの試みが、デルタパッチ(delta patch)またはバイナリパッチ(binary patch)の使用に関する。デルタパッチが、コンピューティングデバイスによって実行される場合に既存のファイルを修正する専用ソフトウェアコードに対応することが当業者には理解されよう。このデルタパッチが専用ソフトウェアコードを含むので、一意のデルタパッチは、ファイルの一意のバージョンごとに必要とされる。ソフトウェアアップデートに適用するときに、ソフトウェアアップデートサービス(software update service)は、完全なアップデートされたファイルを伝送する代わりに、より小さなサイズのアップデートデルタパッチを伝送することができる。次いでこのアップデートされたデルタパッチを利用してこの既存のファイルを修正してそのアップデートされたファイルにする。
このアップデートデルタパッチは、ファイルをアップデートするために必要とされるデータ量を潜在的に減少させる可能性があるが、デルタパッチング(delta patching)に対する現行のアプローチは、ファイルの多数のバージョンが存在する状況において、適用可能なデルタファイルの選択を管理する際に不十分である。一意のデルタパッチがファイルのバージョンごとに必要とされるので、典型的なソフトウェアアップデートシステムではしばしば、ファイルの一意の各バージョンに対応する、たとえ数千でないとしても数百の一意のデルタパッチを必要とする可能性がある。1つのアプローチでは、デルタパッチングをサポートする一部のアップデートサービスは、すべての可能性のあるデルタパッチをクライアントコンピューティングデバイス(client computing device)に対して伝送する。しかし、このアプローチでは、一般に可能性のあるアップデートデルタパッチの数が増すにつれて、このソフトウェアアップデートを実施するために必要とされるデータ量が増大する。したがって、適用可能な可能性のあるデルタパッチ数は、その完全なアップデートされたファイルと同じサイズへと速やかに増大してしまう可能性がある。別のアプローチでは、ネットワーク化されたアップデートソフトウェアサービスが、クライアントマシンをスキャンしてクライアントマシンごとにどのデルタパッチが適用可能となり得るかを選択する。これによって伝送されるデルタパッチ情報量が減少するが、このアプローチは、そのクライアントマシンをスキャンし適用可能なデルタパッチを選択するための、このソフトウェアアップデートサービス上の追加のロジックを必要とする。この追加のロジックの使用は、このサービスが提供する必要があるそのシステムリソースを増大させる。さらに、このアプローチは一般に、従来のウェブサーバが一般に実現するなどのネットワークキャッシング(network caching)の利用を妨げる。
前述の短所に加えて、既存のシステムでは、ハードウェアドライバなど、ある種のタイプのソフトウェアアップデートを配信することができない。当技術分野において知られているように、ハードウェアドライバに適用されるアップデートなど専用化されたソフトウェアアップデートは、ほとんどの専用化されたソフトウェアアップデートが特定のハードウェアを有するクライアントコンピュータ上でしか機能しないことになるので、大規模配信でユーザに提供することが困難である。ほとんどの場合において、例えばクライアントコンピュータが互換性のないハードウェアドライバのアップグレードを取得する場合には、このドライバアップグレードのインストレーションは、致命的なエラーを引き起こすこともあり、あるいはそのコンピュータが動作しないようにさえすることもある。
前述のことから簡単に理解されるように、サーバといくつかのクライアントの間でソフトウェアアップデートの改善された通信を有するシステムおよび方法が必要になっている。さらに、専用化されたアップデートを配信する場合に、アップデートサービスが特定のタイプのクライアントをターゲットにすることを可能にする改善されたメカニズムを有するソフトウェアアップデートのシステムおよび方法が必要になっている。
コンピューティングデバイス上の1つまたは複数のファイルをアップデートするためのシステムおよび方法が提供される。クライアントコンピューティングデバイスは、特定のバージョンのインストール済みのファイルを用いて特定のデルタパッチを識別するインデックスを含むアップデート情報を取得する。適用可能なアップデートのうちのどれを実行するかについて選択すると、クライアントコンピューティングデバイス上のアップデートエージェントは、インベントリを実施してアップデートすべきどのバージョンのファイルがそのマシン上にインストールされるかを識別する。このアップデートエージェントは、対応するデルタパッチを選択し、その要求をアップデートサービスに対して送信する。
本発明の一態様によれば、このクライアントコンピューティングデバイス上でデータをアップデートするための方法が提供される。この方法は、ソフトウェアアップデートサービスと通信する少なくとも1つのクライアントコンピューティングデバイスを含むコンピュータシステムの形で実施することができる。この方法によれば、コンピューティングデバイスは、このクライアントコンピューティングデバイス上にインストールされた1つまたは複数のファイルをアップデートするための1つまたは複数の使用可能なソフトウェアアップデートの選択を取得する。次いで、このコンピューティングデバイスは、複数のデルタパッチを識別するインデックスを取得する。各デルタパッチは、少なくとも1つのバージョンのインストール済みのファイルに対応する。このコンピューティングデバイスは、このクライアントコンピューティングデバイス上にインストールされた1つまたは複数のファイルのインベントリを取得する。このコンピューティングデバイスは、1つまたは複数の適用可能なデルタパッチを選択してこの選択されたソフトウェアアップデートを実施する。1つまたは複数の適用可能なパッチの選択は、このクライアントコンピューティングデバイス上にインストールされた1つまたは複数のファイルのインベントリに対する、その複数のデルタパッチを識別するインデックスのマッピングに対応する。次いで、このコンピューティングデバイスは、この1つまたは複数の選択されたデルタパッチを要求する。
本発明の別の態様によれば、このクライアントコンピューティングデバイス上でデータをアップデートするための方法が提供される。この方法は、ソフトウェアアップデートサービスと通信する少なくとも1つのクライアントコンピューティングデバイスを含むコンピュータシステムの形で実施することができる。本発明によれば、コンピューティングデバイスは、このクライアントコンピューティングデバイス上にインストールされた1つまたは複数のファイルをアップデートするための1つまたは複数の使用可能なソフトウェアアップデートの選択、および少なくとも1つのバージョンのインストール済みのファイルをアップデートするための複数の使用可能なデルタパッチを識別するパッケージを取得する。このコンピューティングデバイスは、このクライアントコンピューティングデバイス上にインストールされた1つまたは複数のファイルのインベントリを取得し、1つまたは複数の適用可能なデルタパッチを選択してこの選択されたソフトウェアアップデートを実施する。この1つまたは複数の適用可能なパッチの選択は、このクライアントコンピューティングデバイス上にインストールされた1つまたは複数のファイルのインベントリに対する、複数の使用可能なデルタパッチを識別するパッケージのマッピングに対応する。次いで、このコンピューティングデバイスは、1つまたは複数の選択されたデルタパッチを求める要求を送信する。
本発明のさらなる態様によれば、このクライアントコンピューティングデバイス上でデータをアップデートするための方法が提供される。この方法は、ソフトウェアアップデートサービスと通信する少なくとも1つのクライアントコンピューティングデバイスを含むコンピュータシステムの形で実施することができる。この方法によれば、コンピューティングデバイスは、このクライアントコンピューティングデバイス上にインストールされた1つまたは複数のファイルをアップデートするための1つまたは複数の使用可能なソフトウェアアップデートの選択、および複数のデルタパッチを識別するインデックスを取得し、ここで各デルタパッチは、少なくとも1つのバージョンのインストール済みのファイルに対応する。次いで、このコンピューティングデバイスは、このクライアントコンピューティングデバイス上にインストールされた1つまたは複数のファイルのインベントリを取得し、1つまたは複数の適用可能なデルタパッチを選択してこの選択されたソフトウェアアップデートを実施する。この1つまたは複数の適用可能なパッチは、このクライアントコンピューティングデバイス上にインストールされた1つまたは複数のファイルのインベントリに対する、これらの複数のデルタパッチを識別するインデックスのマッピングに対応する。このコンピューティングデバイスは、1つまたは複数の選択されたデルタパッチを要求し、この要求されたデルタパッチを取得する。このコンピューティングデバイスは、このデルタパッチを対応するインストール済みのファイルとマージしてアップデートされたファイルを生成し、このアップデートされたファイルをインストールする。
本発明の前述の態様およびその多くの付随する利点については、以下の詳細なる説明を添付図面と併せて参照することによってさらに良く理解が進むにつれて、さらに簡単に認識されよう。
一般的に説明すると、本発明は、ソフトウェアアップデートを管理するためのシステムおよび方法を対象としている。より詳細には、本発明は、ソフトウェアアップデートを選択し実施するために必要とされる帯域幅および処理リソースを最小にしながら、ソフトウェアアップデートの選択と実施を実行するためのシステムおよび方法を対象としている。本発明によれば、ソフトウェアアップデートは、特定のソフトウェアアプリケーションまたはオペレーティングシステムについてのアップデートに対応することが可能である。さらに、ソフトウェアアップデートは、ソフトウェアドライバ、またはシステムBIOSなどのファームウェアへのアップデートを含むこともできる。本発明の一態様によれば、これらのソフトウェアアップデートを処理するためのシステムおよびコンポーネントアーキテクチャが提供される。本発明の別の態様によれば、クライアントマシンのアップデートサービスとの許可および同期化を実施するためのアップデートプロトコルおよびインターフェースが提供される。本発明のさらなる態様によれば、インストレーションコンポーネント、およびデルタパッチを利用した様々なインストール済みのファイルをアップデートするための方法が提供される。しかし、本発明の追加の態様を本出願において提供することもできることが当業者には理解されよう。さらに、各識別された態様は、個別に、あるいは共通の発明態様の一部分として考えることができることが、当業者には理解されよう。
図1のソフトウェアアップデートシステム100は、本発明によるソフトウェアアップデートシステム100を示すブロック図である。一般的に説明すると、このソフトウェアアップデートシステム100は、1つまたは複数のクライアントコンピューティングデバイス110、アップデートサービス120、および外部アップデートプロバイダ130を含むことができる。一般的に説明すると、このアップデートサービス120は、このクライアントコンピューティングデバイス110に伝えられそこでインストールされるソフトウェアアップデートの配信を記憶し管理する。このソフトウェアアップデートは、このアップデートサービス120によって、あるいは任意の数の外部アップデートプロバイダ130によって提供することができる。
このクライアントコンピューティングデバイス110と、このアップデートサービス120と、この外部アップデートプロバイダ130は、ネットワーク101を介して電子的に通信する。このネットワークは、LAN(ローカルエリアネットワーク)、またはWAN(ワイドエリアネットワーク)やインターネットなどのより大規模なネットワークでもよい。一般的に知られているソフトウェアを使用することにより、ソフトウェアアップデートシステム100は、クライアントコンピューティングデバイス110とこのアップデートサービス120のサーバ121、122、123および124との間でドキュメント、コマンド、および他の知られているタイプの情報を交換するように構成することができる。当業者には理解されるように、図1に示すソフトウェアアップデートシステム100は、本発明を実施するための1つの適切なシステムの簡略化された実施例であり、本発明は、この実施例だけには限定されない。
以下にさらに詳細に説明するように、一実施形態のアップデートサービス120は、いくつかのサーバを備えている。図1に示すように、このアップデートサービス120は、このアップデートサービス120のこれら全部のプロセスを管理し、このアップデートサービス120のサーバ121、122、123および124のプロセスを調整するためのアップデートサーバ121を含んでいる。許可サーバ122は、クライアントが要求するときに許可クッキーを生成し、次にこの許可クッキーを使用してサーバクッキーを生成し、このサーバクッキーは、クライアントコンピュータがこのアップデートサービス120によって生成されるアップデートにアクセスすることができるようにする。メタデータサーバ123は、アップデートサービス120が提供するこれらのアップデートに関する一般的な情報を提供する。このメタデータサーバ123は、本発明のシステムが特定のタイプのクライアントコンピュータまたは特定のグループのクライアントコンピュータについての特定のアップデートを識別することができるようにする。ダウンロードサーバ124は、アップデートサービス120が提供するソフトウェアアップデートに関連するデータファイルを配信するための1つまたは複数のソフトウェアコンポーネントを提供する。
外部アップデートプロバイダ130は、ソフトウェアアップデートを配信する1つまたは複数のサーバを含むことができる。外部アップデートプロバイダ130は、ソフトウェア、ソフトウェアアップデート、またはクライアントコンピュータのグループに対して配信すべき他のデータを提供するエンティティに関連づけることができる。例えば、外部アップデートプロバイダ130は、このアップデートサービス120を使用して1つまたは複数のソフトウェアアプリケーションについてのアップデートを配信したいと希望するサードパーティソフトウェア開発業者に関連づけることができる。別の実施例では、外部アップデートプロバイダ130は、ソフトウェアアップデートシステム120に関連づけることもできる。
クライアントコンピューティングデバイス110は、ソフトウェアアプリケーション114を記憶し実行するどのようなコンピューティングデバイスとすることもできる。このクライアントコンピューティングデバイス110は、それだけには限定されないが、PC(パーソナルコンピュータ)、PDA(携帯型個人情報端末)、移動電話、2方向ページャなどを含めていくつかの異なるコンピュータ製品のうちのどの1つからでも形成することができる。当業者または他の人々に理解されるように、このクライアントコンピューティングデバイス110のアーキテクチャは適切な任意の形態を取ることができる。例えば、クライアントコンピューティングデバイス110は、ネットワーク101との通信を提供するためのネットワークインターフェースを含むことができる。このネットワークインターフェースは、有線または無線の任意のネットワーク接続と共に使用するように構成することができ、TCP/IPプロトコルなど適切な任意の通信プロトコルを用いて使用することができる。さらに、クライアントコンピューティングデバイス110は、処理ユニット、ディスプレイ、およびメモリユニットを含むことができる。このメモリユニットは、オペレーティングシステム116などのクライアントコンピューティングデバイス110を動作させるために必要なプログラムコードを記憶することができる。さらに、このメモリユニットは、本発明のプロセスを制御し実行するためのアップデート管理コンポーネント112を記憶する。
このソフトウェアアップデートシステム100は、実行される場合に、本発明を実施するソフトウェアプログラムを記憶する。実行される場合に、このソフトウェアアップデートシステム100は、ソフトウェアアップデートを記憶し管理し選択的に伝える。以下でさらに十分に説明するように、多くの他の利点のうちでもとりわけ、本発明は、ソフトウェアアップデートを受信する資格を有するターゲットグループのクライアントコンピューティングデバイスを定義し選択するメカニズムを提供している。本発明は、ソフトウェアアップデートに関連するデータファイルをダウンロードするための改善されたメカニズムも提供している。
本発明を例示する目的のために、本発明の動作する実施例の詳細な説明が提供される。この動作する実施例を説明するに際して、ソフトウェアアプリケーションの特定のアップグレード、例えばメディアプレーヤバージョン6.0からメディアプレーヤバージョン7.0のアップグレードを言及することができるソフトウェアアップデートに対して言及を行う。当業者には理解されるように、かかるソフトウェアアップデートは、このソフトウェアアップデートに関連するいくつかのデータファイルの通信およびインストレーションを含むことができる。したがって、本発明を例示する目的では、ソフトウェアアップデートとソフトウェアアップデートを含む個別のデータファイルとの間で区別が行われる。
次に図2〜6を参照して、クライアントコンピューティングデバイス110上で1つまたは複数のファイルをアップデートするためのソフトウェアアップデートシステム100のコンポーネント間の例示の相互作用について説明する。図2を参照すると、ソフトウェアアップデートサービスは、1つまたは複数の外部アップデートプロバイダ130によるソフトウェアアップデート情報の伝送によって起動される。前述のように、外部アップデートプロバイダ130は、ソフトウェアアップデートシステム100に関連づけることができる。代わりに、ソフトウェアアップデート情報は、サードパーティの外部アップデートプロバイダ130が伝送することもできる。本発明の例示の一実施形態においては、このソフトウェアアップデート情報は、ファイルをアップデートするために利用されるソフトウェアコード、ファイルを置換するために利用されるソフトウェアコード、このソフトウェアアップデートの適用性を決定するための様々な規則、および/またはこのソフトウェアアップデートを記述するディスプレイ情報を含むことが可能である。このソフトウェアアップデート情報の送信は、いつでも終了することができ、他の例示したソフトウェアアップデートコンポーネントの相互作用の開始と同時である必要はない。
外部アップデートプロバイダ130からのソフトウェアアップデート情報を受信すると、このアップデートサービス120は、1つまたは複数のデータを生成して、アップデート情報の伝送を実施する。このデータは、ファイルの異なるバージョンをアップデートするための1組のソフトウェアデルタパッチに対応するパッチストレージファイル(patch storage file)を含むことができる。このデータはまた、このパッチストレージファイル中で見出される対応するデルタ(delta)に対して特定のファイルバージョンをマッピングするインデックスに対応するパッチストレージマニフェスト(patch storage manifest)を含むこともできる。このデータは、以下にさらに非常に詳細に説明するように、このアップデートエージェント(update agent)が特定のソフトウェアアップデートデータを要求しインストールするために利用することになる情報に対応する自己展開ファイルをさらに含むことができる。パッチストレージファイル、パッチストレージマニフェスト、および自己展開ファイルの生成は、いつでも終了することができ他の例示したコンポーネントの相互作用と同時である必要がないことが当業者には理解されよう。
ソフトウェアアップデート情報のクライアントに対する伝送を起動するために、クライアントコンピューティングデバイス110は、このアップデートサービス120に対して認証要求を起動する。本発明の例示の一実施形態においては、この認証要求は、クライアントコンピューティングデバイス110とアップデートサービス120の間のアップデートプロトコル相互作用に対応し、これについては、以下でさらに非常に詳細に説明することにする。この認証が完了すると、アップデートサービス120は、認証クッキーをクライアントコンピューティングデバイス110に送信する。次に図3を参照すると、この認証済みのクライアントコンピューティングデバイス120は、次いでこの使用可能なアップデートのアップデートサーバ120との同期化を起動する。本発明の例示の一実施形態においては、この同期化要求は、クライアントコンピューティングデバイス110とアップデートサービス120との間のアップデートプロトコル相互作用にも対応し、これについては、以下でさらに非常に詳細に説明することにする。この同期化が完了すると、クライアントコンピューティングデバイス110は、すべての適用可能なソフトウェアアップデートの情報、およびこのアップデートを記述する情報を受信する。しかし、本発明の例示の一実施形態においては、このアップデートをインスタンス化するソフトウェアコードは、ダウンロードされていない。
続けて図3を参照すると、このアップデートプロセス中のある時点で、インストールすべきアップデートの選択が受信される。本発明の例示の一実施形態においては、ユーザが、同期化中に受信するソフトウェアアップデート情報を提示され、適切なアップデートを選択するように求められることもある。代わりに、クライアントコンピューティングデバイス110が、すべての適用可能なソフトウェアアップデートを自動的に選択するように構成することもできる。さらに、クライアントコンピューティングデバイス110が、使用可能なソフトウェアアップデートのサブセットを自動的に選択することができるようにする何らかの規則を有することもある。さらにまた、ユーザが、インターネットのウェブページを介するなどアップデートサービス120と通信することによってアップデートの選択を開始することもできる。
次に図4を参照すると、アップデートエージェントがまだ存在していない場合、アップデート管理コンポーネント112は、クライアントコンピューティングデバイス110上でアップデートエージェント118をインスタンス化する。次いでアップデートエージェント118は、自己展開ファイルなどのソフトウェアアップデート情報パッケージの伝送を要求する。このアップデートエージェント118は、この自己展開ファイルを受信し、以下で説明するようにそのインストーラに対して任意のアップデートを実施する。さらに、アップデートエージェント118は、アップデートサービス120から任意の欠損した、または破損した情報を要求することができる。
次に図5を参照すると、アップデートエージェント118が、そのソフトウェアアップデート情報パッケージを受信した後に、アップデートエージェント118は、クライアントコンピューティングデバイス110上でインストールされるファイルのインベントリを実施する。このインベントリとそのソフトウェアアップデート情報パッケージの比較に基づいて、アップデートエージェント118は、どのデルタパッチまたは他のアップデート情報が、この選択されたアップデートを完了するために必要になるかを決定する。次いでアップデートエージェント118は、特定のデルタアップデートを求める要求を伝送する。本発明の一実施形態においては、ソフトウェアアップデートを求める要求は、直接ネットワーク接続を介して伝送される直接要求に対応することもあり、これは手動アップデートと呼ばれることになる。本発明の別の実施形態においては、ソフトウェアアップデートを求める要求は、顕在的なユーザアクションを必要とせずに伝送されるバックグラウンド要求である場合もある。この実施形態は、自動アップデートと呼ばれることになる。
本発明の例示の一実施形態においては、このソフトウェアアップデートが、デルタパッチに対応する場合、アップデートエージェント118は、そのパッチストレージマニフェストによって識別される特定のデルタパッチを識別する要求をアップデートサービス120に対して伝送する。代わりに、デルタパッチが使用可能でない場合、またはいくつかのデルタパッチが失敗している場合に、アップデートエージェント118は、フォールバックプロシージャ(fallback procedure)を起動することができる。このフォールバックプロシージャは、そのパッチストレージファイルから全体のアップデートファイルの完全コピーの伝送を求める要求を含むことができる。このフォールバックプロシージャはまた、自己完結型のパッケージから全体がアップデートされたファイルの完全コピーの伝送を求める要求を含むこともできる。
本発明の例示の一実施形態においては、アップデートサービス120のダウンロードサーバ124は、アップデートエージェント118からのこのソフトウェアアップデート要求を直接処理することができる。代わりに、この要求は、アップデートサービス120からのこの要求されたアップデートデルタパッチをいずれにしても受信している従来のウェブサーバなど任意の数の追加の外部ダウンロードサーバによって処理することもできる。例えば、ある会社では、内部サーバを利用してクライアントマシンをアップデートすることができる。さらに、この要求は、以前の要求を処理する際にそのアップデートデルタパッチの一部または全部がキャッシュされた外部ダウンロードサーバによって処理することもできる。したがって、この実施形態においては、このダウンロードは、「HTTP」(hyper text transfer protocolハイパーテキスト転送プロトコル)データ要求をサービスすることが可能ないくつかの追加のダウンロードサーバに分散することができる。
図6を参照すると、このソフトウェアアップデート情報が受信された後に、アップデートエージェント118は、このデルタパッチをこのインストール済みのファイルとマージしてアップデートされたファイルを生成する。さらに、アップデートエージェント118は、このマージが正常にその適切なファイルをアップデートしたかどうか妥当性検査することができる。前述のように、デルタパッチを妥当性検査することができない場合には、アップデートエージェント118は、そのデルタパッチを再度要求することができ、あるいは、何回かの失敗の後に全体がアップデートされたファイルを要求することができる。アップデートエージェント118が、妥当性検査されたアップデートファイルを取得した後に、このファイルは、クライアントコンピューティングデバイス110上にインストールされる。
図7は、本発明による、クライアントコンピューティングデバイス110とソフトウェアアップデートサービス120の間の相互作用を示すソフトウェアアップデート処理ルーチン700の流れ図である。ブロック702において、このソフトウェアアップデートサービス120は、このクライアントコンピュータ110に対してアクセスを許可する。本発明の例示の一実施形態においては、クライアントコンピュータに対するアクセスの許可は、特定のグループのコンピュータに関連するソフトウェアアップデートへのアクセスを可能にするサーバ発行クッキー(server−issued cookie)の生成を含むことが可能である。この許可プロセスのより詳細な説明は、図8に関して説明することにする。
ブロック704において、このクライアントコンピュータ110とソフトウェアアップデートサービス120は、アップデート情報を同期化させる。本発明の例示の一実施形態においては、ソフトウェアアップデートサービス120は、このクライアントコンピューティングデバイス110に対して特定のソフトウェアアップデートを記述するメタデータを送信する。このメタデータは、ユーザがインストレーションについての1つまたは複数のアップデートを選択できるようにする使用可能なソフトウェアアップデートを記述する情報を含んでいる。この同期化プロセスのより詳細な説明については、図9および図10に関して以下で説明することにする。ブロック706において、クライアントコンピューティングデバイス110は、ダウンロードする適用可能なアップデートの選択を得る。本発明の例示の一実施形態においては、適用可能なアップデートのこの選択は、ユーザの選択を実施するいくつかの固有のユーザインターフェースの利用に対応する可能性がある。ユーザインターフェースの選択については、図11に関してさらに非常に詳細に説明することにする。
ブロック708において、クライアントコンピューティングデバイス110は、適用可能なソフトウェアアップデートのこのユーザ選択を処理し、ソフトウェアアップデートサービス120とインターフェースして特定のアップデート情報を要求する。本発明の例示の一実施形態においては、クライアントコンピューティングデバイス110は、1つまたは複数の適用可能なアップデートデルタパッチを選択し要求する。次いでクライアントコンピューティングデバイス110上のアップデートエージェント118は、この要求されたデータを処理してこの選択されたソフトウェアアップデートを実施することができる。ブロック710において、このルーチン700は終了する。
図8を参照して、クライアントコンピューティングデバイス110に対してアクセスを許可するための、ブロック702(図7)に対応するプロトコル図800について次に説明することにする。本発明の例示の一実施形態においては、ソフトウェアアップデートサービス120は、拡張ターゲティングメカニズム(extensible targeting mechanism)を利用してクライアントコンピューティングデバイス110のアップデートおよび他のソフトウェアへのアクセスを制御する。このソフトウェアアップデートサービス120は、特定のソフトウェアアップデートを1つまたは複数のターゲットグループのクライアントコンピューティングデバイス110に関連づけるメカニズムを組み込んでいる。例えば、ソフトウェアアップデートサービス120は、特定のハードウェアデバイスを有する特定のブランドのクライアントコンピューティングデバイス110だけに特定のハードウェアドライバアップデートのアクセスを制限することができる。かかる実施例においては、このソフトウェアアップデートサービス120は、特定のブランド名および特定のハードウェアデバイスを有するクライアントコンピューティングデバイス110のターゲットグループを定義し、この特定のソフトウェアダウンロードの送信をそのターゲットグループだけに制限することができる。
本発明の例示の一実施形態においては、拡張ターゲティングメカニズムは、1つまたは複数のターゲットグループに対するクライアントコンピューティングデバイスの会員資格を定義するソフトウェアコンポーネント(「許可プラグイン」)の使用によって実行される。クライアントコンピューティングデバイス110上の許可プラグインの存在は、そのクライアントコンピューティングデバイスがその許可プラグインの特定のターゲットグループに属するかどうかを規定する。例えばあるターゲットグループは、特定のソフトウェアアプリケーションについての有効な「PID」(product identification製品識別)番号を有するすべてのコンピュータを含むことができる。かかる実施例においては、図8に関して以下でより詳細に説明するように、許可プラグイン826をそのクライアント中でインストールしてそのクライアントコンピューティングデバイスのメモリモジュールからPIDを読み取り、この得られたPIDを対応するPIDサーバプラグイン829へと渡すことができる。本明細書中でPIDバリデータ(PID validator)829とも呼ばれるこの対応するPIDプラグインは、1つまたは複数の方法を利用してこの受信されたPIDが有効かどうかを判定する。このクライアントコンピューティングデバイス110上に記憶されているPIDが有効であると判定された後に、このサーバは、このクライアントコンピューティングデバイス110が有効なPIDを有するターゲットグループのメンバであることを示すサーバクッキーを生成する。別の実施例においては、ターゲットグループは、ベータテストコンピュータ(beta test computer)として指定されるクライアントコンピューティングデバイスを含むことができる。
本発明の例示の一実施形態においては、ソフトウェアアップデートサービス120の許可サーバ122は、この許可サーバが認識することになるクライアントコンピューティングデバイスの1組のターゲットグループを定義するいくつかのサーバ許可プラグインを含んでいる。各サーバ許可プラグインは、クライアントコンピューティングデバイス110上に記憶された対応するクライアント許可プラグインとデータをやりとりするコンポーネントを含んでいる。同様にして、各クライアントコンピューティングデバイス110は、そのクライアントが属するターゲットグループを識別する1つまたは複数のクライアント許可プラグインを含んでいる。本発明の例示の一実施形態においては、このクライアント許可プラグインは、オペレーティングシステムのインストレーションやアップグレードなど、ソフトウェアアプリケーションのインストレーションまたはアップグレード中に各クライアントコンピューティングデバイス中にインストールすることができる。さらに、このサーバ許可プラグインは、ソフトウェアアップデートへのアクセスを制御したいと希望するアドミニストレータが動的にインストールし、または取り除くことができる。クライアントコンピューティングデバイス110および許可サーバ122上に記憶されたこの許可プラグインは、実際のソフトウェアプラグインとすることも可能であり、あるいはこの許可プラグインは、動的にリンクされたライブラリ中へとハードコード化することも可能である。
図8に示すように、この許可サーバ122は、3つの実施例のサーバ許可プラグイン、すなわち(1)すべてのコンピュータを含むターゲットグループ(以下で、「オールコンピュータターゲットグループ(All Computer target group)」)を定義する第1のサーバ許可プラグイン828、(2)有効なPIDを有するコンピュータを含むターゲットグループ(以下で、「PIDターゲットグループ」)を定義する第2のサーバ許可プラグイン829、および(3)ベータテストコンピュータを含むターゲットグループ(以下で、「ベータターゲットグループ」)を定義する第3のサーバ許可プラグイン830を含んでいる。また図8に示すように、クライアントコンピューティングデバイス110は、2つのクライアント許可プラグイン、すなわち(1)クライアントコンピューティングデバイス110が、オールコンピュータターゲットグループのメンバであることを示す第1のクライアント許可プラグイン825、および(2)クライアントコンピューティングデバイス110が、PIDターゲットグループのメンバであることを示す第2のクライアント許可プラグイン826を含んでいる。この実施例においては、クライアントコンピューティングデバイス110は、このクライアントコンピューティングデバイス110がそのベータターゲットグループのメンバであることを示す許可プラグインを含んでいない。当業者には理解されるように、各クライアント許可プラグイン825および826は、クライアントコンピューティングデバイス110上で1つまたは複数のファンクションを実行してこの妥当性検査プロセスを支援するように構成することができる。例えば、この第2のクライアント許可プラグイン826は、クライアントコンピューティングデバイス110のメモリを検査してインストール済みのソフトウェアアプリケーションについてのPIDを検証し、または取得するように構成することができる。
図8に示すように、許可サブルーチン702は、クライアントコンピューティングデバイス110が構成要求803を許可サーバ122に伝える場合に開始される。本発明の例示の一実施形態においては、この構成要求803は、この許可サーバ122上に記憶されたその許可プラグインを記述する情報を取得するように構成された任意の適切なソフトウェアコンポーネントから形成される。当業者には理解されるように、構成要求803は、「GetConfig」と呼ばれる、知られている方法を利用することができる。この構成要求803を受信することに応答して、許可サーバ122は、構成応答804を伝え、この構成応答は、許可サーバ122上に記憶されたすべての許可プラグインを識別する情報を含んでいる。一実施形態においては、この構成応答804は、許可サーバ122上に記憶されるすべての許可プラグインを識別し記述するストリングのアレイを含んでいる。本実施例においては、この構成応答804は、第1のサーバ許可プラグイン828、第2のサーバ許可プラグイン829、および第3のサーバ許可プラグイン830を識別する情報を含んでいる。
ブロック805において、クライアントコンピューティングデバイス110は、この構成応答804を受信することに応答して1つまたは複数の許可クッキーを生成する。ブロック805のプロセスにおいて、クライアントコンピューティングデバイス110は、マッチングしたクライアントとサーバ許可プラグインの各対ごとに許可クッキーを生成する。したがって、本実施例においては、第1のクライアント許可プラグイン825と第1のサーバ許可プラグイン828が共にオールコンピュータターゲットグループに関連するので、第1のクライアント許可プラグイン825は、このオールコンピュータターゲットグループに関連する第1の許可クッキーを生成する。さらに、第2のクライアント許可プラグイン826と第2のサーバ許可プラグイン829が共にPIDターゲットグループに関連するので、第2のクライアント許可プラグイン826は、このPIDターゲットグループに関連する第2の許可クッキーを生成する。クライアントコンピューティングデバイス110は、それがベータターゲットグループのメンバであることを示す許可プラグインをもたないので、第3の許可クッキーは生成されない。
当業者には理解されるように、ブロック805のプロセスの一実施形態は、当技術分野において「GetAuthCookie」と呼ばれる一般に知られているソフトウェアの方法を使用することを含んでいる。この各許可クッキーの生成は、追加の処理を含むことができることも理解されよう。例えば、第2のクライアント許可プラグイン826は、このクライアントのシステムレジストリ(system registry)に記憶された情報を検査してPIDを検索しこのPIDをこの許可クッキー中に含めるように構成することができる。他の実施例においては、ブロック805のプロセスは、他のコンピュータまたはデバイスと通信するためのプロセスを含むことができる。例えば、クライアント許可プラグインは、サウンドカード、スキャナ、ビデオカードなどのデバイスと通信してこのデバイスの型およびモデルを取得することができる。限定のない他の実施例においては、クライアント許可プラグインは、フィンガプリントリーダ(fingerprint reader)などのセキュリティデバイスと通信して、ユーザを記述する情報を取得することができる。
一般に、クライアント許可プラグインは、クライアントコンピューティングデバイス110、またはクライアントコンピューティングデバイス110に通信可能に接続された他の任意のコンピューティングデバイスの任意のコンポーネントから構成情報を読み取ることができる。他の実施例においては、クライアント許可プラグインは、1つまたは複数のパブリックまたは専用のAPI(アプリケーションプログラミングインターフェース)を利用してこの対応するサーバプラグインによって妥当性検査されるクライアントからの情報を収集し暗号化するように構成することができる。かかる実施例においては、PIDバリデータプラグイン826は、専用のAPIを使用してこのクライアントのPIDを暗号化して、この暗号化済みのPIDを暗号解読と妥当性検査のためにサーバに渡す。他の実施形態においては、他のクライアント許可プラグインは、フィンガプリントリーダや声紋などの生物測定学の測定を利用して許可クッキーを構築して妥当性検査のためにサーバに渡すことができる。さらに他の実施例においては、クライアント許可プラグインは、ウェブサービスまたは他の任意のサービスを呼び出して許可証明書または他の任意タイプのデータをこの許可サーバ122に伝えることができる。
本発明の例示の一実施形態においては、各許可クッキーは、関連するターゲットグループを識別するストリングを含んでいる。例えば、ストリングは、特定の許可クッキーがこのPIDターゲットグループに関連することを示すことができる。各許可クッキーは、クライアントとサーバの間でデータを伝えるためのデータセクションも含んでいる。例えば、このPIDターゲットグループに関連する許可クッキーは、実際のPIDを含むデータセクションを有することができる。当業者には理解されるように、このデータセクションは、バイトアレイなどの任意の形式で記憶される任意のタイプのデータを含むことができる。例えば、クライアントおよびサーバ上のプラグインが、パブリックキー(public key)およびプライベートキー(private key)の通信を必要とする場合には、かかるデータは、1つまたは複数の許可クッキーのデータセクション中で暗号化することができる。
クライアントコンピューティングデバイス110が対応するクライアントおよびサーバの許可プラグインの各対ごとに許可クッキーを生成した後に、このクライアントコンピューティングデバイスは、この生成済みの許可クッキーをこの許可サーバ122に対して伝える。図8に示すように、クライアントコンピューティングデバイス110は、クッキー要求806においてこの許可クッキーを伝える。このクッキー要求806は、ブロック805のプロセス中で生成された許可クッキーのアレイを伝えるための適切な任意のフォーマットを含んでいる。この許可方法702のこの一部分の一実施形態は、当技術分野において「GetCookie」と呼ばれる一般的に知られているソフトウェアの方法の使用を含むことができる。
一実施形態においては、クッキー要求806は、クライアントコンピューティングデバイス110のメモリに記憶された他の許可サーバクッキーも含んでいる。以下の説明からさらに簡単に理解されるように、クライアントコンピューティングデバイス110のこのメモリは、この許可ルーチン700の以前の実行において作成された以前の許可サーバクッキーを記憶していることもある。クッキー要求806においてこの記憶済みの許可サーバクッキーを提供することにより、このクライアントコンピューティングデバイス110は、許可サブルーチン702の以前の実行で認可されたそのアクセス権を維持することができるようになる。本実施例においては、このクライアント中に許可サーバクッキーが記憶されていないので、このクッキー要求806は、このオールコンピュータターゲットグループに関連する第1の許可クッキーと、このPIDターゲットグループに関連する第2の許可クッキーを含んでいる。
次に、ブロック807に示すように、このクッキー要求806を受信することに応答して、許可サーバ122は、サーバクッキーを生成する。一実施形態においては、この受信した許可クッキーごとに適切な許可プラグインに対して呼出しを行って、サーバクッキーデータが生成される。各サーバ許可プラグインによって生成されるサーバクッキーデータは、この受信された許可クッキー中で識別されるターゲットグループごとの識別子を含んでいる。本実施例においては、クッキー要求806が、このオールコンピュータターゲットグループに関連する第1の許可クッキーと、このPIDターゲットグループに関連する第2の許可クッキーとを含んでいるので、許可サーバ122は、これらの各ターゲットグループについての識別子を含むサーバクッキーデータを生成する。許可サーバ122上において、以前のサーバクッキーがそのクッキー要求806において受信されている場合には、このサーバクッキーデータを以前のサーバクッキーのデータと組み合わせて新しいサーバクッキーを生成する。一実施形態においては、この新しいサーバクッキーは、トリプルDES(Triple DES)などのパブリックに利用可能な暗号方法の使用によって暗号化される。
本発明の例示の一実施形態においては、このサーバクッキーは、1つまたは複数の関連するターゲットグループを識別する暗号化された情報を含むことが可能である。さらに、このサーバクッキーは、有効期限データ(expiration data)を含むことができ、これは、クリアテキストフォーマットでも暗号化フォーマットでも記憶される。クリアテキストフォーマットで記憶される有効期限データは、このサーバクッキーの有効期限切れについて監視するためにクライアントコンピューティングデバイス110によって使用される。この暗号化フォーマットで記憶される有効期限データは、ソフトウェアアップデートサービス120によって使用されて、このクライアントコンピューティングデバイス110が、特定のターゲットグループに関連するアップデートを受信することが許可されているかどうかを判定する。一実施形態においては、このサーバクッキーの有効期限データは、このサーバクッキーで識別されるすべてのターゲットグループに適用される。代わりに、またはこの全体のサーバクッキーに適用される有効期限の時間に追加して、このサーバクッキーは、それぞれ、個別のターゲットグループに適用できる複数の有効期限データを含むことができる。当業者には理解されるように、各サーバクッキーは、追加のデータを含むことができる。例えば、サーバクッキーは、この許可サブルーチン702の最後の実行のタイムスタンプなどのクライアント状態情報を記憶するように構成することができる。
生成された後に、この許可サーバクッキー809は、許可サーバ122からクライアントコンピューティングデバイス110に伝えられる。次に、ブロック811に示すように、このサーバクッキーは、その後にクライアントコンピューティングデバイス110のメモリに記憶される。クライアントコンピューティングデバイス110が、このサーバクッキーの少なくとも1つのコンポーネントが、有効期限切れになったことを判定した場合には、このクライアントコンピューティングデバイスは、この許可方法702を再実行して新しいサーバクッキーを取得することができる。前述のように、この許可方法702の後続の各実行において、クライアントコンピューティングデバイス110は、このクッキー要求806においてその記憶されたサーバクッキーを許可サーバ122に対して伝えることができる。一実施形態においては、サーバが、クライアントにこのサーバ構成が変更されたこと、すなわち新しい許可プラグインが追加されたことを通知しない限り、このクライアントは、要求803を送信する必要がない。
本発明の別の態様によれば、このソフトウェアアップデートサービス120は、メタデータサーバ123とクライアントコンピューティングデバイス110の間でアップデート情報を同期化させるための同期化サブルーチンを提供することができる。一意のソフトウェアアップデート階層を使用することによって、この同期化サブルーチンは、特定のクライアントコンピューティングデバイスに適用される特定のアップデートを効率的に識別することが可能である。さらに、この許可サブルーチン702において生成されるこのサーバクッキーの使用によって、この同期化サブルーチンは、特定のターゲットグループに関連するアップデートに対するアクセスを選択的に認可することが可能である。
本発明の例示の一実施形態によれば、各ソフトウェアアップデートは3つのコンポーネント、すなわち(1)命令コンポーネント、(2)局所的データコンポーネント、および(3)データコンポーネントを含んでいる。当業者には理解されるように、各アップデートは、1つまたは複数の前述のコンポーネントを有することができる。例えば、アップデートが、命令コンポーネント、局所的データコンポーネント、およびデータストリームコンポーネントを含むこともある。別の実施例においては、アップデートは、クライアントコンピューティングデバイスの1つまたは複数の条件をテストするための1つの命令コンポーネントしか含まないこともある。このソフトウェアアップデートの様々なコンポーネントについて以下でより詳細に説明する。
一般的に説明すると、この命令コンポーネントは、2つのサブコンポーネント、すなわち(1)クライアントコンピューティングデバイス110がテストすべき1つまたは複数の条件を定義する適用規則、および(2)個別のアップデートの適切なインストレーションのために必要とされる1つまたは複数のアップデートを識別する1組の前提条件を含んでいる。以下で説明するように、この適用規則は、1台のコンピュータに関連したいくつかの条件を定義することが可能であり、これらの各条件は、任意の論理演算子を使用することによって他の条件に関連づけることが可能である。例えば、この命令コンポーネントは、コンピュータが特定のバージョンのWindows(登録商標)をインストールしているかどうかを判定する適用規則を含むこともできる。また以下で説明するように、この1組の前提条件は、以前にインストールされている必要がある1つまたは複数のアップデートを識別することが可能である。例えば、図9を参照して以下でさらに詳細に説明するように、個別のアップデートは、個別のアップデートの適切なインストレーションのために必要とされる他のアップデートをリストにした前提条件を含むこともある。他の実施例においては、図9にも示すように、この1組の前提条件は、より複雑な前提条件の規則を定義するための論理演算子の使用を含むことも可能である。
この命令コンポーネントはまた、特定のアップデートに依存する他のアップデートが存在するかどうかを示す、ブールフラグ(Boolean flag)などのコードも含む。図では、特定のアップデートに依存する他のアップデートが存在しない場合には、アップデートは、LEAFアップデートであると考えられる。あるアップデートがLEAFであるかどうかを示すために使用されるこのブールフラグは、関連したアップデートが追加され、または除去されるときに、メタデータサーバ123によって動的にアップデートされる。
各アップデートの局所的データコンポーネントは、このアップデートを記述する一般的な情報を含んでいる。例えば、この局所的データコンポーネントは、このアップデートの特徴および利点を記述する情報を含むことができる。この局所的データコンポーネントはまた、このアップデートのインストレーションプロシージャのテキスト記述を含むこともできる。さらに、この局所的データコンポーネントは、このアップデートに関連した他の任意のデータまたは情報を含むこともできる。例えば、その局所的データは、アップデートが、高優先順位のアップデートであることを示すことができる。別の実施例においては、この局所的データは、アップデートが他のソフトウェアアップデートと共にインストールすることができないことを示すメッセージなど、特定のインストレーションメッセージを提供することができる。この局所的情報は、ユーザに対してその含まれる情報の表示を可能にするフォーマットにすることもできる。
各アップデートのデータコンポーネントは、そのアップデートの1つまたは複数のバイナリデータストリーム(binary data stream)を含んでいる。一実施形態において、各アップデートのデータコンポーネントは、実行可能ファイル、ドキュメント、リンクされたライブラリなど、1つまたは複数のデータファイルに関連づけることができる。以下でさらに詳細に説明するように、各アップデートは、データファイルの組合せに関連づけることができ、これらのデータファイルのそれぞれは、クライアントが使用するソフトウェアの実際のアップグレード、インストレーション、または修正を実施する。例えば、アップデートのインストレーションは、選択されたアップデートを完了するために必要とされるすべての情報を含む1つのCABファイルの使用によって実施することができる。代わりに、このアップデートのインストレーションは、クライアントコンピューティングデバイス上に記憶される1つまたは複数のファイルをアップデートするために使用されるいくつかの個別のアップデートの使用によって実施することができる。
本発明の例示の一実施形態においては、ソフトウェアアップデートは、このソフトウェアアップデートの制御された配信を可能にする階層の形で構成することが可能である。一般的に説明すると、アップデートのこの階層は、アップデートの間の関係を定義しており、特にどのアップデートが他のアップデートに依存しているかを示している。図示するために、実施例の1組のアップデートが、図9に提供され示されている。図に示すように、サンプルのアップデート900の階層は、ベースの組のアップデート901、第2の組のアップデート902、および第3の組のアップデート903を含んでいる。一般的に、ベースの組のアップデート901中の各アップデートは、他のアップデートのインストレーションを必要とする前提条件を有していない。しかし、第6のアップデート921は、この第1のアップデート911、第2のアップデート912、および第3のアップデート913のインストレーションを必要とする前提条件を含んでいる。第7のアップデート922は、第4のアップデート914のインストレーションを必要とする前提条件を含んでいる。第8のアップデート931は、第6のアップデート921、および第5のアップデート915のインストレーションを必要とする前提条件を含んでいる。したがって、第8のアップデート931はまた、第1のアップデート911、第2のアップデート912、および第3のアップデート913のインストレーションを必要とする。本発明を例示するために、このサンプルの1組のアップデート900のうちのすべてのアップデートが、すべてオールコンピュータターゲットグループおよびPIDターゲットグループに関連していることが想定されている。
また図9に示すように、また以下でさらに詳細に説明するように、各アップデートは、このアップデートのインストレーションについての条件を指定する適用規則を含んでいる。例えば、第1のアップデート911は、オペレーティングシステムの英語バージョンのインストレーションを必要とする。第2のアップデート912は、Windows(登録商標)XPバージョンSP1のインストレーションを必要とする。別の実施例においては、第6のアップデート921は、XP PATCH1と呼ばれるソフトウェアパッチのインストレーションを必要とする。したがって、この適用規則が満たされていない場合には、クライアントコンピューティングデバイス110は、このアップデートをインストールしないはずである。
図9はまた、特定のアップデートに依存する他のアップデートがあるかどうかを示す命令コンポーネントのセクションを示している。このセクションは、LEAFと呼ばれ、これは、ソフトウェアアップデートが一連の関連したアップデートの最後のアップデートであることを示すブール値(Boolean value)の形式とすることができる。本発明を例示する目的では、他のアップデートが、特定のアップデートを前提条件としてリストアップしない場合には、特定のアップデートは、LEAFアップデートになる。図9に示すように、第7のアップデート922と、第8のアップデート931が、このたった2つのLEAFアップデートである。
図10は、本発明に従って形成される同期化サブルーチン704(図7)のプロトコル図を示している。一般的に説明すると、この同期化サブルーチン704は、クライアントコンピューティングデバイス110と、メタデータサーバ123などのサーバとの間である種のアップデートの命令コンポーネントを選択的に交信してクライアントコンピューティングデバイス110に適用することが可能なアップデートを識別する。図10に示すように、アップデートを起動するために、クライアントコンピューティングデバイス110は、まずインストール済みのアップデートを処理し、このクライアントにとって使用可能な1つまたは複数のアップデートを要求する同期化要求1051をメタデータサーバ123に対して伝える。この同期化要求1051を受信することに応答して、このメタデータサーバ123は、いくつかのアップデートをこのクライアントコンピューティングデバイス110に対して戻す。以下の説明からさらに簡単に理解されるように、クライアントコンピューティングデバイス110は、この同期化要求1051の通信に先立って局所的に記憶されたデータを処理する。
クライアントコンピューティングデバイス110は、各受信されたアップデートの命令コンポーネントを処理してこの適用規則中で定義されるその条件を満たすことができるかどうかを判定する。個別のアップデート中で定義されるこの条件が満たされる場合、同期化サブルーチン1050を例示する目的では、個別のアップデートが「インストール済み」であり、このインストール済みのアップデートがこのクライアントのアップデートキャッシュの第1のコンポーネントに保存される。他方、個別のアップデート中で定義されるこの条件が満たされない場合には、個別のアップデートは、「失敗した」と考えられ、この失敗したアップデートが、このクライアントのアップデートキャッシュの第2のコンポーネントに保存される。この同期化サブルーチン1050のこの説明において、アップデートがインストールされる場合には、この適用規則のこれらの前提条件およびこの条件が満たされていることを仮定することができる。このサブルーチンを説明するためのアップデートのインストレーションは、このアップデートに関連するこのデータファイルが、クライアントコンピューティングデバイス110において実際にインストールされることを必ずしも意味していない。
一実施形態においては、このクライアントのアップデートキャッシュのこれらの2つのコンポーネントを使用してこの受信済みのアップデートを分類する。第1のコンポーネントが、インストール済みの非LEAFアップデートを記憶するために使用され、第2のコンポーネントが、クライアントが受信する他のすべてのアップデート、すなわちインストールされなかったアップデートを記憶するために使用される。このアップデートキャッシュの第2のコンポーネントは、すべてのLEAFアップデートのストレージも含んでいる。以下でさらに詳細に説明するように、このアップデートキャッシュに記憶されるアップデートが、メタデータサーバ123に伝えられこれによって処理されてクライアントコンピューティングデバイス110上でインストレーションのために使用可能な他の関連したアップデートを識別することができる。
ここで図10に戻って、アイテム1051、1055、および1060として示されている同期化要求の細部について次に説明することにする。当業者には理解されるように、この同期化要求は、アップデートを要求するいくつかの異なるデバイス、プロセス、アプリケーション、ユーザ起動されたコマンドのうちの1つによって起動することができる。この同期化要求は、アップデートのリストを要求するユーザ、クライアントエージェントが起動する自動アップデート、あるいはメタデータサーバ123またはアップデートサービス120からの情報を要求する他の任意のソフトウェアコンポーネントによって起動することができる。一実施形態においては、この同期化要求は、許可ルーチン702から生成された許可サーバクッキーなどの許可サーバクッキーを含んでいる。このサーバクッキーの使用により、このサーバは、そのクライアントが1つまたは複数のターゲットグループのメンバであるかどうかを判定できるようになる。
各同期化要求は、このクライアントのアップデートキャッシュに記憶されたアップデートごとの識別子を含むこともできる。より詳細には、1つまたは複数のアップデートが、アップデートキャッシュに記憶されている場合、この同期化要求は、インストール済みの非LEAFアップデートについての識別子を有する第1のコンポーネントと、LEAFアップデート、失敗したアップデート、インストールされなかった他のアップデートなど、他のすべてのアップデートについての識別子を有する第2のコンポーネントとを含んでいる。このアップデート識別子は、それだけには限定されないが、整数アレイを含めて任意のフォーマットにすることができる。代わりに、このクライアントのアップデートキャッシュにアップデートが記憶されていない場合には、この同期化要求は、アップデート識別子を用いて構成されていない。同期化要求がアップデート識別子を用いて構成されていない場合に、この同期化要求は、このクライアントコンピューティングデバイス110がキャッシュされたアップデートをまったくもたないことを示す指示を提供する。
図10に示すように、第1の同期化要求1051が、クライアントコンピューティングデバイス110からメタデータサーバ123へと伝えられる。本実施例においては、これがこの方法の最初の実行であることを考えれば、このクライアントのアップデートキャッシュは、どのようなアップデートも含んでいないことになる。したがって、この第1の同期化要求1051は、キャッシュされたアップデートについての識別子を含んでいない。この同期化要求を受信することに応答して、ブロック1052に示すように、メタデータサーバ123は、この同期化要求が少なくとも1つのアップデート識別子を含むかどうかを判定する。この同期化要求がアップデート識別子を含んでいないと判定された場合、メタデータサーバ123は、クライアントコンピューティングデバイス110に伝えるための第1のレベルのアップデートを選択することによって応答する。前述のように、第1のレベルのアップデートは、他のアップデートを識別する前提条件をもたないどのようなアップデートも含むことができる。
代わりに、同期化要求が、少なくとも1つのアップデート識別子を含んでいると判定された場合には、メタデータサーバ123は、このサーバの記憶されたアップデートの前提条件を検査してこのクライアントに配信するための追加のアップデートを選択する。一実施形態においては、メタデータサーバ123は、条件が満たされた前提条件を有するアップデートを選択する。この前提条件の検査において、このサーバは、このクライアント上にインストールされた非LEAFアップデートの識別子を含む同期化要求の第1のコンポーネントのアップデートを使用する。
条件が満たされた前提条件を有するアップデートを選択するのに加えて、このサーバはまた、この同期化要求の第2のコンポーネント中で識別されるアップデートを使用してこの選択されたアップデートにフィルタをかける。より詳細には、この同期化要求の第2のコンポーネント中で識別されるインストールされていないアップデート、LEAFアップデート、および失敗したアップデートを使用して1つまたは複数の選択されたアップデートにフィルタをかける。本発明のこの特徴によって、本発明のシステムおよび方法は、メタデータサーバ123上に記憶されるアップデートの複数回の伝送を回避することができるようになる。
本実施例に戻ると、この第1の同期化要求1051は、アップデート識別子を含んでいないので、このメタデータサーバ123は、クライアントコンピューティングデバイス110に伝えるためのベースレベルのアップデート901を選択する。図9に示すアップデートのサンプルの組を参照すると、このベースレベルのアップデート901は、911、912、913、914および915と呼ばれるアップデートを含んでいる。
ブロック1052の処理において、メタデータサーバ123はまた、この同期化要求1051に含まれる許可サーバクッキーを検査して、クライアントコンピューティングデバイス110に関連するターゲットグループを識別する。メタデータサーバ123はまた、ブロック1052のプロセスで選択されたこのアップデートのターゲットグループも検査する。次いで、ブロック1052のこのプロセスは、この受信済みの許可サーバクッキー中で識別されるターゲットグループに関連していないすべての選択されたアップデートをフィルタで取り除く。本実施例においては、選択されたアップデート911、912、913、914および915のすべてが、PIDターゲットグループおよびオールコンピュータターゲットグループに関連するので、これらの選択されたアップデートのすべてがクライアントコンピューティングデバイス110に対して送信される。
次いでメタデータサーバ123は、同期化応答1053中でこの選択されたアップデートをクライアントコンピューティングデバイス110に伝える。一般的に、各同期化応答は、このサーバ120が送信する各アップデートの命令コンポーネントを含んでいる。したがって、本実施例においては、第1の同期化応答1053は、911、912、913、914および915と呼ばれるこれらのアップデートについての命令コンポーネントを含んでいる。一実施形態においては、各同期化応答は、各アップデートの局所的データコンポーネントまたはデータコンポーネントを含んでいない。
次に、ブロック1054に示すように、クライアントコンピューティングデバイス110は、各受信済みのアップデートの命令コンポーネントを処理してこの適用規則で定義される条件を満たすことができるかどうかを判定する。再度図9を参照すると、このクライアントコンピューティングデバイス110は、受信されたアップデート911〜915の命令コンポーネントを処理する。本発明を例示するために、クライアントコンピューティングデバイス110のオペレーティングシステムは、Windows(登録商標)バージョンXP SP1の英語のインストレーションであることがこの実施例において想定されている。また、クライアントコンピューティングデバイス110は、DellのPCであり、32ビットのX86プロセッサを作動させていることも想定されている。したがって、このサンプルの1組のアップデートの命令コンポーネントの処理においては、このコンピュータが英語のOSを含んでいるので、クライアントコンピューティングデバイス110は、第1のアップデート911中で定義される条件が満たされるはずであると判定するはずである。このオペレーティングシステムがWindows(登録商標)バージョンXP SP1であるので、この第2のアップデート912中で定義される条件も満たされるはずである。クライアントコンピューティングデバイス110が、X86プロセッサを作動させているのでこの第3のアップデート913中で定義される条件も満たされるはずである。クライアントコンピューティングデバイス110がDellのPCであるので第5のアップデート915中で定義される条件も満たされるはずである。その結果、第1のアップデート911、第2のアップデート912、第3のアップデート913、および第5のアップデート915はすべて、このクライアントのアップデートキャッシュの第1のコンポーネントに保存される。クライアントコンピューティングデバイス110は64ビットのX86プロセッサを作動させていないので第4のアップデート914中で定義される条件は、満たされないはずである。したがって、この第4のアップデート914は、失敗したアップデートであると考えられ、このクライアントのアップデートキャッシュの第2のコンポーネントに保存される。
図10に戻ると、ブロック1054の処理において、クライアントコンピューティングデバイス110はまた、後続の同期化要求が必要とされるかどうかを判定する。一実施形態においては、少なくとも1つのこの受信済みのアップデートが、それがLEAFアップデートではないことを示す場合、後続の同期化要求が必要であることが決定される。本実施例においては、受信済みのアップデートのすべてがLEAFアップデートではないので、後続の同期化要求が必要とされることが決定される。したがって、クライアントコンピューティングデバイス110は、後続の同期化要求1055をメタデータサーバ123に伝える。
以上で概要を述べたように、同期化要求は、このクライアントのアップデートキャッシュに記憶されるアップデートごとの識別子を含んでいる。したがって、本実施例において、後続の同期化要求1055は、第1のアップデート911、第2のアップデート912、第3のアップデート913、および第5のアップデート915が、このクライアント上にインストールされていることを示す第1のデータコンポーネントを含んでいる。さらに、後続の同期化要求1055は、第4のアップデート914が、このクライアント上に正常にインストールされていないことを示す第2のデータコンポーネントを含んでいる。
後続の同期化要求1055を受信することに応答して、以上で概要を述べたように、メタデータサーバ123は、後続の同期化要求1055が、少なくとも1つのアップデート識別子を含むかどうかを判定する。後続の同期化要求が少なくとも1つのアップデート識別子を含むと判定された場合、メタデータサーバ123はすべての記憶されているアップデートの前提条件を検査してこのクライアントに配信するための追加のアップデートを選択する。
再度本実施例を参照すると、ブロック1056の処理において、その前提条件が満たされるので、メタデータサーバ123は、第6のアップデート921を選択するはずである。より詳細には、図9に示すように、第1のアップデート911、第2のアップデート912、および第3のアップデート913のインストレーションを必要とするその前提条件が満たされるので、第6のアップデート921が、クライアントコンピューティングデバイス110に伝えるために選択される。第7のアップデート922および第8のアップデート931は、これらの前提条件が満たされないので、このクライアントに伝えるために選択されないはずである。より詳細には、この同期化要求1055は、第7のアップデート922についての前提条件である、第4のアップデート914についての識別子を含んでいない。さらに、同期化要求1055は、第8のアップデート931についての前提条件である第6のアップデート921についての識別子を含んでいない。
図10に戻ると、同期化サブルーチン1050は、後続の応答1057において選択されたアップデートをメタデータサーバ123からクライアントコンピューティングデバイス110へと伝えることによって継続される。再度本実施例を参照すると、この後続の応答1057は、第6のアップデート921に関連した情報を含むはずであり、これは後続の応答1057においてクライアント110に伝えられる。
後続の応答1057を受信すると、クライアントコンピューティングデバイス110は、後続の応答1057の命令コンポーネントを処理する。ブロック1054のプロセスと同様に、クライアントコンピューティングデバイス110は、各受信されたアップデートの命令コンポーネントを処理して、この適用規則中で定義される条件が満たされるかどうかを判定する。本実施例においては、XP PATCH1がこのクライアントコンピューティングデバイス中でインストールされると想定する場合に、第6のアップデート921は、インストールすべきと考えられ、このアップデートは、クライアントコンピューティングデバイス110のこのアップデートキャッシュに書き込まれる。この第6のアップデート921がLEAFアップデートではないので、クライアントコンピューティングデバイス110は、このクライアントのアップデートキャッシュの第1および第2のコンポーネントに記憶されるすべてのアップデートを含む別の同期化要求1060を送信する。この同期化要求1060も、許可サーバクッキーを含んでいる。
本実施例においては、メタデータサーバ123の前述の処理を使用することによって、この同期化要求1060は、ブロック1061において処理され、ここでは、このサーバは、第8のアップデート731を選択する。この同期化要求1060は、第5および第6のアップデート915および921がクライアントコンピューティングデバイス110中にインストールされることを示すので、この第8のアップデート931が選択される。この第8のアップデート931は、この許可サーバクッキー中で識別される同じターゲットグループに関連することを想定すると、第8のアップデート931の命令コンポーネントが、別の応答1062中においてクライアントコンピューティングデバイス110に対して伝えられる。次いで、第8のアップデート931が、ブロック1054および1059のプロセスと同様にしてブロック1063において処理される。この応答1062の受信済みのアップデートがすべて、LEAFアップデートであるので、後続の同期化要求が、メタデータサーバ123に対して返信されない。
クライアントコンピューティングデバイス110において、この受信済みのアップデートのすべてがLEAFアップデートであると判定された後に、またはアップデートが応答1062中で受信されない場合には、同期化サブルーチン1050は、クライアントコンピューティングデバイス110からメタデータサーバ123へとドライバ同期化要求1064を伝える。当業者には理解されるように、このドライバ同期化要求1064は、クライアントコンピューティングデバイス110中にインストールされるハードウェアをすべて記述する情報と、このインストール済みのソフトウェアを記述する情報を含むことができる。以前のソフトウェア同期化要求(1051、1055、および1060)と同様に、このドライバ同期化要求1064は、このインストール済みのアップデートをサーバに対して伝えることができる。さらに、このクライアント上に現在キャッシュされているすべてのドライバアップデートが、もしある場合には、このサーバに対して伝えられる。
このドライバ同期化要求1064を受信することに応答して、メタデータサーバ123は、このクライアント上にまだキャッシュされていない、クライアントコンピューティングデバイス110に適用されるすべてのドライバアップデートを送信することによって応答する。その前提条件および条件が満たされる場合には、ドライバアップデートは、応答1065においてクライアントコンピューティングデバイス110に対して送信される。このドライバアップデートを伝える応答1065は、各アップデートの命令コンポーネントを伝えることが好ましい。次いでこのドライバアップデートは、このクライアントコンピューティングデバイスのアップデートキャッシュに書き込まれる。
このドライバアップデートを含むこの応答1065を受信した後に、この同期化サブルーチン1050は、この受信済みのソフトウェアアップデートおよびハードウェアアップデートのそれぞれの局所的データを求める要求1066を送信する。以上で概要を述べたように、各アップデートの局所的データコンポーネントは、このアップデートを記述する一般的な情報を含んでいる。例えば、この局所的データコンポーネントは、このアップデートの特徴および利点を記述する情報を含むことができる。この局所的データコンポーネントはまた、このアップデートのインストレーションプロシージャのテキスト記述を含むこともできる。さらに、この局所的データコンポーネントは、このアップデートに関連した他の任意のデータまたは情報を含むこともできる。
したがって、この受信済みのソフトウェアアップデートおよびハードウェアアップデートのそれぞれのこの局所的データを求める要求1066を受信すると、メタデータサーバ123は、このクライアントのこのアップデートキャッシュに保存されたすべてのこの受信済みのソフトウェアアップデートおよびハードウェアアップデートについてのすべての局所的データを送信することによって応答する。受信した後に、この局所的データをソフトウェアアプリケーションによって処理して、これらのアップデートのうちのどれをインストールする必要があるかを決定することができる。代わりに、この受信済みの局所的データをユーザに対して表示して、このクライアントコンピューティングデバイス110にとって使用可能なすべてのアップデートについてそのユーザに通知することができる。一実施形態においては、この受信済みの局所的データは、ウェブページ上に表示することが可能である。本実施例においては、局所的データは、第6および第8のアップデート921および931についてこのクライアントが受信することができる。局所的データがベースアップデート911、912、913、および915に記憶されている場合には、これらのアップデートについてのこの局所的データも、このクライアントは受信するはずである。
図11は、このクライアントにとって使用可能なこれらのアップデートに関連する局所的データの一実施例を表示するウェブページ1100の一実施例を示している。図では、ウェブページ1100は、あるアップデートの第1の詳細な記述1105と、別のアップデートの第2の詳細な記述1106とを含んでいる。また図に示すように、各アップデートは、それぞれこれらのアップデートのユーザ選択を受け取るための選択メカニズム1103および1104に関連している。また図に示すように、ウェブページ1100は、ユーザが、メタデータサーバ123やダウンロードサーバ124などのサーバに対する、アップデートの選択の通信を制御できるようにする制御ボタン1101を用いて構成されている。
本実施例においては、メタデータサーバ123の前述の処理を使用することによって、この同期化要求1060は、ブロック1061において処理され、ここでは、このサーバは、第8のアップデート931を選択する。この同期化要求1060は、第5および第6のアップデート915および921がクライアントコンピューティングデバイス110中にインストールされることを示すので、この第8のアップデート931が選択される。この第8のアップデート931は、この許可サーバクッキー中で識別される同じターゲットグループに関連することを想定すると、第8のアップデート931の命令コンポーネントが、別の応答1062中においてクライアントコンピューティングデバイス110に対して伝えられる。次いで、第8のアップデート931が、ブロック1054および1059のプロセスと同様にしてブロック1063において処理される。この応答1062の受信済みのアップデートがすべて、LEAFアップデートであるので、後続の同期化要求が、メタデータサーバ123に対して返信されない。
クライアントコンピューティングデバイス110はまた、各アップデートの局所的データを検査して、特定のアップデートが、排他的インストレーションを必要とするかどうか、すなわち別のアップデートのインストレーションファイルと同時にはインストールすることができないインストレーションファイルを有するアップデートであるかどうかを判定することができる。かかる特徴は、局所的データ中に、または特定のアップデートの他のコンポーネント中に、この特定のアップデートが排他的インストレーションを必要とすることを示すテキストを見つけることによって実施することができる。クライアントコンピューティングデバイス110が、かかるアップデートを検出する場合には、このクライアントは、排他的インストレーションを必要とするアップデートの記述を有する、図11に示すテキストメッセージ1122などの視覚インジケータを表示する。
図7に戻ると、このソフトウェアアップデートルーチン700は、ブロック706で継続され、ここで、クライアントコンピューティングデバイス110は、これらのアップデートの選択を受け取る。以上で指摘したように、制御ボタン1101の動作に応答して、1つまたは複数のアップデートの選択をメタデータサーバ123またはダウンロードサーバ124が取得することが可能である。1つまたは複数のアップデートの選択を受け取った後に、このソフトウェアアップデートルーチン700は、ブロック708で継続され、ここでこの選択されたソフトウェアアップデートが処理される。
本発明のさらに他の態様によれば、ソフトウェアアップデートサービス120は、このソフトウェアアップデートサービスとクライアントコンピューティングデバイス110の間で情報を選択し伝送する方法を提供することができる。図12Aおよび12Bは、本発明による、要求されたソフトウェアを検索しインストールするための、クライアントコンピューティングデバイス110によって実施されるソフトウェアアップデート処理サブルーチン1200を示している。前述のように、このソフトウェアアップデート処理サブルーチン1200は、ソフトウェアアップデートの選択が生成され受信された後に実施することができる。図12Aを参照すると、ブロック1202において、アップデート管理コンポーネント111が、アップデートエージェント118をインスタンス化する。本発明の例示の一実施形態において、このアップデートエージェント118は、要求されたソフトウェアアップデートを完了するため、このアップデートエージェントのインストレーションコンポーネントの要求されたバージョンを生成するため、既存のファイルをデルタパッチとマージすることによってアップデートされたファイルを生成するため、および/またはアップデートされたファイルのインストレーションを開始するために、どのようなソフトウェアアップデート情報が必要とされるかを決定するための専用ソフトウェアコンポーネントである。アップデートエージェント118が、すでにインスタンス化されている場合には、ブロック1202は、省略することができる。
ブロック1204において、アップデートエージェント118は、アップデートサービス120からソフトウェアアップデート情報を取得する。本発明の例示の一実施形態においては、アップデートサービス120が送信するこのソフトウェアアップデート情報は、このアップデートエージェントが利用することができる様々なデータを含む、自己展開ファイルなどのパッケージの形態である。一態様によれば、このパッケージは、特定のソフトウェアアップデートに対応するすべてのファイルのリストを含むことが可能である。さらに、このパッケージは、アップデートすべき特定のバージョンのファイルをアップデートサービス120上のそのパッチストレージファイルに記憶される対応するソフトウェアアップデートデルタパッチに対してマッピングするパッチストレージマニフェストの少なくとも一部分のコピーを含むことが可能である。このパッケージはまた、このインストレーションを完了するために必要とされるインストレーションコンポーネントのバージョンの識別を含むことが可能な、アップデートすべきファイルごとのインストレーション情報を含むことも可能である。さらにこのパッケージはまた、アップデートエージェント118についてのインストレーションコンポーネントまたはクライアントコンピューティングデバイス110上にすでに記憶されているインストレーションコンポーネントのバージョンをアップデートするためのデルタパッチを含むことが可能である。さらにまた、このパッケージは、このアップデートエージェントにソフトウェアアップデートが正常であったかどうかを判定できるようにする検証情報を含むことが可能である。例えば、この検証情報は、比較するためのアップデートファイルについての基準ハッシュ値を含むことが可能である。このアップデートエージェント118は、パッケージのその内容を検証することもできる。
判断ブロック1206において、テストを実施してアップデートエージェント118がアップデートを実施するためにこのインストレーションコンポーネントのバージョンをアップデートする必要があるかどうかを判定する。この自己展開ファイル中のインストレーションコンポーネントの完全なコピーの送信により、ソフトウェアアップデートごとの、アップデートサービス120が送信するデータ量を増大させる可能性があることが当業者には理解されよう。したがって本発明の例示の一実施形態においては、インストレーションコンポーネントのベースラインバージョンは、このクライアントコンピューティングデバイスに記憶し、インストレーションコンポーネントデルタパッチを介してこの現行のソフトウェアアップデートの要件について特にアップデートすることができる。したがって、この自己展開ファイル中のこのインストレーション情報は、クライアントコンピューティングデバイス110上において、含められた任意のインストレーションコンポーネントアップデートをこのインストレーションコンポーネントのこのベースラインバージョンとマージする必要があるか否かをアップデートエージェント118に指示する。アップデートが必要とされる場合、図13に関して以下でさらに非常に詳細に説明するように、ブロック1208において、アップデートエージェント118は、このベースラインインストレーションコンポーネント(baseline installation component)をアップデートする。
このアップデートエージェントがこのインストレーションコンポーネントをアップデートした後に、またはこのインストレーションコンポーネントが、アップデートを必要としない場合には、ブロック1210において、アップデートエージェント118は、クライアントコンピューティングデバイス110上にインストールされたファイル、およびこの特定のバージョンのファイルのインベントリを実施する。本発明の例示の一実施形態において、アップデートエージェント118は、この選択されたアップデートに対応するものとしてこのパッケージ中で識別されたすべてのファイルについてクライアントコンピューティングデバイス110のファイルシステムに照会することができる。代わりに、アップデートエージェント118が、最近インベントリを実施したことがある場合には、このキャッシュされたバージョンのインベントリを利用することができる。ブロック1212において、アップデートエージェント118は、この要求されたアップデートを完了するためにどのようなソフトウェアアップデート情報が必要とされるかを識別する。本発明の例示の一実施形態において、そのパッチストレージマニフェストは、必要とされるデルタパッチに対するインストール済みのファイルのバージョンのマッピングを含んでいる。したがって、デルタパッチングが利用可能な場合、アップデートエージェント118は、このマッピングを利用してこのパッチストレージファイル内の特定のデルタパッチおよびそのオフセットロケーションを識別することになる。代わりに、デルタパッチが利用可能でなく実施できない場合には、アップデートエージェント118は、ダウンロードするために全体のファイルを識別することができる。

次に図12Bを参照すると、ブロック1214において、このアップデートエージェント(update date agent)は、識別されたソフトウェアアップデート情報を求める要求を送信する。本発明の例示の一実施形態において、アップデートエージェント118は、このアップデートサービス120のダウンロードサーバ124に対してこのパッチストレージファイルから必要とされる特定の範囲のパッチを示すことによって特定のデルタパッチを求める要求を送信することができる。前述のように、このパッチストレージファイルは、各デルタパッチがそのパッチストレージファイルに伴うそのロケーションによって識別される多数の適用可能デルタパッチを含んでいる。このパッチストレージファイルが一部の実施形態ではかなり大きいこともあるので、アップデートエージェント118は、このパッチストレージマニフェストから指示されるように、このパッチストレージファイル中の特定のロケーションからのデータだけしか求めない要求を利用することができる。本発明の代替実施形態においては、アップデートエージェント118は、アップデートファイルの全体コピーおよび/またはこのパッチストレージファイルの完全コピーを要求することができる。
本発明の代替実施形態においては、アップデートサービス120に排他的に関連づけることができない別のダウンロードサーバが、このアップデートエージェント118の要求を処理することができる。この実施形態においては、この要求パッチストレージファイルは、全部または一部分をネットワーク上で任意の数の追加のダウンロードサーバに対して伝送することができる。この追加のダウンロードサーバは、プライベートネットワーク上でクライアントをアップデートするために利用されるプライベートネットワークの一部分とすることができる。さらに、この追加のダウンロードサーバは、パブリックネットワークの一部分とすることができる。プライベートネットワーク環境においては、これらのダウンロードサーバは、クライアント要求を処理するためのパッチストレージファイルの完全コピーを取得することができる。代わりに、ダウンロードサーバは、他のクライアントからの以前のデータ要求を処理する際にこのパッチストレージファイルの一部分をキャッシュすることもでき、このキャッシュデータを利用してこのダウンロードを履行することができる。したがって、この追加のダウンロードサーバは、アップデートサービス120のダウンロードサーバ124上における通信歪み(communication strain)を低減することが可能である。
ブロック1216において、アップデートエージェント118は、この要求されたアップデート情報を受信する。本発明の例示の一実施形態においては、この要求されたアップデート情報は、2つのアプローチで伝送することができる。手動アップデートと呼ばれる第1のアプローチでは、このアップデート要求は、直接HTTPデータ配信応答(direct HTTP data delivery response)を求める要求と共にアップデートサービス120に対して送信される。このアプローチにおいては、アップデートサービス120は、使用可能な全帯域幅のすべてを利用してこの要求されたデータをアップデートエージェント118に対して送信することができる。自動アップデートと呼ばれる第2のアプローチでは、このアップデート要求は、間接HTTPデータ配信応答(indirect HTTP data delivery response)を求める要求と共にアップデートサービス120に対して送信される。この応答においては、アップデートサービス120は、この要求されたデータをバックグラウンドプロセス(background process)として送信する。このバックグラウンドプロセスは、使用可能な帯域幅の最小量を利用するようにして実施することができる。さらに、このバックグラウンドプロセスは、このダウンロードプロセス中に中断し、次に利用可能な時に再開することができる。バックグラウンドプロセスを介して要求されたデータを伝送するためのシステムおよび方法についての説明は、参照により本明細書中に組み込まれている、2000年2月16日に出願の「System and Method for Transferring Data Over a Network」という名称の同一出願人による同時係属の米国特許出願第09/505,735号明細書中に説明されている。フォアグラウンドまたはバックグラウンドのデータ配信は、この選択されたソフトウェアアップデートの優先順位を必ずしも反映したものではなく、代わりにこのアップデート情報を取得するためにどのようにして帯域幅が割り付けられるかを反映したものであることが当業者には理解されよう。
要求された情報をこのアップデートサービスから受信した後に、ブロック1218において、アップデートエージェント118は、このデルタパッチをこの対応するインストール済みのファイルとマージする。本発明の例示の一実施形態においては、アップデートエージェント118は、このインストール済みのファイルの元のバージョンをキャッシュして、この選択されたファイルがこのダウンロードおよびマージングプロセス中に変化しないようにする。さらに、このインストール済みのファイルのキャッシュされた元のバージョンを使用してこの選択されたアップデートをアンインストール(uninstall)することができる。
判断ブロック1220において、テストを実施してこのアップデートされたファイルが有効であるかどうかを判定する。本発明の例示の一実施形態においては、アップデートエージェント118は、ハッシングアルゴリズムを利用して、アップデート情報パッケージから得られ、有効なファイルアップデートに対応する基準ハッシュ値を現在の修正されたファイルからのハッシュと比較することができる。これらのハッシュがマッチングしない場合、現行の修正ファイルは有効ではない。いくつかの代替の妥当性検査アルゴリズムのうち任意の1つを利用することもできることが当業者には理解されよう。このアップデートファイルが有効でない場合には、このサブルーチン1200はブロック1214に戻り、ここでこのアップデートエージェントは、アップデート情報を再度要求することができる。代わりに、アップデートエージェント118が、このアップデートファイルを数回にわたって生成しようと試みてもうまくいかない場合には、このアップデートエージェントは、いくつかのフォールバックプロシージャ(fallback procedure)の1つを実施することができる。本発明の一実施形態において、このアップデートエージェント118は、このパッチストレージファイルに記憶されこのパッチストレージマニフェストから識別されたアップデートファイルの完全コピーをアップデートサービス120から要求することができる。本発明の他の実施形態においては、アップデートエージェント118は、アップデートサービス120から自己完結型のファイル中のこのアップデートファイルのコピーを要求することができる。本発明のさらに他の実施形態においてサブルーチン1200は、その他の場合には失敗することもある。
この選択されたファイルが有効になった後に、判断ブロック1222において、テストを実施して追加のダウンロードが何か必要とされるかどうかを判定する。本発明の例示の一実施形態においては、サブルーチン1200は、以前に選択されたダウンロードの終了後に追加のダウンロードがあるかについて絶えずチェックする反復ループに入る。このダウンロード中にファイルの状態が変化する場合、アップデートエージェント118は、この新しい状態変化について追加のダウンロードを要求し続けるはずである。追加のダウンロードが必要とされる場合には、ブロック1224において、アップデートエージェント118は、別のインベントリを実施し、すべての適用可能なデルタパッチを識別する。次いでこのサブルーチン1200はブロック1214へと戻る。
すべてのこの要求されたアップデートのダウンロードが完了した後に、判断ブロック1224において、テストを実施して、このクライアントマシンの状態が変化しているかどうかを判定する。本発明の例示の一実施形態においては、アップデート情報のダウンロードおよびマージングと、このアップデートされたファイルの実際のインストレーションの間で時間が経過してしまうこともある。したがってこのアップデートファイルをインストールするのに先立ってこのアップデートエージェントは、このクライアントコンピューティングデバイス状態が変化しているかどうかを判定する。この状態が変化している場合には、このファイルアップデートは有効でないこともあり、このアップデートはブロック1226において失敗する。代わりに、状態の変化が起こっていなければ、アップデートエージェント118は、ブロック1228においてこのアップデートされたファイルをインストールし、サブルーチン1200は、ブロック1230において戻る。
次に図13を参照して、ブロック1208(図12A)に対応するベースラインインストレーションコンポーネントをアップデートするための、クライアントコンピューティングデバイス110によって実施されるサブルーチン1300について説明することにする。判断ブロック1302において、テストを実施して新しいベースラインインストレーションコンポーネントが、アップデートサービス120からアップデートエージェント118に伝送される自己展開ファイル中に含まれるかどうかを判定する。本発明の例示の一実施形態において、このベースラインインストーラ(baseline installer)をアップデートするために必要とされるデルタパッチが、アップデートされたインストレーションコンポーネントの伝送とサイズが同等である場合、新しいベースラインインストレーションコンポーネントが伝送されることになる。アップデートされたインストレーションコンポーネントが含まれる場合には、ブロック1304において、このアップデートエージェントは、このアップデートされたベースラインインストレーションコンポーネントを新しいインストレーションコンポーネントとしてインストールする。さらに、この新しいアップデートされたインストレーションコンポーネントは、クライアントコンピューティングデバイス110のメモリに保存されて追加のアップデートについてのベースラインインストーラとしての役割を果たすことができる。ブロック1306においてこのサブルーチンは戻る。
アップデートされたベースラインインストレーションコンポーネントが、この自己展開ファイル中に含まれていない場合には、ブロック1308においてアップデートエージェント118は、この自己展開ファイルからベースラインインストレーションコンポーネントデルタパッチを取得する。本発明の例示の一実施形態において、このベースラインインストレーションコンポーネントデルタパッチは、このベースラインインストレーションコンポーネントとマージされてアップデートされたベースラインインストレーションコンポーネントを生成することができるソフトウェアコードに対応する。したがって、ブロック1310において、このアップデートエージェントは、このベースラインインストレーションコンポーネントデルタパッチをこのベースラインインストレーションコンポーネントとマージする。ブロック1312において、次いでアップデートエージェント118は、このアップデートされたベースラインインストレーションコンポーネントを現在のインストレーションコンポーネントとして指定する。本発明の例示の一実施形態において、このインストレーションが完了した後にはこのアップデートされたインストレーションコンポーネントは、保存されないことになる。この実施形態によれば、アップデートエージェント118は、クライアントコンピューティングデバイス110のメモリ中に限られた数のベースラインインストレーションコンポーネントしか保持しない。したがって、このアップデートエージェントは、インストレーションごとに、一時的なアップデートされたインストレーションコンポーネントを生成する。各クライアントコンピューティングデバイス110は、限られた数のベースラインインストレーションコンポーネントにしか対応することができないので、アップデートサービス120には、クライアントコンピューティングデバイスごとに1つのベースラインインストレーションコンポーネントデルタパッチを伝送する必要があるだけである。ブロック1314において、このサブルーチン1300は、戻る。
本発明の好ましい実施形態について示し説明してきたが、本発明の趣旨および範囲を逸脱することなく様々な変更をここで行うことができることが理解されよう。例えば、本明細書中で説明した例示の実施例は、ソフトウェアアップデートに適用されるが、本発明の範囲は、ソフトウェアアップデートに関連した情報の配信および通信以外の他の使用を含んでいる。したがって、特定の主題がこの開示中において明確に除外されない限り、本発明の範囲が、ソフトウェアアップデート以外の、またはソフトウェアアップデートに追加の任意タイプのデータの配信および通信に適用されることを理解されたい。
本発明による、クライアントコンピュータ、およびアップデートソフトウェアを提供するアップデートサービスを含むソフトウェアアップデートシステムを示すブロック図である。 本発明による、アップデートサービスを用いたクライアントコンピューティングデバイスの認証を示す、図1のソフトウェアアップデートシステムのブロック図である。 本発明による、クライアントコンピューティングデバイスとアップデートサービスの間の使用可能なアップデートの同期化を示す、図1のソフトウェアアップデートシステムのブロック図である。 本発明による、アップデートサービスからクライアントコンピューティングデバイスへのソフトウェアアップデート情報の伝送を示す、図1のソフトウェアアップデートシステムのブロック図である。 本発明による、クライアントコンピューティングデバイスによるアップデート情報の処理および選択を示す、図1のソフトウェアアップデートシステムのブロック図である。 本発明による、クライアントコンピューティングデバイスによるデルタパッチのマージング、およびアップデートファイルのインストレーションを示す、図1のソフトウェアアップデートシステムのブロック図である。 本発明による、クライアントコンピューティングデバイス上におけるインストレーションのために使用可能なソフトウェアアップデートを識別するための、クライアントコンピューティングデバイスおよびアップデートサービスによって実施されるソフトウェアアップデートルーチンを示す流れ図である。 本発明による、アップデートサービス上に記憶されるアップデートに対する選択的なアクセスを提供するための許可ルーチンのプロトコル図である。 本発明による、許可ルーチンを示す実施例の1組のソフトウェアアップデートのブロック図である。 本発明による、選択グループのソフトウェアアップデートをソフトウェアアップデートサービスからクライアントコンピューティングデバイスへと伝えるための同期化ルーチンのプロトコル図である。 本発明による、個別のクライアントコンピューティングデバイスにとって使用可能なソフトウェアアップデートのリストを表示するためのグラフィックユーザインターフェースの例示のセクションを示すブロック図である。 本発明による、要求されたソフトウェアを検索しインストールするためのクライアントコンピューティングデバイス110によって実施されるソフトウェアアップデート処理サブルーチン1200の一部分を示す図である。 本発明による、要求されたソフトウェアを検索しインストールするためのクライアントコンピューティングデバイス110によって実施されるソフトウェアアップデート処理サブルーチン1200の一部分を示す図である。 本発明による、ベースラインインストレーションコンポーネントをアップデートするための、クライアントコンピューティングデバイスによって実施されるサブルーチンを示す流れ図である。

Claims (10)

  1. クライアントコンピューティングデバイス上にインストール済みのファイルをアップデートするための方法であって、前記クライアントコンピューティングデバイスは、サーバコンピューティングデバイスとネットワークを介して通信し、前記方法は、前記クライアントコンピューティングデバイスが、
    前記クライアントコンピューティングデバイス上にインストール済みのファイルをアップデートするために使用可能な1つまたは複数のソフトウェアアップデートのうち、特定のソフトウェアアップデートを実施することを選択するユーザ選択を受信するステップと、
    前記サーバコンピューティングデバイスから、前記特定のソフトウェアアップデートを実施するために使用可能な複数のデルタパッチを識別するパッケージを取得するステップであって、前記パッケージは、前記複数のデルタパッチの各々について、各デルタパッチと、該デルタパッチの適用によりアップデートされるべきファイルとをマッピングしている、ステップと、
    前記クライアントコンピューティングデバイス上にインストール済みのファイルのインベントリを取得するステップと、
    前記特定のソフトウェアアップデートを実施することにより前記インストール済みのファイルのバージョンをアップデートするために前記インストール済みのファイルに適用すべきデルタパッチを、前記複数のデルタパッチから選択するステップであって、前記適用すべきデルタパッチは、前記インベントリによって識別される前記インストール済みのファイルと、前記パッケージ内において前記複数のデルタパッチの各々にマッピングされた前記ファイルとの比較に基づいて選択される、ステップと、
    前記適用すべきデルタパッチを求める要求を前記サーバコンピューティングデバイスに送信するステップと
    前記適用すべきデルタパッチを前記サーバコンピューティングデバイスから取得するステップと、
    前記インストール済みのファイルを、前記クライアントコンピューティングデバイス上にキャッシュするステップと、
    前記適用すべきデルタパッチをそれぞれ、前記インストール済みのファイルのうち対応するインストール済みのファイルとマージしてアップデートされたファイルを生成するステップと、
    前記アップデートされたファイルをインストールするのに先立って、前記パッケージから取得され、有効なファイルアップデートに対応する基準ハッシュ値と、前記アップデートされたファイルからのハッシュ値を比較することによって、前記アップデートされたファイルが有効であるかどうかを判定するステップと、
    前記アップデートされたファイルが有効でないと判定された場合、前記クライアントコンピューティングデバイス上において、前記アップデートされたファイルを前記キャッシュされたインストール済みのファイルに復元するステップと、
    前記アップデートされたファイルが有効であると判定された場合、前記アップデートされたファイルを前記クライアントコンピューティングデバイスにインストールするステップと
    を含むことを特徴とする方法。
  2. 前記サーバコンピューティングデバイスは、前記特定のソフトウェアアップデートを実施するための前記複数のデルタパッチを含むパッチストレージファイルを有し、前記パッケージは、前記適用すべきデルタパッチの各々について前記パッチストレージファイル内におけるストレージロケーションを識別するパッチストレージマニフェストを含むことを特徴とする請求項1に記載の方法。
  3. 前記適用すべきデルタパッチを求める要求を前記サーバコンピューティングデバイスに送信するステップは、前記クライアントコンピューティングデバイスが、前記パッチストレージマニフェストにより前記適用すべきデルタパッチの各々の前記ストレージロケーションを識別して、前記パッチストレージファイル内の前記ストレージロケーションにある特定のデルタパッチを求める要求を前記サーバコンピューティングデバイスに送信するステップを含むことを特徴とする請求項2に記載の方法。
  4. 前記適用すべきデルタパッチを求める要求を前記サーバコンピューティングデバイスに送信するステップは、前記クライアントコンピューティングデバイスが、前記パッチストレージマニフェストにより前記適用すべきデルタパッチの各々の前記ストレージロケーションを識別して、前記パッチストレージファイル内の前記ストレージロケーションに各々ある特定のデルタパッチのセットを求める要求を前記サーバコンピューティングデバイスに送信するステップを含むことを特徴とする請求項2に記載の方法。
  5. 前記適用すべきデルタパッチを求める要求を前記サーバコンピューティングデバイスに送信するステップは、該要求に応答して前記適用すべきデルタパッチが前記サーバコンピューティングデバイスから前記ネットワーク上の使用可能な全帯域幅の全てを使用して送信されることを求める要求とともに、前記適用すべきデルタパッチを求める要求を前記サーバコンピューティングデバイスに送信するステップを含むことを特徴とする請求項1に記載の方法。
  6. 前記適用すべきデルタパッチを求める要求を前記サーバコンピューティングデバイスに送信するステップは、該要求に応答して前記適用すべきデルタパッチが前記サーバコンピューティングデバイスから前記ネットワーク上の使用可能な帯域幅の最小帯域幅を使用して送信されることを求める要求とともに、前記適用すべきデルタパッチを求める要求を前記サーバコンピューティングデバイスに送信するステップを含むことを特徴とする請求項1に記載の方法。
  7. 前記クライアントコンピューティングデバイス上にインストール済みのファイルのインベントリを取得するステップは、前記クライアントコンピューティングデバイス上に以前に取得されたインベントリがキャッシュされているとき、該キャッシュされたインベントリを取得することを含むことを特徴とする請求項1に記載の方法。
  8. 前記パッケージは、インストレーションコンポーネントアップデートを含み、前記クライアントコンピューティングデバイス上のインストレーションコンポーネントを前記インストレーションコンポーネントアップデートからアップデートするステップをさらに含むことを特徴とする請求項1に記載の方法。
  9. 前記インストレーションコンポーネントアップデートは、インストレーションコンポーネントデルタパッチであることを特徴とする請求項に記載の方法。
  10. クライアントコンピューティングデバイスに、該クライアントコンピューティングデバイス上にインストール済みのファイルをアップデートするための方法を実行させるためのコンピュータ実行可能命令を記録したコンピュータ読取可能記録媒体であって、前記クライアントコンピューティングデバイスは、サーバコンピューティングデバイスとネットワークを介して通信し、前記方法は、
    前記クライアントコンピューティングデバイス上にインストール済みのファイルをアップデートするために使用可能な1つまたは複数のソフトウェアアップデートのうち、特定のソフトウェアアップデートを実施することを選択するユーザ選択を受信するステップと、
    前記サーバコンピューティングデバイスから、前記特定のソフトウェアアップデートを実施するための複数のデルタパッチを識別するパッケージを取得するステップであって、前記パッケージは、前記複数のデルタパッチの各々について、各デルタパッチと、該デルタパッチの適用によりアップデートされるファイルとをマッピングしている、ステップと、
    前記クライアントコンピューティングデバイス上にインストール済みのファイルのインベントリを取得するステップと、
    前記特定のソフトウェアアップデートを実施することにより前記インストール済みのファイルのバージョンをアップデートするために前記インストール済みのファイルに適用すべきデルタパッチを、前記複数のデルタパッチから選択するステップであって、前記適用すべきデルタパッチは、前記インベントリによって識別される前記インストール済みのファイルと、前記パッケージにおいて前記複数のデルタパッチの各々にマッピングされた前記ファイルとの比較に基づいて選択される、ステップと、
    前記適用すべきデルタパッチを求める要求を前記サーバコンピューティングデバイスに送信するステップと
    前記適用すべきデルタパッチを前記サーバコンピューティングデバイスから取得するステップと、
    前記インストール済みのファイルを、前記クライアントコンピューティングデバイス上にキャッシュするステップと、
    前記適用すべきデルタパッチをそれぞれ、前記インストール済みのファイルのうち対応するインストール済みのファイルとマージしてアップデートされたファイルを生成するステップと、
    前記アップデートされたファイルをインストールするのに先立って、前記パッケージから取得され、有効なファイルアップデートに対応する基準ハッシュ値と、前記アップデートされたファイルからのハッシュ値を比較することによって、前記アップデートされたファイルが有効であるかどうかを判定するステップと、
    前記アップデートされたファイルが有効でないと判定された場合、前記クライアントコンピューティングデバイス上において、前記アップデートされたファイルを前記キャッシュされたインストール済みのファイルに復元するステップと、
    前記アップデートされたファイルが有効であると判定された場合、前記アップデートされたファイルを前記クライアントコンピューティングデバイスにインストールするステップと
    を含むことを特徴とするコンピュータ読取可能記録媒体。
JP2006543792A 2003-12-15 2004-07-23 デルタパッチを利用してファイルをアップデートするための方法 Active JP4800968B2 (ja)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US10/737,725 2003-12-15
US10/737,725 US7509636B2 (en) 2003-12-15 2003-12-15 System and method for updating files utilizing delta compression patching
PCT/US2004/023581 WO2005071542A1 (en) 2003-12-15 2004-07-23 System and method for updating files utilizing delta compression patching

Publications (3)

Publication Number Publication Date
JP2007514232A JP2007514232A (ja) 2007-05-31
JP2007514232A5 JP2007514232A5 (ja) 2007-09-20
JP4800968B2 true JP4800968B2 (ja) 2011-10-26

Family

ID=34654195

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2006543792A Active JP4800968B2 (ja) 2003-12-15 2004-07-23 デルタパッチを利用してファイルをアップデートするための方法

Country Status (11)

Country Link
US (1) US7509636B2 (ja)
EP (1) EP1614032B1 (ja)
JP (1) JP4800968B2 (ja)
KR (1) KR101150041B1 (ja)
CN (1) CN1777867B (ja)
AU (1) AU2004279173B2 (ja)
BR (1) BRPI0406403A (ja)
CA (1) CA2501548A1 (ja)
MX (1) MXPA05006614A (ja)
RU (1) RU2367005C2 (ja)
WO (1) WO2005071542A1 (ja)

Families Citing this family (115)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8255361B2 (en) * 2003-01-31 2012-08-28 Oracle America, Inc. Method and system for validating differential computer system update
US7774485B2 (en) 2004-05-21 2010-08-10 Bea Systems, Inc. Dynamic service composition and orchestration
US20060136555A1 (en) * 2004-05-21 2006-06-22 Bea Systems, Inc. Secure service oriented architecture
US20060031431A1 (en) * 2004-05-21 2006-02-09 Bea Systems, Inc. Reliable updating for a service oriented architecture
US8615601B2 (en) * 2004-05-21 2013-12-24 Oracle International Corporation Liquid computing
US7661102B2 (en) * 2004-08-20 2010-02-09 Smith Micro Software, Inc. Method for reducing binary image update package sizes
US7716660B2 (en) * 2004-12-14 2010-05-11 Microsoft Corporation Method and system for downloading updates
US8195952B2 (en) * 2004-12-14 2012-06-05 International Business Machines Corporation System and method of facilitating the identification of a computer on a network
EP1688834A3 (en) * 2005-02-03 2009-01-14 LG Electronics Inc. Video device having software upgrade function using wireless communication and method for controlling the same
US7577879B2 (en) * 2005-06-07 2009-08-18 Microsoft Corporation Patching a mobile computing device software error
US8577761B1 (en) * 2005-06-30 2013-11-05 Oracle America, Inc. System and method for dynamic offering topologies
US20070067512A1 (en) * 2005-09-19 2007-03-22 Smar Research Corporation Method, system and software arrangement for processing a device support file for a field device
US8291093B2 (en) 2005-12-08 2012-10-16 Microsoft Corporation Peer-to-peer remediation
US7716658B2 (en) * 2005-12-09 2010-05-11 Oracle America, Inc. Method and apparatus for optimizing patching of objects containing references
CN100459500C (zh) * 2006-01-18 2009-02-04 腾讯科技(深圳)有限公司 一种客户端软件加载功能扩展文件的方法
CN101361041B (zh) 2006-02-01 2012-03-21 富士通株式会社 对象关系显示装置以及对象关系显示方法
KR100750169B1 (ko) * 2006-03-08 2007-08-21 삼성전자주식회사 델타 파일 생성 방법 및 이를 이용한 소프트웨어 업데이트방법
US20080005732A1 (en) * 2006-05-11 2008-01-03 Coon Robert F Method and System for Integrating Software Update Services with Software Applications
US8667273B1 (en) 2006-05-30 2014-03-04 Leif Olov Billstrom Intelligent file encryption and secure backup system
US8099605B1 (en) 2006-06-05 2012-01-17 InventSec AB Intelligent storage device for backup system
RU2388045C2 (ru) * 2006-06-19 2010-04-27 Самсунг Электроникс Ко., Лтд. Система и способ обновления программы для переносного устройства с поддержкой ота
US7636728B2 (en) * 2006-06-22 2009-12-22 Microsoft Corporation Media difference files for compressed catalog files
KR101426710B1 (ko) * 2006-07-14 2014-09-23 삼성전자주식회사 휴대단말기의 버전정보 갱신 장치 및 방법
US8589341B2 (en) * 2006-12-04 2013-11-19 Sandisk Il Ltd. Incremental transparent file updating
US8527660B2 (en) * 2006-12-22 2013-09-03 Palm, Inc. Data synchronization by communication of modifications
US9563417B2 (en) 2006-12-29 2017-02-07 International Business Machines Corporation Patch management automation tool for UNIX, APARXML
JP4345844B2 (ja) * 2007-05-09 2009-10-14 ソニー株式会社 通信システム、情報処理装置および方法、並びにプログラム
US8762984B2 (en) * 2007-05-31 2014-06-24 Microsoft Corporation Content distribution infrastructure
JP2009087136A (ja) * 2007-10-01 2009-04-23 Nec Corp 障害修復システムおよび障害修復方法
US8434077B2 (en) * 2007-10-18 2013-04-30 International Business Machines Corporation Upgrading virtual resources
US8631397B2 (en) 2008-03-31 2014-01-14 Microsoft Corporation Virtualized application image patching
US20090313352A1 (en) * 2008-06-11 2009-12-17 Christophe Dupont Method and System for Improving the Download of Specific Content
US8312448B2 (en) * 2008-06-24 2012-11-13 Sony Corporation Configuration to order software deployment and management
KR101016916B1 (ko) * 2008-10-30 2011-02-22 한국항공우주산업 주식회사 비행 시뮬레이션 및 테스트를 위한 항공기 임베디드 시스템의 데이터 주입 방법
US8332842B2 (en) * 2008-11-14 2012-12-11 International Business Machines Corporation Application restore points
US8539477B2 (en) 2009-02-24 2013-09-17 Microsoft Corporation Managed environment update selection
US8402452B2 (en) * 2009-04-02 2013-03-19 International Business Machines Corporation Automatically recommending an upgrade approach for a customizable software product
CN101604371B (zh) 2009-07-22 2012-02-08 阿里巴巴集团控股有限公司 插件权限的控制方法及系统
CN101989208A (zh) * 2009-08-04 2011-03-23 鸿富锦精密工业(深圳)有限公司 软件更新方法
JP5478986B2 (ja) * 2009-08-21 2014-04-23 株式会社日立ソリューションズ 情報機器及びプログラム
JP5378119B2 (ja) * 2009-09-01 2013-12-25 富士通エフ・アイ・ピー株式会社 ラッピングファイル更新システム及びラッピングファイル更新方法
US10148433B1 (en) 2009-10-14 2018-12-04 Digitalpersona, Inc. Private key/public key resource protection scheme
US9176898B2 (en) * 2009-11-09 2015-11-03 Bank Of America Corporation Software stack building using logically protected region of computer-readable medium
US9128799B2 (en) * 2009-11-09 2015-09-08 Bank Of America Corporation Programmatic creation of task sequences from manifests
US8584113B2 (en) * 2009-11-09 2013-11-12 Bank Of America Corporation Cross-updating of software between self-service financial transaction machines
US8972974B2 (en) * 2009-11-09 2015-03-03 Bank Of America Corporation Multiple invocation points in software build task sequence
US9122558B2 (en) * 2009-11-09 2015-09-01 Bank Of America Corporation Software updates using delta patching
US8671402B2 (en) * 2009-11-09 2014-03-11 Bank Of America Corporation Network-enhanced control of software updates received via removable computer-readable medium
US20110113226A1 (en) * 2009-11-09 2011-05-12 Bank Of America Corporation Distribution Of Software Updates
US9015136B2 (en) * 2010-01-22 2015-04-21 Microsoft Technology Licensing, Llc Storing temporary state data in separate containers
US20110238572A1 (en) * 2010-03-25 2011-09-29 Bank Of America Corporation Remote Control Of Self-Service Terminal
TW201135594A (en) * 2010-04-08 2011-10-16 Inventec Corp System for updating software using separated modules and method thereof
US9110690B2 (en) * 2010-04-28 2015-08-18 General Electric Company Systems, methods, and apparatus for deploying application code change configurations for multiple target controllers
US8799453B2 (en) 2010-10-20 2014-08-05 Microsoft Corporation Managing networks and machines for an online service
US8417737B2 (en) 2010-10-20 2013-04-09 Microsoft Corporation Online database availability during upgrade
US9075661B2 (en) 2010-10-20 2015-07-07 Microsoft Technology Licensing, Llc Placing objects on hosts using hard and soft constraints
US20120102480A1 (en) * 2010-10-20 2012-04-26 Microsoft Corporation High availability of machines during patching
US8386501B2 (en) 2010-10-20 2013-02-26 Microsoft Corporation Dynamically splitting multi-tenant databases
US8751656B2 (en) 2010-10-20 2014-06-10 Microsoft Corporation Machine manager for deploying and managing machines
US8850550B2 (en) 2010-11-23 2014-09-30 Microsoft Corporation Using cached security tokens in an online service
US9721030B2 (en) 2010-12-09 2017-08-01 Microsoft Technology Licensing, Llc Codeless sharing of spreadsheet objects
US8589363B2 (en) 2011-07-19 2013-11-19 Exagrid Systems, Inc. Systems and methods for managing delta version chains
US8707289B2 (en) 2011-07-20 2014-04-22 Google Inc. Multiple application versions
KR101286378B1 (ko) * 2011-08-18 2013-07-15 웹싱크 주식회사 파일 동기화 방법 및 이를 위한 시스템
US20130232229A1 (en) * 2012-03-02 2013-09-05 Ilya Firman Distribution of Application Files
CN103309768B (zh) 2012-03-16 2015-03-11 腾讯科技(深圳)有限公司 系统文件修复方法和装置
GB201208373D0 (en) 2012-05-14 2012-06-27 Touchtype Ltd Mechanism for synchronising devices,system and method
US9244673B2 (en) 2012-06-08 2016-01-26 Apple Inc. System and method for updating application archive files
US9075693B2 (en) * 2012-06-27 2015-07-07 Google Inc. Methods for updating applications
CN102831204B (zh) * 2012-08-09 2015-09-30 珠海金山网络游戏科技有限公司 一种具备版本控制能力的文件打包格式
US9015654B2 (en) * 2012-08-13 2015-04-21 Bitbar Technologies Oy System for providing test environments for executing and analysing test routines
KR102026637B1 (ko) * 2012-12-20 2019-09-30 엘지전자 주식회사 디스플레이장치 및 이의 제어방법
US9418072B2 (en) * 2013-03-04 2016-08-16 Vmware, Inc. Cross-file differential content synchronization
CN103207902A (zh) * 2013-03-27 2013-07-17 交通银行股份有限公司 一种金融客户端数据更新方法及系统
US8997082B1 (en) * 2013-07-16 2015-03-31 Amazon Technologies, Inc. Differential patch of content
CN104424037B (zh) * 2013-08-29 2018-12-14 中兴通讯股份有限公司 一种动态补丁函数的方法及装置
US9760362B2 (en) 2013-09-26 2017-09-12 International Business Machines Corporation Analytics based patch management and distribution
US9715378B2 (en) * 2013-12-18 2017-07-25 International Business Machines Corporation Automated software update scheduling
KR20150087988A (ko) * 2014-01-23 2015-07-31 한국전자통신연구원 단말용 응용 프로그램 관리 시스템 및 방법
US9692808B2 (en) * 2014-01-24 2017-06-27 Adobe Systems Incorporated Code path directives for controlling in-app experiences
US9996339B2 (en) * 2014-06-04 2018-06-12 Microsoft Technology Licensing, Llc Enhanced updating for digital content
CN104133699B (zh) * 2014-07-28 2018-11-27 广州视睿电子科技有限公司 设备系统软件升级方法与系统
EP2993578A1 (en) * 2014-09-02 2016-03-09 Gemalto M2M GmbH Method for adapting firmware of a wireless communication device
CN104503790B (zh) * 2014-12-19 2017-09-29 广东欧珀移动通信有限公司 一种应用版本的管理方法及系统、智能终端
US9785429B2 (en) * 2015-02-27 2017-10-10 Lenovo (Singapore) Pte. Ltd. Efficient deployment of thin client applications to end user
IN2015CH02762A (ja) * 2015-06-01 2015-07-17 Wipro Ltd
CN105069078A (zh) * 2015-07-31 2015-11-18 天脉聚源(北京)传媒科技有限公司 一种处理增量索引合并失败的方法及装置
CN105117250B (zh) * 2015-08-24 2019-03-29 联想(北京)有限公司 一种兼容性处理方法及电子设备
US9740473B2 (en) 2015-08-26 2017-08-22 Bank Of America Corporation Software and associated hardware regression and compatibility testing system
CN105404653B (zh) * 2015-10-30 2019-03-26 无锡清华信息科学与技术国家实验室物联网技术中心 一种全分布式文件索引及协作编辑机制的实现方法
JP6622577B2 (ja) * 2015-12-04 2019-12-18 キヤノン株式会社 配信システム、及び配信システムの制御方法
CN107015821B (zh) * 2016-01-28 2021-05-11 腾讯科技(深圳)有限公司 增量更新的方法和装置
US10291700B2 (en) * 2016-02-08 2019-05-14 International Business Machines Corporation Network optimized scan with dynamic fallback recovery
US10025583B2 (en) 2016-02-17 2018-07-17 International Business Machines Corporation Managing firmware upgrade failures
WO2017145357A1 (ja) * 2016-02-26 2017-08-31 三菱電機株式会社 情報処理装置、情報処理方法及び情報処理プログラム
US20170277517A1 (en) * 2016-03-22 2017-09-28 M2Communication Inc. Method Of Updating Program Code And Electronic Device Using The Same
US20170300317A1 (en) * 2016-03-24 2017-10-19 Knight Point Systems, Inc. System and method for patching software in a target computer system device
US10157009B2 (en) * 2016-07-06 2018-12-18 Arris Enterprises Llc Custom command file for efficient memory update
CN106293835A (zh) * 2016-08-09 2017-01-04 捷开通讯(深圳)有限公司 一种智能设备固件升级的方法及系统
CN106909427B (zh) * 2017-03-23 2020-09-22 北京奇虎科技有限公司 一种软件更新方法、装置和软件更新数据发布方法、系统
US10318281B1 (en) * 2017-04-06 2019-06-11 Amdocs Development Limited System, method, and computer program for upgrading software associated with a distributed, state-full system
US10191732B2 (en) 2017-06-09 2019-01-29 Citrix Systems, Inc. Systems and methods for preventing service disruption during software updates
US10496398B2 (en) * 2017-07-25 2019-12-03 Aurora Labs Ltd. Hot updates to ECU software using tool chain
CN108241500B (zh) * 2018-01-15 2022-02-01 腾讯科技(深圳)有限公司 一种硬件组件的修复方法、装置、系统和存储介质
JP7013918B2 (ja) * 2018-02-16 2022-02-01 トヨタ自動車株式会社 車両制御装置、プログラム更新方法およびプログラム
US10868853B2 (en) * 2018-06-08 2020-12-15 Verizon Patent And Licensing Inc. System and method for image file generation and management
DE102018211979A1 (de) * 2018-07-18 2020-01-23 Bayerische Motoren Werke Aktiengesellschaft Verfahren zur zentralen Update-Verwaltung für ein Fahrzeug und System zur zentralen Update-Verwaltung für ein Fahrzeug
EP4296849A1 (en) * 2019-09-03 2023-12-27 Google LLC Accelerating application and sub-package installations
CN113050977B (zh) * 2019-12-27 2022-06-17 武汉斗鱼网络科技有限公司 一种数据处理的方法及系统
CN111416998A (zh) * 2020-03-16 2020-07-14 上海晶曦微电子科技有限公司 一种用于交通设备的信息更新系统及方法
US11379215B1 (en) * 2020-06-15 2022-07-05 Amazon Technologies, Inc. Application-update techniques
CN113342376B (zh) * 2021-06-23 2022-08-30 支付宝(杭州)信息技术有限公司 一种针对物联网设备的操作系统进行升级的方法及装置
CN114661322B (zh) * 2022-03-11 2023-05-23 荣耀终端有限公司 操作系统的升级方法、电子设备及存储介质
EP4293500A1 (de) * 2022-06-17 2023-12-20 Siemens Aktiengesellschaft Aktualisieren einer software durch eine auszuführende umsetzungsvariante
CN115543403B (zh) * 2022-11-29 2023-03-21 紫光同芯微电子有限公司 一种系统升级方法及装置

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2001508575A (ja) * 1997-11-12 2001-06-26 コーニンクレッカ フィリップス エレクトロニクス エヌ ヴィ ソフトウェア更新マネージャ
JP2002135316A (ja) * 2000-10-26 2002-05-10 Oki Electric Ind Co Ltd 統合サービスネットワーク
JP2003263322A (ja) * 2002-03-11 2003-09-19 Toshiba Corp 情報環境設定システム、プログラム及び方法

Family Cites Families (24)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5835911A (en) * 1994-02-08 1998-11-10 Fujitsu Limited Software distribution and maintenance system and method
US5845077A (en) 1995-11-27 1998-12-01 Microsoft Corporation Method and system for identifying and obtaining computer software from a remote computer
US6049671A (en) 1996-04-18 2000-04-11 Microsoft Corporation Method for identifying and obtaining computer software from a network computer
US6074434A (en) * 1996-06-07 2000-06-13 International Business Machines Corporation Selection of code updates, data updates or new data for client
US6347398B1 (en) 1996-12-12 2002-02-12 Microsoft Corporation Automatic software downloading from a computer network
JPH1124934A (ja) * 1997-06-30 1999-01-29 Hitachi Software Eng Co Ltd クライアント・サーバシステムにおけるクライアントプログラムの配布管理方法
GB2333864B (en) * 1998-01-28 2003-05-07 Ibm Distribution of software updates via a computer network
US6167567A (en) * 1998-05-05 2000-12-26 3Com Corporation Technique for automatically updating software stored on a client computer in a networked client-server environment
US6216175B1 (en) 1998-06-08 2001-04-10 Microsoft Corporation Method for upgrading copies of an original file with same update data after normalizing differences between copies created during respective original installations
US6704933B1 (en) * 1999-02-03 2004-03-09 Masushita Electric Industrial Co., Ltd. Program configuration management apparatus
US6594822B1 (en) 1999-02-19 2003-07-15 Nortel Networks Limited Method and apparatus for creating a software patch by comparing object files
US6477703B1 (en) * 1999-06-29 2002-11-05 Hewlett-Packard Company Software patch selection tool
US6363524B1 (en) * 1999-09-10 2002-03-26 Hewlett-Packard Company System and method for assessing the need for installing software patches in a computer system
US6493871B1 (en) 1999-09-16 2002-12-10 Microsoft Corporation Method and system for downloading updates for software installation
US6711675B1 (en) * 2000-02-11 2004-03-23 Intel Corporation Protected boot flow
US6751794B1 (en) 2000-05-25 2004-06-15 Everdream Corporation Intelligent patch checker
US6675180B2 (en) * 2000-06-06 2004-01-06 Matsushita Electric Industrial Co., Ltd. Data updating apparatus that performs quick restoration processing
US6985929B1 (en) * 2000-08-31 2006-01-10 The United States Of America As Represented By The Secretary Of The Navy Distributed object-oriented geospatial information distribution system and method thereof
US6928426B2 (en) * 2000-12-30 2005-08-09 Intel Corporation Method and apparatus to improve file management
US6763517B2 (en) * 2001-02-12 2004-07-13 Sun Microsystems, Inc. Automated analysis of kernel and user core files including searching, ranking, and recommending patch files
US6782350B1 (en) * 2001-04-27 2004-08-24 Blazent, Inc. Method and apparatus for managing resources
US6966058B2 (en) * 2002-06-12 2005-11-15 Agami Systems, Inc. System and method for managing software upgrades in a distributed computing system
US20040088700A1 (en) * 2002-10-31 2004-05-06 Chung-I Lee System and method for automatically installing software on client computers via a network
US20040117414A1 (en) * 2002-12-17 2004-06-17 Capital One Financial Corporation Method and system for automatically updating operating systems

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2001508575A (ja) * 1997-11-12 2001-06-26 コーニンクレッカ フィリップス エレクトロニクス エヌ ヴィ ソフトウェア更新マネージャ
JP2002135316A (ja) * 2000-10-26 2002-05-10 Oki Electric Ind Co Ltd 統合サービスネットワーク
JP2003263322A (ja) * 2002-03-11 2003-09-19 Toshiba Corp 情報環境設定システム、プログラム及び方法

Also Published As

Publication number Publication date
AU2004279173A1 (en) 2005-06-30
EP1614032A1 (en) 2006-01-11
WO2005071542A1 (en) 2005-08-04
KR20060114616A (ko) 2006-11-07
RU2367005C2 (ru) 2009-09-10
KR101150041B1 (ko) 2012-06-01
CA2501548A1 (en) 2005-06-15
CN1777867A (zh) 2006-05-24
EP1614032B1 (en) 2014-06-04
MXPA05006614A (es) 2005-09-22
RU2005116848A (ru) 2006-01-20
BRPI0406403A (pt) 2005-10-04
EP1614032A4 (en) 2012-04-18
US20050132382A1 (en) 2005-06-16
CN1777867B (zh) 2010-09-15
US7509636B2 (en) 2009-03-24
AU2004279173B2 (en) 2010-06-24
JP2007514232A (ja) 2007-05-31

Similar Documents

Publication Publication Date Title
JP4800968B2 (ja) デルタパッチを利用してファイルをアップデートするための方法
JP4914220B2 (ja) ソフトウェアアップデートのための通信方法およびシステム
JP4871138B2 (ja) ソフトウェアアップデートのための通信方法
KR101098621B1 (ko) 네트워킹된 환경에서 설치 컴포넌트들을 업데이트하는시스템 및 방법
US7676448B2 (en) Controlling installation update behaviors on a client computer
US20050203968A1 (en) Update distribution system architecture and method for distributing software

Legal Events

Date Code Title Description
A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20070723

A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20070723

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20100921

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20101221

A02 Decision of refusal

Free format text: JAPANESE INTERMEDIATE CODE: A02

Effective date: 20110204

RD13 Notification of appointment of power of sub attorney

Free format text: JAPANESE INTERMEDIATE CODE: A7433

Effective date: 20110425

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A821

Effective date: 20110425

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20110606

RD13 Notification of appointment of power of sub attorney

Free format text: JAPANESE INTERMEDIATE CODE: A7433

Effective date: 20110607

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A821

Effective date: 20110607

A911 Transfer to examiner for re-examination before appeal (zenchi)

Free format text: JAPANESE INTERMEDIATE CODE: A911

Effective date: 20110628

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

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20110729

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

Free format text: JAPANESE INTERMEDIATE CODE: A01

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20110804

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

Free format text: PAYMENT UNTIL: 20140812

Year of fee payment: 3

R150 Certificate of patent or registration of utility model

Ref document number: 4800968

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

Free format text: JAPANESE INTERMEDIATE CODE: R150

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

S111 Request for change of ownership or part of ownership

Free format text: JAPANESE INTERMEDIATE CODE: R313113

R350 Written notification of registration of transfer

Free format text: JAPANESE INTERMEDIATE CODE: R350

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250