<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    空間站

    北極心空

      BlogJava :: 首頁 :: 聯系 :: 聚合  :: 管理
      15 Posts :: 393 Stories :: 160 Comments :: 0 Trackbacks
    翻譯整理: PCplayer

    關鍵詞:subversion 安裝 服務器 配置 apache ssl
    最后更新:2007-8-19
    版本:v1.0

    修改歷史:
    v0.1 2006-08-06
    v0.2 2006-09-10 加入ssl的配置
    v0.21 2006-09-13 修正2.3配置中一個錯誤(由blair1978 報告)
    v0.23 2006-09-26 在附件1中添加兩個必要文件,不然無法創建SSL證書
                             修正一個創建證書的命令錯誤
    v0.26 2006-10-16 更新mod_ssl_etc.rar(openssl必需軟件包)中的mod_ssl.so,由sunbeam在
                              http://bbs.iusesvn.com/thread-418-1-1.html提供
    v1.0 2007-8-19 告知已支持Apache2.2.4

    轉載請注意原文出處、版本、作者(譯者)http://bbs.iusesvn.com/thread-158-1-1.html
    --------------------------------------------------------------------------------

    1. 引言
    2. 安裝過程
    2.1. 安裝Apache
    2.2. 安裝Subversion
    2.3. 配置
    2.4. 使用SSL來保護你的服務

    摘要

    本文是TortoiseSVN1.3.5幫助中關于配置服務器一節的翻譯,根據行文需要做了一些調整與增減。英文原文參見TortoiseSVN1.3.5幫助的3.1. Apache Based Server。

    要使用TortoiseSVN(或者其它的Subversion客戶端),你要有一個存放版本庫的地方。你可以將版本庫存放在本機,使用file://協議來訪問,也可以將它們放在一個服務器上,使用http://或svn://協議來訪問。兩種服務器協議(http://和svn://)也可以被加密成https://及svn+ssh://。下面將一步一步地為你展示如何在windows上配置這樣一個服務器。

    如果你沒有服務器或者你只想單獨地工作,那么將版本庫存放在本機并使用file://協議來訪問是你最好的選擇,這樣的話,你可以略過本文。

    注:目前windows下的subversion有專門的for apache2.2.x版本,可以跟Apache2.2.x配合,不過本文所帶的附件只在Apache2.0.x上測試過

    1. 引言
    在所有的Subversion服務器配置方式中,基于Apache的是最靈活的。雖然配置起來有一點點復雜,但是它提供了其它方式所沒有的好處:
    引用:
    WebDAV
    基于Apache配置的Subversion服務器使用了被許多其它程序支持的WebDAV協議。舉個例子,你可以在Windows的資源管理器中將這樣的一個版本庫掛載成一個“Webfolder”,然后像文件系統中的其它文件夾一樣訪問它。

    瀏覽版本庫
    你可以在不安裝Subversion客戶端的情況下,使用瀏覽器來瀏覽版本庫中的內容。這將使得更大范圍的用戶可以訪問你的數據。

    用戶驗證
    你可以使用任何Apache支持的驗證機制,包括SSPI和LDAP。

    安全
    Apache是非常的穩定和安全,因此你的版本庫自然而然地擁有同樣的安全性。包括SSL加密。
    2. 安裝過程
    2.1. 安裝Apache
    安裝Apache前,你要有一臺運行Windows2000、Windows XP + sp1或Windows2003的電腦。

    警告:請注意,沒安裝Service Pack 1的Windows XP將導致錯誤的網絡數據從而破壞你的版本庫!

    http://httpd.apache.org/download.cgi 最新版本的Apache Web服務器。確保你下載的版本大于2.0.54。2.0.54版本的Apache將不能與Subversion 1.3.xx配合工作。而且,小于2.0.54的Apache也因為在windows上的編譯存在一個bug而導致不能與subversion1.2配合使用。

    一旦你已經有了Apache2的安裝程序,你可以雙擊它,它將引導你完成整個安裝過程。請確保你輸入正確的服務器URL(如果你的服務器沒有DNS名稱,你可以直接輸入IP地址)。我建議你將Apache安裝成 for all Users,on Port 80,as a service。注意:如果你已經有一個IIS或者其它的程序使用80端口,安裝可能會失敗。如果是這樣,你可以到程序目錄下的Apache Group\Apache2\conf目錄中找到文件httpd.conf,將其中的Listen 80改成一個不用的端口,比如Listen 81。然后重新運行這個安裝程序,這次應該不會再有問題了。

    現在你可以在你的瀏覽器中鍵入 http://loccalhost,如果呈現了一個已經配置好的網站,那么你的Apache就安裝成功了。

    警告

    如果你將Apache安裝成一個服務,它將以本地system帳戶來運行。為Apache創建一個單獨的用戶來運行它將會更安全一些。

    請確保運行Apache的用戶有版本庫的完全訪問權限(右鍵版本庫目錄->屬性->安全)。要不然,用戶將無法提交他們的更改。

    就算Apache以本機system來運行,你也要設置它能完全讀寫版本庫目錄。

    如果沒有為Apache配置這個許可,用戶將會得到"禁止訪問"的錯誤信息,在Apache的錯誤日志中表現為錯誤500。

    2.2. 安裝Subversion
    http://subversion.tigris.org/ser ... entList?folderID=91 (英文)

    http://bbs.iusesvn.com/forum-7-1.html中文)下載最新版本的Subversion。

    運行Subversion安裝程序,如果安裝程序能夠識別你已經安裝了Apache,那么你的安裝基本上就OK了。如果它不能,那么你要做一些額外的步驟。
    注:如果你先安裝Apache,再安裝Subversion,正常情況下下面的工作(2.3配置前)Subversion安裝程序已經幫你完成了
    使用資源管理器,進入Sibversion的安裝目錄(通常為c:\program files\Subversion),找到文件httpd/mod_dav_svn.so和mod_authz_svn.so,將它們拷貝到Apache的modules目錄(通常為c:\program files\apache group\apache2\modules)。

    從Subversion的安裝目錄拷貝文件libdb43.dll到Apache的modules目錄。

    使用如記事本之類的文本編輯器編輯Apache的配置文件(通常為c:\program files\apache group\apache2\conf\httd.conf),修改以下內容:

    去掉以下行的注釋(將開頭的#刪除):
    復制內容到剪貼板
    代碼:
    #LoadModule dav_fs_module modules/mod_dav_fs.so
    #LoadModule dav_module modules/mod_dav.so
    在LoadModule節的最后添加以下兩行:
    復制內容到剪貼板
    代碼:
    LoadModule dav_svn_module modules/mod_dav_svn.so
    LoadModule authz_svn_module modules/mod_authz_svn.so
    2.3. 配置
    現在,你已經安裝了Apache和Subversion,但是Apache還不知道如果處理像TortoiseSVN一樣的Subversion客戶端。要讓Apache知道哪個URL將被Subversion使用,你要像下面這樣編輯Apache的配置文件(通常在c:\program files\apache group\apache2\conf\httpd.conf):

    在配置文件的最后添加下面這些行:
    復制內容到剪貼板
    代碼:
    <Location /svn>
    DAV svn
    SVNParentPath D:\SVN
    AuthType Basic
    AuthName "Subversion repositories"
    AuthUserFile D:\passwd
    #AuthzSVNAccessFile D:\svnaccessfile
    Require valid-user
    </Location>
    這樣配置表示:你所有的版本庫將位于D:\SVN目錄下,要訪問你的版本庫可以使用這樣的URL:http://MyServer/svn/,訪問權限將由passwd文件中的用戶名/密碼來限制。

    要創建passwd文件,可以打開命令行(DOS窗口),將當前目錄切換到apache2目錄(通常為c:\program files\apache group\apache2),然后打入以下命令以創建文件:
    復制內容到剪貼板
    代碼:
    bin\htpasswd -c passwd <username>
    此命令執行bin目錄下的htpasswd.exe來創建一個密碼文件,重啟Apache服務。

    將你的瀏覽器指向http://MyServer/svn/MyNewRepository(MyNewRepository是你之前創建的Subversion版本庫)。如果一切正常,你將被提示輸入用戶名密碼,輸入正確的用戶名密碼后你就可以看到版本庫中的內容了。

    對你剛剛輸入的apache配置作一些簡短的說明:
    引用:
    <Location /svn>

    意味著可以通過像這樣的URL(http://MyServer/svn)來訪問Subversion版本庫

    DAV svn

    告訴Apache哪個模塊負責服務像那樣的URL--在這里就是Subversion模塊

    SVNListParentPath on

    在Subversion 1.3及更高版本中,這個指示器使得Subversion列出由SVNParentPath指定的目錄下所有的版本庫

    SVNParentPath D:\SVN

    告訴Subversion在目錄D:\SVN下尋找版本庫

    AuthType Basic

    啟用基本的驗證,比如用戶名/密碼對

    AuthName "Subversion repositories"

    當一個驗證對話框彈出時,告訴用戶這個驗證是用來做什么的

    AuthUserFile D:\passwd

    指定D:\passwd用為密碼文件用來驗證用戶的用戶名及密碼

    AuthzSVNAccessFile D:\svnaccessfile

    指定D:\svnaccessfile來限定各個用戶或組在版本庫中目錄的訪問權限

    Require valid-user

    限定用戶只有輸入正確的用戶名及密碼后才能訪問這個路徑
    ----------------------------------------

    上面的配置僅僅是一個簡單的示例。你還可以對Apache進行許許多多的配置。

    1如果你想讓所有用戶對版本庫都有讀的權限而只有特定的用戶才有寫的權限,你可以將這行
    復制內容到剪貼板
    代碼:
    Require valid-user
    改為
    復制內容到剪貼板
    代碼:
    <LimitExcept GET PROPFIND OPTIONS REPORT>
    Require valid-user
    </LimitExcept>
    2上面的配置使用了passwd文件將你所有的版本庫作為一個單元來限定訪問權限。如果你想獲得更多的控制,如限定某個用戶可以訪問版本庫中的哪個目錄,可以把下面這行的#去掉:
    復制內容到剪貼板
    代碼:
    #AuthzSVNAccessFile D:\svnaccessfile
    然后用文本編輯器創建一個Subversion授權文件。Apache將確保只有有效的用戶可以訪問你的/svn位置,然后將用戶名傳到AuthzSVNAccessFile模塊,這樣可以依據Subversion授權文件得到更精細的權限控制。注意,路徑將被指定為[庫:路徑]或者簡單的[路徑]。如果你不明確指定一個庫,訪問規則將應用到由SVNParentPath指定的目錄下所有的版本庫中。一個授權文件例子可能像這樣:
    復制內容到剪貼板
    代碼:
    [groups]
    admin = john, kate
    devteam1 = john, rachel, sally
    devteam2 = kate, peter, mark
    docs = bob, jane, mike
    training = zak

    # 為所有庫指定默認訪問規則
    # 所有人可以讀,管理員可以寫,危險分子沒有任何權限
    [/]
    * = r
    @admin = rw
    dangerman =

    # 允許開發人員可以完全訪問他們的項目版本庫
    [proj1:/]
    @devteam1 = rw
    [proj2:/]
    @devteam2 = rw
    [bigproj:/]
    @devteam1 = rw
    @devteam2 = rw
    trevor = rw

    # 文檔編寫人員對所有的docs目錄有寫權限
    [/trunk/doc]
    @docs = rw

    # 培訓人員可以完全訪問培訓版本庫
    [TrainingRepos:/]
    @training = rw
    2.4. 使用SSL來保護你的服務器
    以上的工作已經可以讓你的svn服務器正常工作了。
    如果你要更安全一些,可以配置ssl來保護你的服務器。
    因為美國出口限制,默認安裝的Apache服務器不支持SSL。但是你自己可以很容易地在其它地方下載到所需要的模塊,然后安裝它。

    首先你需要SSL的必需文件。你可以http://hunter.campbus.com/ 或這里找到相應的軟件包(或者下載本主題的附件1: mod_ssl_etc.rar (595.45 KB) )。然后只要將包解開將其中的mod_ssl.so拷到Apache的modules目錄、openssl.exe、libeay32.dll、ssleay32.dll拷到bin目錄、conf/ssl.conf拷到conf目錄。

    在Apache的conf目錄中用文本編輯器打開ssl.conf。

    將下面這些行用#注釋掉:
    復制內容到剪貼板
    代碼:
    DocumentRoot "c:/apache/htdocs"
    ServerName [url]www.example.com:443[/url]
    ServerAdmin [email]you@example.com[/email]
    ErrorLog logs/error_log
    TransferLog logs/access_log
    修改
    復制內容到剪貼板
    代碼:
    SSLCertificateFile conf/ssl.crt/server.crt
    復制內容到剪貼板
    代碼:
    SSLCertificateFile conf/ssl/my-server.cert
    修改
    復制內容到剪貼板
    代碼:
    SSLCertificateKeyFile conf/ssl.key/server.key
    復制內容到剪貼板
    代碼:
    SSLCertificateKeyFile conf/ssl/my-server.key
    修改
    復制內容到剪貼板
    代碼:
    SSLMutex file:logs/ssl_mutex
    復制內容到剪貼板
    代碼:
    SSLMutex default
    刪除以下兩行(如果有):
    復制內容到剪貼板
    代碼:
    <IfDefine SSL>
    </IfDefine>
    打開Apache配置文件(httpd.conf),去掉這行的注釋
    復制內容到剪貼板
    代碼:
    #LoadModule ssl_module modules/mod_ssl.so
    Openssl需要一個配置文件。你可以從這里下載一個可工作的版本http://tud.at/programm/openssl.cnf (或者本主題附件2: openssl.cnf.rar (1.21 KB) )。將它保存到bin/openssl.cnf。

    下面你要創建一個SSL證書。你可以打開一個命令行窗口,然后cd到Apache安裝目錄(比如C:\program files\apache group\apache2),敲入以下命令:
    復制內容到剪貼板
    代碼:
    bin\openssl req -config bin\openssl.cnf -new -out my-server.csr
    你將被問及一句口令短語。請注意,不要使用簡單的幾個詞,而應該輸入一整個句子,比如一篇詩詞的一部份,越長越好。同樣,你還要輸入你的服務器URL。然后其它的問題都是可選問答的,不過我建議你也將它們填充。

    下一步,敲入以下命令:
    復制內容到剪貼板
    代碼:
    bin\openssl rsa -in privkey.pem -out my-server.key
    以及(注意,只有一行)
    復制內容到剪貼板
    代碼:
    bin\openssl x509 -in my-server.csr -out my-server.cert -req -signkey my-server.key -days 4000
    這樣將創建一個4000天后才過期的證書。最后敲入:
    復制內容到剪貼板
    代碼:
    bin\openssl x509 -in my-server.cert -out my-server.der.crt -outform DER
    這些命令在Apache目錄下創建了一些文件(my-server.der.crt, my-server.csr, my-server.key, .rnd, privkey.pem, my-server.cert)。將這些文件拷貝到目錄conf/ssl

    (比如C:\program files\apache group\apache2\conf\ssl),如果目錄ssl不存在,你必須先創建一個。

    重啟Apache服務。

    現在可以用類似這樣的url來訪問你的版本庫了https://servername/svn/project
    引用:
    強制通過SSL來訪問

    當你配置了SSL來提高版本庫安全時,你可能想禁用無SSL的http訪問方式,而只允許通過https訪問。要達到這種效果,你要在<Location>塊加入另外一個指示器SSLRequireSSL。

    一個示例<Location>塊可能像這樣:

    <Location /svn>

    DAV svn

    SVNParentPath D:\SVN

    SSLRequireSSL

    AuthType Basic

    AuthName "Subversion repositories"

    AuthUserFile passwd

    #AuthzSVNAccessFile svnaccessfile

    Require valid-user

    </Location>

    基于Apache的svn服務器的多庫單庫

    以上介紹的配置為Apache多庫方式,即一個location可以同時為多個版本庫服務,
    假設你的ip為192.168.0.1,在D:\SVN目錄下建了兩個版本庫,proj1和proj2
    可以分別用下面兩個url來訪問你的版本庫
    復制內容到剪貼板
    代碼:
    [url]http://192.168.0.1/svn/proj1[/url]
    復制內容到剪貼板
    代碼:
    http://192.168.0.1/svn/proj1
    此時權限文件類似于這樣
    復制內容到剪貼板
    代碼:
    [groups]
    admin=user1
    dev=user2

    [proj1:/]
    @admin=rw
    @doc=r

    [proj2:/]
    @admin=rw
    @doc=r
    還有一種配置方式為Apache單庫方式,即一個location只能為一個版本庫服務,
    配置時只要將上面的SVNParentPath改為SVNPath,同時將后面的路徑由版本庫的父目錄改為版本庫的目錄
    如:
    復制內容到剪貼板
    代碼:
    <Location /svn>
    DAV svn
    SVNPath D:\SVN\proj1
    AuthType Basic
    AuthName "Subversion repositories"
    AuthUserFile D:\passwd
    #AuthzSVNAccessFile D:\svnaccessfile
    Require valid-user
    </Location>
    這時,可以用下面的URL來訪問版本庫proj1
    復制內容到剪貼板
    代碼:
    http://192.168.0.1/svn
    權限文件可能是
    復制內容到剪貼板
    代碼:
    [groups]
    admin=user1
    dev=user2
    [/]
    @admin=rw
    @doc=r
    關于單庫多庫的權限配置區別,也可以參考這個文章以加深理解
    http://www.iusesvn.com/bbs/thread-157-1-1.html
    posted on 2008-09-04 10:33 蘆葦 閱讀(829) 評論(0)  編輯  收藏 所屬分類: 其他
    主站蜘蛛池模板: 亚洲最大AV网站在线观看| 亚洲AV无码一区二区二三区入口| 美女被免费网站91色| 亚洲午夜电影一区二区三区| 97在线观免费视频观看| 亚洲天堂男人影院| 国产精品成人无码免费| 黄页免费视频播放在线播放| 亚洲精品中文字幕无乱码麻豆| 亚洲色婷婷综合久久| 亚洲国产精品尤物YW在线观看| 麻豆国产人免费人成免费视频 | 成人免费一区二区无码视频| 久久99热精品免费观看牛牛| a毛片成人免费全部播放| 美女被羞羞网站免费下载| 亚洲一本一道一区二区三区| 亚洲一区二区三区免费在线观看| 亚洲免费在线视频| 亚洲av永久无码精品古装片| 亚洲综合另类小说色区| 亚洲人妻av伦理| 亚洲&#228;v永久无码精品天堂久久 | 青青草97国产精品免费观看| 亚洲日韩AV一区二区三区中文| 亚洲国产成a人v在线观看 | 99久久国产免费-99久久国产免费| 成人影片一区免费观看| a级毛片毛片免费观看久潮| 大妹子影视剧在线观看全集免费| 一级毛片视频免费| 波霸在线精品视频免费观看| 色播在线永久免费视频网站| 中国在线观看免费的www| 中文字幕免费不卡二区| 免费A级毛片无码视频| 精品国产污污免费网站aⅴ| 久久经典免费视频| 免费A级毛片无码免费视| 色www永久免费视频| 亚洲国产高清精品线久久|