Git是一個由林納斯•托瓦茲為了更好地管理linux內核開發而創立的分布式版本控制/軟件配置管理軟件。與常用的版本控制工具 CVS, Subversion 等不同,它采用了分布式版本庫的方式,不必服務器端軟件支持,使源代碼的發布和交流極其方便。 Git 的速度很快,這對於諸如 Linux kernel 這樣的大項目來說自然很重要。 Git 最為出色的是它的合並跟蹤(merge tracing)能力。
1、在FreeBSD8.1下安裝Git服務器
(1)用ports安裝Git
cd /usr/ports/devel/gitmake install clean
(2)修改/etc/rc.conf,讓git隨開機啟動
git_daemon_enable=”YES”
(3)新增使用者git
pw useradd git
(4)啟用git daemon
/usr/local/etc/rc.d/git_daemon start
(5)用sockstat 來驗證git是否啟動
sockstt -4l | grep 9418root git-daemon 37064 3 tcp4 192.168.21.248:9418 *:*
2、如何導入一個新的Git項目
(1)首先把自己介紹給git系統,比如自己的姓名和email地址,命令如下:
git config--global user.name "Andrew.yu"git config--global user.email " [email protected]"
(2)提交我的目錄/home/andrewyu/test進Git項目庫
cd /home/andrewy/test/git initgit add .git commit
(3)這時候 大家可觀察我們的/home/andrewy/test的目錄
[root@research_jail ~/project]# ls -lsarttotal 82 -rw-r--r-- 1 root wheel 18 Apr 7 07:42 30 -rw-r--r-- 1 root wheel 0 Apr 7 07:42 20 -rw-r--r-- 1 root wheel 0 Apr 7 07:42 12 drwxr-xr-x 8 root wheel 512 Apr 7 07:42 .git2 drwxr-xr-x 3 root wheel 512 Apr 7 07:43 .2 drwxr-xr-x 4 root wheel 512 Apr 7 07:43 ..
Git init命令可用於初始化當前所在目錄的這個項目,shell返回的提示表明已經建立了一個.git隱藏目錄來保存這個項目前的進展信息。
3、Git命令行操作
查看源代碼和快照的區別
git diff
查看快照和倉庫的區別
git diff --cached
查看整體改動的信息
git status
告訴git我修改了hello.py文件,請檢查下(GIT中無論修改還是增加新文件均使用add進行登記)
git add hello.py
提交到git
git commit
查看日志
git log
只回退commit的信息,但index file(就是臨時存儲區域)和修改的代碼仍然在
git reset --soft HEAD
不僅回退commit的信息,代碼也恢復到修改前的版本
git reset --hard HEAD
回退commit和index file的信息,保留代碼的修改
git reset --mixed HEAD
默認情況等同於mixed
git reset HEAD
從index file中刪除一個已經登記的文件
git reset -- a.py
創建branch-a分支
git branch branch-a
切換到branch-a分支
git checkout branch-a
將分支合並到主干(如果有沖突會提示沖突的地方,修改後再合並)
git merge branch-a
分支內容合並到主干後刪除branch-a分支
git branch -d branch-a
不論分支內容是否合並到主干,均刪除branch-a分支
git branch -D branch-a
克隆hello-git到hello-git2中
git clone /home/flynewton/hello-git hello-git2cd hello-git2
==========================================================
(1)修改hello-git2中的源代碼並提交
(2)創建分支branch-b,並修改分支中的源碼並提交
(3)進入hello-git文件夾中
==========================================================
將hello-git2主干代碼作為本地的新分支hello2-works
git fetch /home/flynewton/hello-git2 master:hello2-works
查看本地主干和hello2-works分支的差異
git -p master..hello2-works
合並hello-git2的主干到本地
git pull /home/flynewton/hello-git2 master
合並hello-git2的分支到主干
git pull /home/flynewton/hello-git2 branch-b
在公司的開發環境中,主要是用SVN來用作版本管理,Git目前處於測試階段,感覺它用來添加項目的子目錄不是特別理想,另外,分支合並時產生的Merge問題也讓人很煩燥,相反,SVN在這些方面都做得很好;我建議大家目前以SVN為主,Git為輔來進行我們的代碼管理工作。