====== 서브버젼(Subversion) 명령어 ====== ===== 목적 ===== - 개인적으로 자주 이용하는 Subversion 명령을 모아두었다. ===== 관리(Administration) ===== ==== 준비 ==== - apache2 + subversion 을 사용하는 것을 기준으로 설명합니다. - Debian 서버 기준이며, 패키지로 설치한 것입니다. - 경로와 파일은 아래와 같다고 가정한다. == == ^ Subversion URL | http://subversion.adminschool.net | ^ 기본디렉토리 | /data/vcs/svn | ^ 아파치설정 | /etc/apache2/mods-available/dav_svn.conf | ^ 계정정보 | /etc/apache2/dav_svn.passwd | ==== 사용자계정 ==== - Subversion 계정관리는 /etc/apache2/dav_svn.passwd 에서 관리한다. - **계정추가**(htpasswd 명령을 이용한다.) # htpasswd /etc/apache2/dav_svn.passwd starlits - **계정삭제**(vi로 /etc/apache2/dav_svn.passwd 파일을 열어 계정이 있는 라인 삭제) - **계정암호변경** - 추가와 명령이 동일하다. - 아이디가 존재하면 암호만 변경된다. # htpasswd /etc/apache2/dav_svn.passwd starlits ==== 프로젝트 생성 ==== - beflyt 라는 프로젝트 디렉토리를 만든다. # svnadmin create /data/vcs/svn/beflyt - apache2에서 사용할 수 있도록 권한을 부여한다. # cd /data/vcs/svn # chown -R www-data.www-data beflyt/ - 웹브라우저를 열어서 확인해 본다. http://subversion.adminschool.net/svn/beflyt ==== 프로젝트 삭제 ==== - /data/vcs/svn 아래의 프로젝트(예 beflyt)를 삭제하면 된다. # cd /data/vcs/svn # rm -rf beflyt ===== 개발(Development) ===== ==== Import Project ==== - 버젼관리할 소스 디렉토리로 이동한다. - **New Project**라는 이름으로 새로운 프로젝트를 최초 등록(Import) 시킨다. # cd /path/to/projectname # svn import -m "New Project" . svn://HostName/projectname/trunk or # svn import -m "New Project" . http://HostName/svn/projectname/trunk ==== Create tag, branch directory ==== - 테그(tag) 디렉토리를 생성한다. # svn mkdir -m "Create tags directory" svn://HostName/projectname/tags or # svn mkdir -m "Create tags directory" http://HostName/svn/projectname/tags - 브런치(branches) 디렉토리를 생성한다. # svn mkdir -m "Create branches directory" svn://HostName/projectname/branches or # svn mkdir -m "Create branches directory" http://HostName/svn/projectname/branches ==== Checkout Project ==== - svn 서버를 이용할 경우 $ svn co svn://subversion.adminschool.net/projectname/trunk projectname - http를 이용하는 경우 $ svn co http://subversion.adminschool.net/svn/projectname/trunk projectname - OS 계정과 다른 계정으로 가져올때 $ svn --username=starlits co http://subversion.adminschool.net/svn/projectname/trunk projectname ==== Update ==== - Subversion Server에 변경된 파일이 있는지 확인하고, 최신정보를 반영한다. $ svn update ==== commit ==== - 변경된 파일 반영하기 $ svn commit ==== checkout/update/commit 차이 ==== == == ^ Checkout | Repository로부터 내용을 꺼내오는 작업 (co 라고 줄여쓸 수 있다.) | ^ Commit | Checkout된 내용을 수정한 뒤에 다시 Repository로 보내는 작업 | ^ Update | Checkout 한 뒤로 다른 사람들이 commit한 내용을 추가적으로 checkout 하는 작업 | ==== add ==== - 파일/디렉토리 추가하기 $ svn add {filename|directory} ==== Diff ==== - 현재 revision이 5 일 경우, revision 4와 차이를 출력한다. $svn diff --revision 4 sample.c Index: sample.c =================================================================== --- sample.c (revision 4) +++ sample.c (working copy) @@ -2,7 +2,8 @@ int main() { - printf("Sample Program Version 0.1\n"); + printf("Sample Program Version 0.2\n"); + printf("Hello Subversion\n"); return 0; } - revision 4와 5를 비교 하고 싶으면 **''-''-revision 4:5 (-r 4:5)**로 하면 된다. \\ **''-''-revision 8:10** 도 가능하다. $ svn diff --revision 4:5 sample.c Index: sample.c =================================================================== --- sample.c (revision 4) +++ sample.c (revision 5) @@ -2,7 +2,8 @@ int main() { - printf("Sample Program Version 0.1\n"); + printf("Sample Program Version 0.2\n"); + printf("Hello Subversion\n"); return 0; } ==== History View ==== - 현재까지 Repository에 올라간 로그기록을 보여준다. $ svn log - 현재소스와 Repository의 소스상의 차이를 보여준다. $ svn diff - 로그기록을 ChangeLog 파일로 만들어 준다. $ svn2cl ==== 과거소스 가져오기 ==== - 현재 최신 소스를 받아온다. $ svn co http://svn.adminschool.net/svn/beflyt/trunk beflyt - 2008년 1월 1일 소스를 받아온다. $ svn co -r {20080101} http://svn.adminschool.net/svn/beflyt/trunk beflyt - **Revision 3** 소스를 받아온다. $ svn co -r 3 http://svn.adminschool.net/svn/beflyt/trunk beflyt ==== 서버와 버젼확인 ==== - SVN 서버에 로컬에 있는 파일보다 최신버젼이 있는지 확인한다. svn status -u ==== tags 사용법 ==== - http://blog.naver.com/joycestudy/100097622001