LINUX搭建SVN用戶端和多重專案的許可權分組管理

來源:互聯網
上載者:User

標籤:des   style   blog   http   color   io   os   使用   ar   

搭建SVN服務,有效管理代碼,以下三步可以快速搞定。
1、安裝

#yum install subversion

判斷是否安裝成功

1 #subversion -v

svnserve, version 1.6.11 (r934486)
出現上面的提示,說明安裝成功。

如果提示如下:-bash: subversion: command not found
經過尋找發現:
[[email protected]]# svnserve –version
svnserve, version 1.6.11 (r934486)
compiled Apr 11 2013, 16:13:51

Copyright (C) 2000-2009 CollabNet.
Subversion is open source software, see http://subversion.tigris.org/
This product includes software developed by CollabNet (http://www.Collab.Net/).

The following repository back-end (FS) modules are available:

* fs_base : Module for working with a Berkeley DB repository.
* fs_fs : Module for working with a plain file (FSFS) repository.

Cyrus SASL authentication is available.

有了SVN軟體後還需要建立SVN庫。

1 #mkdir /opt/svn/repos
2 #svnadmin create /opt/svn/repos

執行上面的命令後,自動在repos下建立多個檔案, 分別是conf, db,format,hooks, locks, README.txt。

2、配置

上面的操作很簡單,幾個命令就搞定, 下面的操作也不難。
進入上面產生的檔案夾conf下,進行配置, 有以下幾個檔案authz, passwd, svnserve.conf
其中authz 是許可權控制,可以設定哪些使用者可以訪問哪些目錄, passwd是設定使用者和密碼的, svnserve是設定svn相關的操作。

2.1先設定passwd

[users]
# harry = harryssecret
# sally = sallyssecret
hello=123
使用者名稱=密碼

這樣我們就建立了hello使用者, 123密碼

2.2 再設定許可權authz

[/]
hello= rw

意思是hello使用者對所有的目錄有讀寫權限,當然也可以限定。
如果是自己用,就直接是讀寫吧。

2.3最後設定snvserv.conf

1 anon-access = none # 使非授權使用者無法訪問
2 auth-access = write # 使授權使用者有寫入權限
3 password-db = password
4 authz-db = authz   # 存取控制檔案
5 realm = /opt/svn/repos # 認證命名空間,subversion會在認證提示裡顯示,並且作為憑證緩衝的關鍵字。

採用預設配置. 以上語句都必須頂格寫, 左側不能留空格, 否則會出錯.

好了,通過以上配置,你的svn就可以了。

3、串連

啟動svn:

1 svnserve -d -r /opt/svn/repos

如果已經有svn在運行,可以換一個連接埠運行

1 svnserve -d -r /opt/svn/repos --listen-port 3391

這樣同一台伺服器可以運行多個svnserver

好了,啟動成功後,就可以使用了。
建議採用TortoiseSVN, 串連地址為: svn://your server address (如果指定連接埠需要添加連接埠 :連接埠號碼)

串連後可以上傳本地的檔案,有效管理你的代碼。

通過以上三步,可以快速的搭建起svn, 開啟你的項目吧,如果您覺得有用,請留言,謝謝您的支援。
轉載請著名來自(公用資訊服務網), 謝謝!

——————————————-華麗的分割線————————————————————————————————
一 需求
程式開發伺服器搭建好SVN伺服器,不可能只管理一個工程項目,如何做到不在一個項目中的開發人員不能訪問其它項目中的代碼,做好技術保密工作。
代碼倉庫有三個倉庫:project1,project2,project3
假設人員有6個人:eg1,eg2,eg3,eg4,eg5,eg6
eg1,eg2,只能訪問project1;
eg3,eg4,只能訪問project2;
eg5,eg6,只能訪問project3;

二 實現
在你的倉庫路徑下:假如是/home/sv
cd /home/svn
//建立三個代碼倉庫
svnadmin create project1
svnadmin create project2
svnadmin create project3
//把兩個許可權設定檔複製到SVN
//根路徑下,統一管理所有代碼倉庫
cd/projcet1/conf
cp authz passwd /home/svn
//開啟設定檔
vi svnserve.conf

修改成如下:
anon-access = none //禁止匿名訪問
auth-access = write
password-db = /home/svn/passwd //統一使用密碼檔案
authz-db = /home/svn/authz
realm = project1 //許可權網域名稱,很重要,寫你的工程名

分別修改project2的svnserve.conf
和上面一樣,最後一行分別寫
anon-access = none //禁止匿名訪問
auth-access = write
password-db = /home/svn/passwd //統一使用密碼檔案
authz-db = /home/svn/authz
realm = project2 //許可權網域名稱,很重要,寫你的工程名

分別修改project3的svnserve.conf
和上面一樣,最後一行分別寫
anon-access = none //禁止匿名訪問
auth-access = write
password-db = /home/svn/passwd //統一使用密碼檔案
authz-db = /home/svn/authz
realm = project3 //許可權網域名稱,很重要,寫你的工程名

修改兩個許可權管理檔案:
passwd
//使用者名稱 = 密碼
[users]
eg1 = 123
eg2 = 123
eg3 = 123
eg4 = 123
eg5 = 123
eg6 = 123

authz
[groups] //分組
admin = eg1,eg2
guest = eg3,eg4
guset1 = eg5,eg6
[/] //管理者擁有所有讀寫權限
* =
@admin = rw
[project1:/] //工程1的存取控制,guest1,2無法訪問
@admin = rw

eg1 = rw
eg2 = rw
[project2:/]
@guest = rw

eg3 = rw
eg4 = rw
[project3:/]
@guest1 = rw

eg5 = rw
eg6 = rw

三 重啟
svnserve -d -r /home/svn

停止命令
killall svnserve

實際測試:
各個群組成員只能訪問自己的項目,無許可權查看別人的項目
只有管理員才能查看所有項目工程

LINUX搭建SVN用戶端和多重專案的許可權分組管理

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.