ソフトウェア設計及び演習2013

鈴木先生のまとめ

svn memo

http://ukai.jp/svn概要 のまとめ

Subversion

SubversionはCVSの利用形態をひきつぎつつ問題点を克服した新しいバージョン管理システム

  • はじめからネットワーク対応が考えられている
    • WebDAV, svn, svn+ssh
  • 差分をやりとり
  • リビジョンはリポジトリ単位
  • アトミックなコミット
    • 複数のファイルの変更も同時にコミットできる
  • ブランチ/タグの扱いが違う
    • コピーする
    • コンテンツをコピーしていないので軽いオペレーション

Subversion リポジトリ

svnのリポジトリはプロジェクトごとに作る リポジトリを越えてファイルの移動がない 参照は svn:externals コミッターが同じ範囲

リポジトリの中身(コンベンション)

  trunk/

トランク (CVS HEADのブランチ)

  branches/	

ブランチ (cvs tag -b)

  tags/

タグ (cvs tag)

svnコマンド

     % svn コマンド 引数
     % svn help
     % svn helpコマンド

URL リポジトリ リポジトリ + パス

     file:/svn/repos
     http://host/svn/repos
     svn://host/svn/repos

リビジョン X, X:Y

     {DATE}
     HEAD		リポジトリの最新
     BASE		ワーキングコピー
     COMMITTED	最後のコミット
     PREV		最後のコミットの前

svn mkdir - リポジトリにディレクトリを作る

     % svn mkdir file:///svn/repos/trunk

     --This line, and those below, will be ignored--
    
     A    file:///svn/repos/trunk
     Committed revision 1.
     % svn ls file:///svn/repos
     trunk/
     % svn mkdir -m 'mkdir branches' file:///svn/repos/branches
     Committed revision 2.
     % svn mkdir -m 'mkdir tags' file:///svn/repos/tags
     Committed revision 3.
    • svn import directory の中味をリポジトリにいれる

srcディレクトリをtrunkのsrcディレクトリに

     % ls src
     foo.c
     % svn import src  file:///svn/repos/trunk
     --This line, and those below, will be ignored--

     A    src
     Adding         src/foo.c
     Committed revision 4.
     % svn ls file:///svn/repos/trunk
     hello/
     % svn ls file:///svn/repos/trunk/src
     foo.c
     % svn ls -R file:///svn/repos/trunk
     src/
     src/foo.c

svn checkout - リポジトリからワーキングコピーに

trunkのsrcディレクトリを手元に

     % svn checkout file:///svn/repos/trunk/src
     A  src/foo.c
     Checked out revision 4.
     % ls hello
     total 20
     drwxr-xr-x    3 ukai     ukai         4096 May 11 23:58 ./
     drwxrwxrwt   10 root     root         8192 May 11 23:58 ../
     drwxr-xr-x    7 ukai     ukai         4096 May 11 23:58 .svn/
     -rw-r--r--    1 ukai     ukai           94 May 11 23:58 foo.c
     % svn info
     Path: 
     Url: file:///svn/repos/trunk/src
     Revision: 4
     Node Kind: directory
     Schedule: normal
     Last Changed Author: ukai
     Last Changed Rev: 4
     Last Changed Date: 2003-05-11 23:55:06 +0900 (Sun, 11 May 2003)

svn status, svn diff - 状態、リポジトリとワーキングコピーの違い

ワーキングコピーで修正

     % cd src
     % vi foo.c

     % svn status
     M	foo.c
     % svn diff
     Index: foo.c
     ===================================================================
     --- foo.c     (revision 4)
     +++ foo.c     (working copy)
     ....

svn commit - ワーキングコピーからリポジトリにコミット

     % svn commit 
     --This line, and those below, will be ignored--
    
     M    foo.c
     Sending        foo.c
     Transmitting file data .
     Committed revision 5.
     % svn status
     % svn diff

svn update - ワーキングコピーを最新に

リポジトリからワーキングコピーに

     % svn update
     At revision 5.

リポジトリからワーキングコピーにとりだしたリビジョンから、ワーキングコピーで修正されたものがあるか

     svn status

コピー -修正- マージ

コピー

  • svn checkout
  • svn update

修正

  • エディタ

マージ

  • svn commit

svn log

     % svn log
     ------------------------------------------------------------------------
     rev 5:  ukai | 2003-05-12 00:03:56 +0900 (Mon, 12 May 2003) | 2 lines
     
     add .
     
     ------------------------------------------------------------------------
     rev 4:  ukai | 2003-05-11 23:55:06 +0900 (Sun, 11 May 2003) | 2 lines
    
     import hello
    
     ------------------------------------------------------------------------

svn add - リポジトリにファイルを追加

     % vi Makefile

     % svn add Makefile
     A         Makefile
     % svn status
     A      Makefile
     % svn commit
    
     --This line, and those below, will be ignored--
    
     A    Makefile
     Adding         Makefile
     Transmitting file data .
     Committed revision 6.
     % svn status -u -v
                    6        6       ukai   .
                    6        6       ukai   Makefile
                    6        5       ukai   foo.c
     Head revision:      6

svn delete - リポジトリからファイルを削除

     % svn delete Makefile
     D         Makefile
     
     --This line, and those below, will be ignored--
    
     D    Makefile
     Deleting       Makefile
    
     Committed revision 7.
     % svn status -u -v
                    6        6       ukai   .
                    6        5       ukai   foo.c
     Head revision:      7

svn move - ファイルを移動

working copy 内

     % svn move foo.c hello.c
     A         hello.c
     D         foo.c

     % svn status
     A  +   hello.c
     D      foo.c

     % svn commit
    
     --This line, and those below, will be ignored--
    
     D    foo.c
     A    hello.c
    
     Adding         hello.c
     Deleting       foo.c
    
     Committed revision 8.

移動前のログがちゃんと見られる

     % svn log hello.c
     ------------------------------------------------------------------------
     rev 8:  ukai | 2003-05-12 00:24:23 +0900 (Mon, 12 May 2003) | 2 lines
    
     move foo.c -> hello.c
    
     ------------------------------------------------------------------------
     rev 5:  ukai | 2003-05-12 00:03:56 +0900 (Mon, 12 May 2003) | 2 lines
    
     add .
    
     ------------------------------------------------------------------------
     rev 4:  ukai | 2003-05-11 23:55:06 +0900 (Sun, 11 May 2003) | 2 lines
     
     import hello
     
     ------------------------------------------------------------------------

プロパティ

プロパティ (svn help propset)

  • svn:ignore
    • 各行に無視するファイルのパターン (.cvsignore)
  • svn:keywords
    • キーワード置換: URL, Author, Date, Rev, Id
  • svn:executable
    • chmod +x
  • svn:eol-style
    • native, LF, CR, CRLF
  • svn:mime-type
  • svn:externals

svn prop*

     % svn propset svn:keywords Id hello.c
     property `svn:keywords' set on 'hello.c'
     % svn commit
     --This line, and those below, will be ignored--
    
     MM   hello.c
     Sending        hello.c
     Transmitting file data .
     Committed revision 9.
    
     static char rcsid[] = "$Id$";
                             ↓
     static char rcsid[] = "$Id: hello.c 9 2003-05-11 15:36:18Z ukai $";
    
     % svn proplist -v hello.c
     Properties on 'hello.c':
       svn:keywords : Id
    
     svn propdel		削除
     svn propedit	変更
     svn propget		取得

svn revert - ワーキングコピーの編集をなかったことにする

     % svn status
     M      hello.c
     % svn revert hello.c
     Reverted hello.c
     % svn status

複数人で使う時は

リポジトリのパーミッション

     % svn ls file:///svn/repos
     svn: Couldn't open a repository.
     svn: Unable to open an ra_local session to URL
     svn: Unable to open repository 'file:///svn/repos'
     svn: Berkeley DB error
     svn: Berkeley DB error while opening environment for filesystem /svn/repos/db:
     Permission denied

group writableにしておく

    umask 002

他の人が修正を既にコミットしていて自分はなにもしてない場合

     % svn status
     % svn update
     U  hello.c
     Updated to revision 11.

修正がかぶらない場合

     % svn status
     M      hello.c
     % svn update
     G  hello.c
     Updated to revision 13.

→ マージされる

コンフリクトする場合

     % svn status
     M      hello.c
     % svn update
     C  hello.c
     Updated to revision 14.
     % ls hello.c*
     hello.c  hello.c.mine  hello.c.r13  hello.c.r14
  • hello.c
    • マージしたもの
    • コンフリクトマークいり
  • hello.c.mine
    • マージする前
  • hello.c.r13
    • ワーキングコピー修正前
  • hello.c.r14
    • リビジョン最新

コンフリクトの解消

コンフリクトマーク

     <<<<<<< .mine
     ワーキングコピーで修正していたもの
     =======
    リポジトリの内容
     >>>>>>> .r14

     % svn update
     At revision 14.
     % svn status
     C      hello.c
     ?      hello.c.mine
     ?      hello.c.r13
     ?      hello.c.r14
     % svn resolve hello.c
     Resolved conflicted state of hello.c
     % ls hello.c*
     hello.c
     % svn status
     % svn update
     At revision 14.

タグ/ブランチ

  • Subversionにおいてはコピー操作。
  • タグ/ブランチにあまり区別はない。
  • バージョン管理システムを使っていなかった時に近い。
     % svn copy file://svn/repos/trunk/hello file:///svn/repos/tags/hello-1.0
    
     --This line, and those below, will be ignored--
    
     A    file:///svn/repos/tags/hello-1.0
     Committed revision 15.
     % svn ls -R file:///svn/repos/
     branches/
     tags/
     tags/hello-1.0/
     tags/hello-1.0/hello.c
     trunk/
     trunk/hello/
     trunk/hello/hello.c

hooksの使い方

リポジトリのhooksディレクトリに.tmpl 拡張子がない実行ファイルを置く。 CVSROOT/管理用ディレクトリと違ってバージョン管理下にはない。

     % ls hooks/
     post-commit.tmpl          pre-commit.tmpl          start-commit.tmpl
     post-revprop-change.tmpl  pre-revprop-change.tmpl

     % cat post-commit
     #!/bin/sh -e
     REPOS="$1"
     cd /path/to/check/out/dir
     umask 002
     svn update `svnlook dirs-changed $REPOS | sed -e 's,trunk/,,'`

リポジトリのバックアップ/リストア

バックアップ

 % svnadmin dump /svn/repos rev1 rev2 > dumpfile1
 % svnadmin dump /svn/repos rev2+1 rev3 --incremental > dumpfile2
 % svnadmin dump /svn/repos rev3+1 rev4 --incremental > dumpfile3

リストア

 % svnadmin create /svn/newrepos
 % svnadmin load /svn/newrepos < dumpfile1
 % svnadmin load /svn/newrepos < dumpfile2
 % svnadmin load /svn/newrepos < dumpfile3

別の方法

 % /usr/lib/subversion/hot-backup.py  /svn/repos /var/backups/subversion/

/var/backups/subversion/repos-n-m にリポジトリがバックアップされる

既知の問題点

  • アクセスコントロールが貧弱
  • ファイル単位で制御できない
  • hooksを使う?
  • 仕様なども含めて検討中
  • どのレイヤにいれるべきか?
  • 日本語ファイル名の扱い
  • annotate
  • svn 1.0以降の予定 svn blame
  • symlink/hardlink
  • svn 1.0以降
  • 仕様が枯れていない
  • 認証情報 .svn/ から ~/.subversion
  • svn-tunnel-agent=ssh から svn+ssh:

よくあるトラブル

  • パーミッション
    • 読み書きできないとdbがオープンできない
    • 複数人で使う時は group writable で umask 002
  • WebDAVのみに限定して www-data の所有にする
  • アップグレードした後
    • svnadmin recover /svn/repos する必要がある場合がある
  • コミット途中にとめた
    • ロックが残っている
    • svn cleanup でロックを消す

まとめ

  • よりよいCVSをめざしたバージョン管理システム
    • ファイルの移動
    • コミットがアトミック
  • 美しい設計、コーディングスタイル
    • HACKING
    • 言語バインディング: python, javaなど
  • しかしながらまだまだ開発途上 (<< 1.0) 実用に使えるがCVSほど枯れてはいない


最終更新日:2013/09/04 10:32:55