Gnutella

P2Pプロトコルおよびファイル共有クライアント

Gnutellaグヌーテラニューテラ)はP2Pプロトコルおよびファイル共有クライアント

概要

編集

ナップスターなどのP2Pクライアントの場合は、中央サーバが存在し、ファイルのメタデータの管理や検索サービスを提供することにより、P2Pネットワークが機能している。それに対し、グヌーテラはサーバに依存せず、純粋にピア間の通信のみでファイルの送受信などの機能を実現している。

P2Pのしくみの分類中、このようなピア間の通信のみによって機能するものをピュアP2P、ナップスターのようにサーバの仲介を必要とするものを、ハイブリッドP2Pと呼んでいる。

その他には、KaZaASkypeに使われているスーパーノード型ハイブリッドP2Pがある。

特徴

編集

ナップスターに代表される第一世代P2P(ハイブリッドP2P)は、中央サーバに依存する為、ネットワークへのトラフィックは少ないが、耐障害性が低く、サーバがダウンしたらネットワークが形成できないという弱点があった。それに対してグヌーテラに代表される第二世代P2P(ピュアP2P)は、各クライアントがサーバを兼ねる(サーバント)為、耐障害性が高い。

製作者の「核戦争でも生き残れるように設計されたもの(Gnutella is designed to survive nuclear war)」や、「万一、ニューヨークに核爆弾が投下されたとしても、(それ自体はたいへんなことだが)ニューヨーク以外の『グヌーテラ友達』によってグヌーテラネットは維持されるだろう」といった言葉が、グヌーテラネットワークの特徴をよく表している。

グヌーテラの仕組み

編集

グヌーテラネットワーク上で交わされているメッセージは、PING、PONG、PUSH、QUERY、QUERY_HITの以上である。

接続

編集

中央サーバが存在しないグヌーテラにおいて、最初に接続するときに何処に問い合わせるのか?という問題が出てくる。 グヌーテラ第一世代では、ノード情報を掲示板などで入手する方法が採られていたが、グヌーテラ第二世代になって、GWC(GWebCache)というブートストラップサーバーにより各ノードと接続する方法がとられた。

接続においては、グヌーテラサーバントはまずPINGという接続要求を出す。それに対して、接続相手はPONGという信号を返して、ハンドシェイクを行い接続が完了する。

検索

編集

検索はグヌーテラネットワークで行っており、ファイルを求めるサーバントは、QUERYをグヌーテラネットワークに送信し、ヒットしたクエリがQUERY_HITとして検索結果に表示される。

転送

編集

グヌーテラでの、ファイルの転送はHTTPプロトコルで行われている。 ファイルの転送は、QUERY_HIT識別子に含まれる、IPアドレスポート番号などによってファイルの所有者にHTTPでの転送命令を出す。 また、ファイル所有者がファイアウォール下にいるサーバントの場合は、PUSH識別子を出し、相手サーバントがHTTPでの転送命令を出す。

開発の経緯

編集

2000年AOL社の一部門であるNullsoftで、当時社員だった Justin FrankelTom Pepperの二人が、最初のグヌーテラクライアントを開発した。

2000年3月14日、二人はNullsoftのサーバー上にプログラムをダウンロードできる形でアップロードした。この出来事はスラッシュドットで告知されたため、その日の内に数千人がソフトをダウンロードした。ソースコードについては、後ほどGPLライセンスの元で提供する予定だった。

翌日、AOLは法的問題を理由にプログラムの提供を中止し、さらにNullsoft部門にプロジェクトを中止させた。しかしこの措置によっても、グヌーテラを止めることはできなかった。

数日後には、リバースエンジニアリングによってプロトコルは解析され、それを元にグヌーテラ互換のオープンソースクローンが登場した。現在でも、様々なグループが グヌーテラ 互換クライアントの開発を続けている。

グヌーテラ第一世代

編集

シャットダウンから間もなくして、Brian MaylandがNullsoftのプログラムを入手して、グヌーテラプロトコルの動作原理を理解するためにリバースエンジニアリングした。彼の仕事のおかげでテキストベースのUNIXプログラムを作ったJosh Pieperや、より使いやすいGUIをもったプログラムを作ろうとしたGene KanSpencer Kimballのような人々によってソフトウェア開発がなされることになった。

グヌーテラ第二世代

編集

ユーザの裾野が広がるにつれ、システムの重大な問題が取り沙汰されはじめた。ネットワークはPINGリクエストで溢れかえり、同時に非常に多くの検索クエリーで高負荷になった。より高速なハブとしての役割を果たすコンピュータに接続した低速のモデムといった形でネットワークのトポロジーは非効率的だった。第一世代のソフトウェアの深刻なバグによってパケットがネットワーク上を不明確にさまよっていた。ネットワークは“本来は少数のユーザのために設計されたもので”100人単位から10,000 単位のユーザに膨張しトラブルに見まわれた。「ただ乗り」や「何も提供していないのにファイルを取り出すだけの人々」によってもユーザが探し物をするのを難しくした。

もう一度、情熱的なコミュニティーが救済に乗り出した。Bob Schmidtが初めてのホストキャッシングシステムを開発した。プログラマー達はGnutella 0.56のコードを修正し、パケットが適切に運ばれるようにTTLのバグを取り除こうとした。そして、Jorge Gonzalesはネットワークをダメにするスパマーたちからネットワークを守る行動に出た。

この時点で、物事は個人の開発者が全てをまかなうにはあまりにも複雑になっていた。彼らはコードを書き、報道やユーザやお金の工面をしなければならなかった。 こういった事情で、早急に商業的な努力が介入し、「救済に乗り出す」必要が出てきた。Clip2はgnutellahosts.comを開発し、より良いホストキャッシュの実装し、いくらかナップスターのようなトポロジーをグヌーテラネットワークに組み入れて合体させるようなやり方で動く小さなサーバリフレクターを開発した。

グヌーテラ互換サーバント

編集
名称 プラットホーム ライセンス
Acquisition macOS シェアウェア
Acqlite macOS GNU GPL
BearShare Microsoft Windows シェアウェア en:Closed source
Phex Java GNU GPL
Cabos Java GNU GPL
CocoGnut RISC OS フリーウェア
Gnucleus Microsoft Windows GNU GPL, GNU LGPL
GTK-Gnutella UNIX GNU GPL
LimeWire Java GNU GPL
mlDonkey
Morpheus Microsoft Windows en:Closed source
Mutella UNIX GNU GPL
Poisoned macOS GNU GPL
Qtella Linux GNU GPL
Shareaza Microsoft Windows GNU GPL
Symella Symbian OS GNU GPL
XNap Java GNU GPL
XFactor macOS GNU GPL

関連項目

編集

脚注・出典

編集
  1. ^ GLYN MOODY 小山祐司監訳『ソースコードの反逆』株式会社アスキー、2002年6月11日、365頁。 

外部リンク

編集

Gnutella互換サーバント