1. 필수 패키지 설치

$ sudo apt-get install make libcurl4-gnutls-dev libexpat1-dev gettext libz-dev libssl-dev asciidoc xmlto autoconf

 

 

2. 다운로드

$ cd /srv/install/git

$ wget http://git-core.googlecode.com/files/git-1.8.4.1.tar.gz
$ tar zxvf git-1.8.4.1.tar.gz
$ cd git-1.8.4.1/


3. 빌드

$ make configure
$ ./configure --prefix=/usr/local
$ make all doc
$ sudo make install install-doc install-html

   - 설치가 잘 되었는지 확인을 해보기 위해서 버전 확인을 해보자.

$ git --version



GIT 자동완성을 지원하기 위해서는...
   - http://whatwant.tistory.com/478


우리 모두 Git으로 행복한 형상관리를...


반응형

기본적으로 RedHat 기본 계정이 root라고 전제하고 진행하면 되겠다.


1. 계정 생성

$ adduser git
$ passwd git
$ adduser gitolite
$ passwd gitolite




2. gitolite 다운로드

$ su git
$ cd
 $ git clone http://github.com/sitaramc/gitolite.git
$ cd gitolite/




3. 관리자 SSH Public-Key 파일 확보 하기

$ exit

$ su gitolite
$ ssh-keygen

$ exit
$ cp /home/gitolite/.ssh/id_rsa.pub /home/git/gitolite/gitolite.pub
$ chown git:git /home/git/gitolite/gitolite.pub 




4. 설치하기

$ su git
$ /home/git/gitolite

$ ./install
./src/gitolite setup -pk ./gitolite.pub




5. gitolite 관리자 계정

$ exit
$ su gitolite
$ cd

$ git clone git@localhost:gitolite-admin.git 

$ git config --global user.email "seinfra@whatwant.com"

$ git config --global user.name "seinfra"

$ git config --global push.default matching



gitolite 사용법이나 기타 사항은 별도의 포스팅을 참고하기 바라며...


반응형

빌드하기 위해 필요한 패키지들을 미리 설치합시다.

yum install curl-devel expat-devel gettext-devel openssl-devel zlib-devel gcc xmlto


asciidoc 은 직접 받아서 설치를 해야 한다.

$ cd /srv/install/asciidoc
wget http://pkgs.repoforge.org/asciidoc/asciidoc-8.6.8-1.el6.rfx.noarch.rpm
$  rpm -Uvh 
asciidoc-8.6.8-1.el6.rfx.noarch.rpm

git 소스파일을 내려 받아야겠죠?!

$ cd /srv/install/git
$ wget  http://git-core.googlecode.com/files/git-1.8.4.1.tar.gz
$ tar zxvf git-1.8.4.1.tar.gz
$ cd ./
git-1.8.4.1  


 Ubuntu에서 했던 것과 차이가 없죠 !?

$ make configure
$ ./configure --prefix=/usr/local
$ make all doc
$ sudo make install install-doc install-html

버전 확인 !

$ git --version


GIT 자동완성을 지원하기 위해서는...

우리 모두 Git으로 행복한 형상관리를...
반응형

Windows 환경에서 Subversion 서버 환경을 구축하는 방법 중 하나로 BitNami 패키지를 활용하는 방법을 살펴보았었다.

   - Subversion 설치 (Windows, BitNami) : http://whatwant.tistory.com/609


상당히 편리하기는 하지만,
솔직히 필자의 취향과는 너무도 다른 방식이기에 공식 배포판을 가지고 환경을 구축하는 방법을 살펴보고자 한다.


리눅스(Ubuntu) 환경에서는 필자가 좋아하는 방식인 SourceCode로 설치하는 방법을 살펴보았었다.

   - Subversion 설치 (Ubuntu, SourceCode) : http://whatwant.tistory.com/566


Windows에서도 SourceCode를 빌드할 수 있겠지만,
솔직히 최근 하루에 30분 짬내기도 힘든 상황에서 좋아하지도 않는 Windows 환경에 시간 투자하기는.... ^^



공식적으로 Windows 환경을 위한 Binary는 다음과 같이 제공이 되고 있다.

   - http://subversion.apache.org/packages.html#windows




1. Download

서버를 구성하기 위해서 최근에 유행(?)하는 것은 VisualSVN이다.

   - http://www.visualsvn.com/


Windows 환경에서 대부분 그렇듯이 Client와 Server 두 가지로 구분되어서 제공되고 있다.

   - http://www.visualsvn.com/downloads/

위 경로로 접속하면 다운로드는 3가지로 구분이 되어서 배포되고 있다.



   - http://www.visualsvn.com/server/download/

System Requirements 등을 확인하면서 다운로드를 받기 위해 위 경로로 접속해보자.


대부분의 Windows 운영체제를 지원해주고 있고 상당히 낮은 CPU와 RAM, HDD 를 요구하고 있다.
즉, 어지간한 환경이라면 다 가능하다라는 아름다운 조건이다~!!!

잡소리가 길었다. [ download now ]를 눌러서 다운로드 받고 실행하자.



2. Install

사실 대부분의 상황에서도 그렇지만, 특히나 서버 프로그램은 경로를 포함해서 되도록이면 Default 설정을 따르는 것이 좋다.
선택의 상황들에 대해서 잘 읽어보고 되도록이면 기본 설정으로 가자.


위 설정을 바꿔야 하는 상황이라면 이미 expert일테니.... ^^


VisualSVN은 상용 Enterprise Edition도 제공을 하고 있다.
좋은 소프트웨어라 판단된다면, 또는 회사 업무용으로 사용한다면 구매해서 사용하는 것을 권장한다.
특히, 인증이나 로그 관련한 부분만으로도 충분히 가치가 있다고 생각한다.


공부를 위해 또는 테스트 용도로 사용한다면, "Standard Edition"으로 선택해서 설치를 계속 진행하자.


설치 경로는 별다른 사유가 없다면 그대로 설정을 하고,
저장소 경로는 각자의 상황에 따라 적절히 변경을 하면 될 것 같다.

그리고, 서버로 사용할 포트를 설정하는데 기본값은 보안을 위해 [ https ]를 사용하는 것을 권장하고 있다.


테스트 용도로 사용하거나 방화벽 등의 이슈가 있는 상황에서는 그냥 일반 http 포트인 80번 포트를 사용하자.


설치 과정이 진행이 되면 위와 같이 마무리가 된다.


서버 프로그램다운(?) Management 화면이 나온다.



repository 생성하고, 계정 관리하고 하는 부분에 대해서는 따로 포스팅하도록 하겠다.

반응형

'SCM > Subversion' 카테고리의 다른 글

Subversion 설치 (Windows, BitNami)  (0) 2013.09.09
Subversion 프로토콜 - 1. SVN (Ubuntu)  (0) 2013.09.09
Subversion 설치 (Ubuntu, SourceCode)  (0) 2013.09.05

개인적으로 별로 좋아하지 않는 Windows 환경, 그리고 별도로 구성된 패키지 방식...
그러나, 어느 해외연구소 담당자가 리눅스 서버와 소스 빌드 설치 등에 익숙하지 않은 관계로...


1. BitNami Stack Download

   - BitNami에서 제공하는 "Version Control"은 몇 가지 없다.
   - 일단, 여기에서 Subversion을 선택하고 다운로드 받자.



2. Install

   - 다운로드 받은 파일을 실행함으로써 설치를 진행하자.


   - 그런데, 이 때 하나 주의해야할 점은 기존에 다른 Server를 운영하는 상황에서는 포트 충돌로 조금 곤란할 수가 있다.
   - 되도록이면 하나의 서버에는 하나의 서버 어플리케이션만 운영하기 바란다.


   - 설치를 하고나면 위와 같은 화면이 뜨고. 왼쪽 위 Subversion Icon을 클릭하면 된다.




그런데, 이렇게 설치를 해보니... 사용법(?) 알아내기도 난감하고, 굳이 이렇게 설치를 해서 뭐가 좋은지 모르겠다.

이렇게 패키지로 설치를 하는 경우 주어진 방법대로 사용하지 않고,
막 쓰게 되면 꼬이게 되어 나중에 상당히 곤란하게 되는 경우가 많았기 때문이다.

반응형

Subversion을 설치했다는 것은 형상관리를 하고자 한다는 말이고,
형상관리를 하겠다라는 것은 일반적으로 여러명과 공동 작업을 하겠다라는 말일 것이다.

여러 명이 접속하는 서버를 구성하기 위해서 가장 중요한 것은 어떤 프로토콜을 사용할 것인가 하는 점이다.

그러면, Subversion에서는 어떤 프로토콜을 사용할 수 있을까?

   - FileSystem
   - HTTP
   - SSH
   - SVN
   - SVN+SSH


1. Protocol - SVN

   - Subversion은 [ svnserve ]를 통해서 고유의 프로토콜을 사용할 수 있게 해준다.
   - 기본으로 사용하는 포트는 [ 3690 ] 이다.

   - 당연한 말이지만, Apache를 통해서 제공하는 HTTP 프로토콜 보다는 훨씬 빠르다.
   - SSH 프로토콜보다 빠른지는 한 번 테스트해봐야 알 수 있을 것 같다.

   - SVN 프로토콜을 사용하기 위해서는 [ svnserve ] 데몬을 실행해야하고, 그 방법은 정말 쉽다.

$ sudo svnserve -d -r /srv/repository/

   - 이것으로 끝이다. Subversion Server가 실행된 것이다.

$ cd /srv/workspace

$ svn checkout svn://127.0.0.1/svnrepo svnrepo

체크아웃된 리비전 0.

$ ls -al
합계 12
drwxr-xr-x 3 chani chani 4096  9월  7 00:20 .
drwxr-xr-x 5 root  root  4096  9월  6 23:55 ..
drwxrwxr-x 3 chani chani 4096  9월  7 00:20 svnrepo

   - SVN  프로토콜을 통해 repository를 받아올 수 있게 되었다.
   - 그런데, 방금 우리는 계정 정보 없이 그냥 막 받아왔다. 우리가 원하는 것은 계정을 통한 권한제어인데...

$ cd /srv/repository/

$ cd svnrepo/

$ ls -al
합계 32
drwxrwxr-x 6   chani chani 4096  9월  5 22:56  ./
drwxr-xr-x 3    chani chani 4096  9월  5 22:56  ../
-rw-rw-r-- 1    chani chani  246  9월  5 22:56  README.txt
drwxrwxr-x 2   chani chani 4096  9월  5 22:56  conf/
drwxrwsr-x 6   chani chani 4096  9월  5 22:56  db/
-r--r--r-- 1      chani chani     2  9월  5 22:56  format
drwxrwxr-x 2   chani chani 4096  9월  5 22:56  hooks/
drwxrwxr-x 2   chani chani 4096  9월  5 22:56  locks/

   - 서버에 생성한 repository를 살펴보자. 위치하고 있는 디렉토리를 주의깊게 살펴봐야 한다.

$ cd conf/

$ ls -al
합계 24
drwxrwxr-x 2  chani chani 4096  9월  5 22:56 .
drwxrwxr-x 6  chani chani 4096  9월  5 22:56 ..
-rw-rw-r-- 1   chani chani 1080  9월  5 22:56   authz
-rw-rw-r-- 1   chani chani  885  9월  5 22:56    hooks-env.tmpl
-rw-rw-r-- 1   chani chani  309  9월  5 22:56    passwd
-rw-rw-r-- 1   chani chani 4002  9월  5 22:56   svnserve.conf

   - 특히 우리가 관심을 가져야 할 곳은 conf/ 디렉토리이다.
   - 우선, 우리는 계정을 사용하겠다라는 설정부터 하자.

$ nano ./svnserve.conf

[general]
anon-access = none
auth-access = write
password-db = passwd

   - anonymous 접근은 막고, 인증받은 계정으로 읽기/쓰기를 하겠으며, 계정 정보는 passwd 파일로 하겠다라는 설정이다.

$ nano ./passwd

[users]
whatwant = 1234

   - 기본적으로 passwd 파일에서 설정은 [ 사용자계정 = 비밀번호 ] 형식이고, 암호화하지 않는다.

$ svn --username whatwant checkout svn://127.0.0.1/svnrepo svnrepo

인증 영역(realm): <svn://127.0.0.1:3690> b4595488-89ba-479b-b681-c8e86660c71c
'whatwant'의 암호: ****

'(null)'의 GNOME 키 링 암호: ****

체크아웃된 리비전 0.

   - ID / Passwd 방식으로 접근이 이루어지는 것을 볼 수 있다.

   - 중간에 보면 [ '(null)'의 GNOME 키 링 암호: **** ] 부분이 걸리적거리는데...

$ nano ~/.subversion/config

[auth]
password-stores =
store-passwords = yes

$ nano ~/.subversion/servers

[groups]
store-plaintext-passwords = no

   - 이제 기본적인 상황은 모두 점검을 했다.
   - 이제 필요한 것은 부팅할 때 자동으로 구동이 되도록 셋팅만 해주면 된다.

   - https://help.ubuntu.com/community/Subversion
   - 필자가 테스트하고 있는 환경이 우분투이기에 우분투 환경에서 사용할 수 있는 방법을 찾아보았다.

   - initd script for svnserve
   - http://odyniec.net/articles/ubuntu-subversion-server/svnserve

$ cd /etc/init.d/
$ sudo wget http://odyniec.net/articles/ubuntu-subversion-server/svnserve
$ sudo chmod +x ./svnserve
$ sudo nano ./svnserve

DAEMON=/usr/local/bin/$NAME
DAEMON_ARGS="-d -r /srv/repository"

$ sudo /etc/init.d/svnserve start

   - 이제 svnserve를 예쁘게 사용하자.


반응형

'SCM > Subversion' 카테고리의 다른 글

Subversion 설치 (Windows, Binary : VisualSVN)  (0) 2013.09.14
Subversion 설치 (Windows, BitNami)  (0) 2013.09.09
Subversion 설치 (Ubuntu, SourceCode)  (0) 2013.09.05


솔직히 Ubuntu 환경에서 Subversion을 설치하는 방법은 너무 쉽다.

$ sudo apt-get install subversion


딱 한 줄의 명령어면 해결이 된다.

하지만, 개인적인 취향으로...
그리고 서버로 운영을 할 것이라면 공부 좀 하면서 SourceCode로 설치하는 것이 좋다고 생각한다.


그러면 해보자 !!!

우선 필요한 것은 빌드에 필요한 밑밥깔기~ 

$ sudo apt-get build-dep subversion

패키지 목록을 읽는 중입니다... 완료
의존성 트리를 만드는 중입니다      
상태 정보를 읽는 중입니다... 완료
다음 새 패키지를 설치할 것입니다:
  apache2-threaded-dev apache2-utils apache2.2-bin apache2.2-common autoconf automoc
  autotools-dev build-essential ca-certificates-java comerr-dev debhelper default-jdk
  default-jre default-jre-headless dh-apparmor diffstat docbook-xml docbook-xsl doxygen
  dpkg-dev g++ g++-4.6 gettext html2text intltool-debian java-common junit kdelibs-bin
  kdelibs5-dev kdoctools krb5-multidev libapr1 libapr1-dev libaprutil1
  libaprutil1-dbd-sqlite3 libaprutil1-dev libaprutil1-ldap libatk-wrapper-java
  libatk-wrapper-java-jni libattica0.3 libclucene0ldbl libdb4.8 libdb4.8-dev
  libdbus-1-dev libdlrestrictions1 libdpkg-perl libexpat1-dev libgcrypt11-dev
  libgettextpo0 libgif4 libglib2.0-dev libgnome-keyring-dev libgnutls-dev
  libgnutls-openssl27 libgnutlsxx27 libgpg-error-dev libgssrpc4 libkadm5clnt-mit8
  libkadm5srv-mit8 libkcmutils4 libkdb5-6 libkde3support4 libkdeclarative5 libkdecore5
  libkdesu5 libkdeui5 libkdewebkit5 libkdnssd4 libkemoticons4 libkfile4 libkhtml5
  libkidletime4 libkimproxy4 libkio5 libkjsapi4 libkjsembed4 libkmediaplayer4
  libknewstuff2-4 libknewstuff3-4 libknotifyconfig4 libkntlm4 libkparts4
  libkprintutils4 libkpty4 libkrb5-dev libkrosscore4 libkrossui4 libktexteditor4
  libkunitconversion4 libkutils4 libldap2-dev libmysqlclient-dev libmysqlclient18
  libneon27-gnutls-dev libnepomuk4 libnepomukquery4a libnepomukutils4 libnss3-1d
  libp11-kit-dev libpcre3-dev libpcrecpp0 libperl-dev libphonon-dev libphonon4
  libplasma3 libpq-dev libpq5 libqca2 libqt4-designer libqt4-dev libqt4-help
  libqt4-qt3support libqt4-scripttools libqt4-test libqtwebkit4 libreadline5 libruby1.8
  libsasl2-dev libserf-dev libserf1 libsolid4 libsoprano-dev libsoprano4 libsqlite3-dev
  libssl-dev libstdc++6-4.6-dev libstreamanalyzer0 libstreams0 libtasn1-3-dev
  libthreadweaver4 libtimedate-perl libtool libunistring0 libvirtodbc0 libxml2-dev
  libxml2-utils libxss1 m4 mysql-common odbcinst odbcinst1debian2 openjdk-6-jdk
  openjdk-6-jre openjdk-6-jre-headless openjdk-6-jre-lib phonon-backend-null po-debconf
  python-all python-all-dbg python-all-dev python-dbg python-dev python2.7-dbg
  python2.7-dev qt4-linguist-tools qt4-qmake quilt ruby1.8 ruby1.8-dev sgml-data
  soprano-daemon swig swig2.0 tzdata-java uuid-dev virtuoso-opensource-6.1-common
  zlib1g-dev
0개 업그레이드, 167개 새로 설치, 0개 제거 및 0개 업그레이드 안 함.
154 M바이트 아카이브를 받아야 합니다.
이 작업 후 486 M바이트의 디스크 공간을 더 사용하게 됩니다.
계속 하시겠습니까 [Y/n]?


뭔가 정말 많이도 설치한다.
무려 167개...!? (물론 각자 상황에 따라 틀릴 것이다)


소스코드를 다운로드 받아서 진행을 해보자.


2013.09.04 현재 가장 최신 버전은 1.8.3 이다.

$ tar zxvf subversion-1.8.3.tar.gz

$ cd subversion-1.8.3/


압축 풀고... 이제 본격적으로 진행하면 된다.

$ ./get-deps.sh
Local directory 'zlib' already exists; the downloaded copy won't be used
Local directory 'serf' already exists; the downloaded copy won't be used
Local directory 'sqlite-amalgamation' already exists; the downloaded copy won't be used
Local directory 'apr' already exists; the downloaded copy won't be used
Local directory 'apr-util' already exists; the downloaded copy won't be used

If you require mod_dav_svn, the recommended version of httpd is:
   http://archive.apache.org/dist/httpd/httpd-2.4.6.tar.bz2

If you require apr-iconv, its recommended version is:
   http://archive.apache.org/dist/apr/apr-iconv-1.2.1.tar.bz2


Subversion과 같이 빌드가 될 다양한 dependency 관계에 있는 모듈들을 미리 점검하는 과정이다.

위의 메시지처럼 같이 빌드할 수 있는 모듈 중 현재 없는 것을 알려주는 경우,
필요하면 설치를 해주고 필요없다면 그냥 무시해도 Subversion 빌드는 진행할 수 있다.

$ cd apr/
$ ./buildconf
$ cd ..


$ cd apr-util/
$ ./buildconf
$ cd ..


$ cd apr-util/xml/expat/
$ ./buildconf.sh
$ cd ../../..


$ ./autogen.sh

$ ./configure

$ make

$ make check

$ sudo make install


설치는 이렇게만 하면 끝이다 !!!

반응형

형상관리 도구를 사용해야 하는 환경에서 종종 문의가 들어오는 내용 중 하나가 바로 IDE 지원 여부이다.
특히 개발자가 가장 많이 사용하는 IDE 라고 하면, MS Visual Studio와 Eclipse를 꼽을 수 있다.

Eclipse 환경에서는 EGit plugin을 사용하면 되고...
   - 참고 : http://whatwant.tistory.com/412

MS Visual Studio 환경에서는 최근 Microsoft 에서 공식 지원을 해주고 있다.
사실 필자는 Visual Studio를 거의 사용하지 않기에 이렇게 지원을 하고 있는지 전혀 모르고 있었다.


Visual Studio Tools for Git

   [ Requirements ]
      ▷ Visual Studio 2012
      ▷ Visual Studio 2012 Update 3

   [ Link ]
      ▷ http://visualstudiogallery.msdn.microsoft.com/abafc7d6-dcaa-40f4-8a5e-d6724bdb980c

   [ Screenshot ]



그런데, 이것 말고도 또 있긴 하다.

Git Source Control Provider
   - http://visualstudiogallery.msdn.microsoft.com/63a7e40d-4d71-4fbb-a23b-d262124b8f4c


사실 이런 도우미들을 사용할 필요 없이 그냥 윈도우즈 환경에서 Git을 설치해서 사용해도 큰 불편함이 없을거라 생각한다.
   - http://git-scm.com/downloads



나중에 기회가 되면 Visual Studio를 설치해서 테스트해보도록 하겠다~ (난 gcc가 좋은데... ㅠㅠ)
반응형

+ Recent posts