「Concurrent Versions System」の版間の差分
細 (→クライアント) |
(相違点なし)
|
2013年6月25日 (火) 11:07時点における最新版
テンプレート:Infobox Concurrent Versions System(コンカレント・バージョンズ・システム、並行バージョンシステム)は、通常CVS(シーブイエス)と略される、テキストファイルの変更を記録し管理するバージョン管理システム。フリーソフトウェアである。
概要
主にソフトウェアの開発に伴うソースコードを始めとしたテキストファイルの共有(保存、取り出し)に使われる。テキストファイルの枝分かれした版を管理することができる。
枝分かれ(並行ヴァージョン)の機能を使わなくても、ファイルの直線的な追加改変を追いかけるのに使うことが出来る。特にダウンロードをする場合、サーバ上のファイルと自分の持っているファイルの差分のみを転送するだけで最新版を手にいれることが出来るため、開発途中のプログラムの配布にも使われる。
通常、CVSサーバを用意してファイルの共有をする。CVSサーバにアクセスするCVSクライアント・プログラムは、コマンドラインの cvs を始め、GUI によるラッパーや、統合開発環境向けのプラグインが多数作られている。
CVSは、ネットワークでの使用を考慮した最初のソースコード管理システムでかつフリーであったこともあり、1990年代を通じて広く利用された。しかしながら、後述するような欠陥が明らかになるにつれ、これらの問題を改善した、Subversion・Perforce・gitなどの新しいツールにとってかわられた。
RCSとの比較
CVSは元々、単一のファイルを対象としたバージョン管理ツールであるRCSの上に作られていたが、現在は依存はなくなった(リポジトリ内のデータ保持は依然として RCS のそれである)。$Id:$などのキーワードは、その名残である。更にRCSは、diffなどのUNIX系のテキスト処理プログラムの上に作られている。
RCSは、マルチユーザーシステム(1台のコンピュータに、複数のダム端末が接続され、CPUやファイルシステムが共有されている)の上で、同じファイル/フォルダを共有した状態で使われたのに比べ、CVSではCVSサーバとして別のコンピュータ上に用意することもできる。
同一ファイルを複数人で同時編集した場合のコンフリクトに対するアプローチも異なる。RCS はファイルをロックする事で同時編集を禁止する。対する CVS では、RCSのような強固なロックメカニズムは、もたない。すなわち、同時編集を許可する代りにコンフリクトが生じた場合、コミット時にマージ操作が必要とされる。
欠点
- ファイル名の変更削除、ディレクトリ名の変更削除をうまく扱えない。
- 異なる文字コード(JIS/SJIS/EUC)に対するサポートがない。
- 基本的に個々のファイルの履歴はわかるが、リポジトリの履歴は簡単には知ることができない。
- バイナリーファイルの扱いが下手で、リポジトリサイズの増大につながる。
- 分散リポジトリをサポートしない。
- アトミック・コミットをサポートしない。複数のファイルを同時にコミットした場合、CVSではそれぞれのファイルを(ごく短時間の間に)一つずつコミットしたものとして扱うため、アトミック性を満たすことができない。
等の点が挙げられる。
クライアント
- Windows - WinCvs, TortoiseCVS(エクスプローラ拡張)
- Mac OS X, Mac OS - MacCvs
- GNOME - gCvs
- Eclipse - クライアント機能が内蔵されている。