青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

大龍的博客

常用鏈接

統(tǒng)計

最新評論

CVS服務(wù)器設(shè)置指南

     Red Hat Linux 8.0和9.0上測試通過。

服務(wù)器的安裝略過不提,因為安裝了開發(fā)工具的話默認(rèn)就已經(jīng)有了CVS。就算沒有,更新軟件包就可以搞定,除非你一定要安裝最新版本。

1.首先創(chuàng)建用于CVS的組和用戶:

代碼:
#groupadd cvs
#useradd cvsroot -g cvs
#passwd cvsroot


OK,用戶已經(jīng)建立好了,cvsroot就是我們做CVS操作使用的。

2.修改配置文件

代碼:
#more /etc/services | grep cvspserver


看看是否有

代碼:
cvspserver 2401/tcp #CVS client/server operations
cvspserver 2401/udp #CVS client/server operations


這2行。系統(tǒng)自帶了CVS時,這2行也已經(jīng)有了,只需要確認(rèn)一下。如果沒有,請自己加上去。
然后必須創(chuàng)建啟動腳本:

代碼:
#vi /etc/xinet.d/cvspserver


內(nèi)容如下

代碼:
service cvspserver
{
disable = no
flags = REUSE
socket_type = stream
wait = no
user = root
server = /usr/bin/cvs
server_args = -f --allow-root=/home/cvsroot pserver
log_on_success += USERID
log_on_failure += USERID
}


其中server指定CVS可執(zhí)行文件路徑,默認(rèn)安裝就是/usr/bin/cvs。server_args指定源代碼庫路徑及認(rèn)證方式等,例子中把源代碼存放在cvsroot的主目錄中,也可以另外指定路徑,但必須注意權(quán)限設(shè)置,pserver是密碼認(rèn)證方式,這種方式的安全性要差一些,但操作起來比較簡單。請注意每行等號左右都有一個空格,否則無法啟動服務(wù)。

3.初始化CVS
切換到cvsroot用戶,然后進行初始化:

代碼:
#cvs -d /home/cvsroot init


這個路徑應(yīng)該與cvspserver文件中指定的路徑相同,初始化后會在此路徑下面創(chuàng)建CVSROOT目錄,存放用于CVS管理的一些文件。此時重新啟動xinetd服務(wù),CVS服務(wù)器應(yīng)該能夠啟動了。

代碼:
#service xinetd restart


當(dāng)然,重新啟動計算機也可以。確認(rèn)是否啟動:

代碼:
#netstat -l | grep cvspserver


如果能看到

代碼:
tcp 0 0 *:cvspserver *:* LISTEN


說明已經(jīng)正常啟動,沒有的話請重新檢查配置過程是否有錯誤或者遺漏。最后還必須檢查防火墻的設(shè)置,把2401端口打開。

4.用戶管理
CVS默認(rèn)使用系統(tǒng)用戶登錄,為了系統(tǒng)安全性的考慮也可以使用獨立的用戶管理。CVS用戶名和密碼保存在CVSROOT目錄下的passwd文件中,格式為:

代碼:
用戶名:密碼:系統(tǒng)用戶


也就是說,它把CVS用戶映射到系統(tǒng)用戶,這樣我們就可以通過系統(tǒng)用戶的權(quán)限設(shè)置來分配給用戶不同的權(quán)限,而不需要讓用戶知道系統(tǒng)用戶名和密碼。
passwd文件默認(rèn)并不存在,我們必須自己創(chuàng)建。文件中的密碼字段使用MD5加密,不幸的是CVS沒有提供添加用戶名的命令,所以我們借用Apache的命令來完成這項工作:

代碼:
#htpasswd passwd username


這個命令為username指定密碼,并保存在passwd中,文件不存在時會自動創(chuàng)建。htpasswd命令不是為CVS而設(shè),因此總有一些遺憾,它不能自動添加映射到的用戶名,不過沒關(guān)系,我們設(shè)置好密碼后,自己把這部分加上。我的做法是映射到cvsroot用戶,如果需要映射其他的用戶,請注意給相應(yīng)的目錄設(shè)置好權(quán)限,否則CVS用戶可能無法訪問源代碼倉庫。
要徹底防止使用系統(tǒng)帳號登陸,可以編輯CVSROOT目錄下的config文件,把

代碼:
#SystemAuth=no


這一行前面的#去掉,CVS就不會驗證系統(tǒng)用戶了,否則當(dāng)用戶名不在passwd文件中時,CVS會進行系統(tǒng)用戶的驗證。
此外還必須配置讀寫權(quán)限,使用CVSROOT目錄下的readers和writers文件進行這個工作。這2個文件默認(rèn)也是沒有的,沒關(guān)系,自己創(chuàng)建就可以了。readers文件記錄擁有只讀權(quán)限的用戶名,每行一個用戶;writers文件記錄擁有讀寫權(quán)限的用戶名,也是每行一個用戶。注意,readers文件比writers優(yōu)先,也就是說出現(xiàn)在readers中的用戶將會是只讀的,不管writers文件中是否存在該用戶。

配置完畢,先測試一下:

代碼:
#cvs -d “:pserver:username@127.0.0.1:/home/cvsroot” login


這里假設(shè)用戶名是username,本機登陸。出現(xiàn)密碼提示,輸入正確的密碼后,登陸成功。如果提示訪問被拒絕,請檢查用戶權(quán)限、目錄權(quán)限以及防火墻設(shè)置。建議設(shè)置環(huán)境變量CVSROOT:

代碼:
#export CVSROOT=:pserver:username@127.0.0.1:/home/cvsroot


以后就不需要輸入-d參數(shù)了,但-d參數(shù)會覆蓋這個環(huán)境變量的設(shè)置。

5.源代碼倉庫的備份和移動
基本上,CVS的源代碼倉庫沒有什么特別之處,完全可以用文件備份的方式進行備份。需要注意的只是,應(yīng)該確認(rèn)備份的過程中沒有用戶提交修改,具體的做法可以是停止CVS服務(wù)器或者使用鎖等等。恢復(fù)時只需要把這些文件按原來的目錄結(jié)構(gòu)存放好,因為CVS的每一個模塊都是單獨的一個目錄,與其他模塊和目錄沒有任何瓜葛,相當(dāng)方便。甚至只需要在倉庫中刪除一個目錄或者文件,便可以刪除該模塊的一些內(nèi)容,不過并不建議這么做,使用CVS的刪除功能將會有一個歷史記錄,而對倉庫的直接刪除不留任何痕跡,這對項目管理是不利的。移動倉庫與備份相似,只需要把該模塊的目錄移動到新的路徑,便可以使用了。
如果不幸在備份之后有過一些修改并且執(zhí)行了提交,當(dāng)服務(wù)器出現(xiàn)問題需要恢復(fù)源代碼倉庫時,開發(fā)者提交新的修改就會出現(xiàn)版本不一致的錯誤。此時只需要把CVS相關(guān)的目錄和文件刪除,即可把新的修改提交。

6.更進一步的管理
CVSROOT目錄下還有很多其他功能,其中最重要的就是modules文件。這個文件定義了源代碼庫的模塊,下面是一個例子:

代碼:
Linux Linux
Kernel Linux/kernel


這個文件的內(nèi)容按行排列,每一行定義一個模塊,首先是模塊名,然后是模塊路徑,這是相對于CVS根目錄的路徑。它定義了兩個模塊,第一個是Linux模塊,它位于Linux目錄中,第二個是Kernel模塊,這是Linux模塊的子模塊。
modules文件并非必須的,它的作用相當(dāng)于一個索引,部分CVS客戶端軟件通過它可以快速找到相應(yīng)的模塊,比如WinCVS。

7.協(xié)同開發(fā)的問題
默認(rèn)方式下,CVS允許多個用戶編輯同一個文件,這對一個協(xié)作良好的團隊來說不會有什么問題,因為多個開發(fā)者同時修改同一個文件的同一部分是不正常的,這在項目管理中就應(yīng)該避免,出現(xiàn)這種情況說明項目組內(nèi)部沒有統(tǒng)一意見。而多個開發(fā)者修改文件的不同部分,CVS可以很好的管理。
如果覺得這種方式難以控制,CVS也提供了解決辦法,可以使用cvs admin -l進行鎖定,這樣一個開發(fā)者正在做修改時CVS就不會允許其他用戶checkout。這里順便說明一下文件格式的問題,對于文本格式,CVS可以進行歷史記錄比較、版本合并等工作,而二進制文件不支持這個操作,比如word文檔、圖片等就應(yīng)該以二進制方式提交。對于二進制方式,由于無法進行合并,在無法保證只有一個用戶修改文件的情況下,建議使用加鎖方式進行修改。必須注意的是,修改完畢記得解鎖。
從1.6版本開始,CVS引入了監(jiān)視的概念,這個功能可以讓用戶隨時了解當(dāng)前誰在修改文件,并且CVS可以自動發(fā)送郵件給每一個監(jiān)視的用戶告知最新的更新。

8.建立多個源代碼倉庫
如果需要管理多個開發(fā)組,而這些開發(fā)組之間不能互相訪問,可以有2個辦法:
a.共用一個端口,需要修改cvspserver文件,給server_args指定多個源代碼路徑,即多個—allow-root參數(shù)。由于xinetd的server_args長度有限制,可以在cvspserver文件中把服務(wù)器的設(shè)置重定向到另外一個文件,如:

代碼:
server = /home/cvsroot/cvs.run


然后創(chuàng)建/home/cvsroot/cvs.run文件,該文件必須可執(zhí)行,內(nèi)容格式為:

代碼:
#!/bin/bash
/usr/bin/cvs -f \
--allow-root=/home/cvsroot/src1 \
--allow-root=/home/cvsroot/src2 \
pserver


注意此時源代碼倉庫不再是/home/cvsroot,進行初始化的時候要分別對這兩個倉庫路徑進行初始化,而不再對/home/cvsroot路徑進行初始化。
b.采用不同的端口提供服務(wù)
重復(fù)第2步和第3步,為不同的源代碼倉庫創(chuàng)建不同服務(wù)名的啟動腳本,并為這些服務(wù)名指定不同的端口,初始化時也必須分別進行初始化。

posted on 2007-09-17 11:36 大龍 閱讀(294) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美一区二区日韩一区二区| 亚洲欧美一区二区三区极速播放 | 亚洲狠狠婷婷| 欧美一区二区三区啪啪| 久久久福利视频| 激情综合在线| 米奇777超碰欧美日韩亚洲| 欧美激情1区2区3区| 日韩亚洲视频在线| 欧美色欧美亚洲另类七区| 一区二区三区久久精品| 免费在线看成人av| 国产精品午夜视频| 亚洲一区999| 亚洲一区二区欧美| 国产精品一卡| 欧美刺激午夜性久久久久久久| 最新亚洲一区| 久久黄色影院| 欧美激情国产日韩| 亚洲欧洲日产国码二区| 亚洲精品一区在线| 久久网站免费| 亚洲欧美在线一区| 欧美在线视频观看免费网站| 亚洲精品自在久久| 精品动漫一区二区| 一区二区成人精品 | 欧美日韩国产限制| 欧美影院成人| 亚洲一区视频在线| 久久亚洲欧美| 亚洲欧美日韩专区| 夜夜精品视频一区二区| 蜜臀av性久久久久蜜臀aⅴ四虎| 欧美国产另类| 久久综合影音| 久久免费视频这里只有精品| 亚洲欧美韩国| 亚洲欧美日韩久久精品| 免费永久网站黄欧美| 亚洲午夜电影| 欧美黄污视频| 欧美精品电影| 欧美黄色小视频| 国内不卡一区二区三区| 国产欧美精品在线播放| 国产精品久久一级| 欧美视频在线不卡| 怡红院av一区二区三区| 在线成人免费观看| 久久九九久精品国产免费直播| 91久久国产精品91久久性色| 西西裸体人体做爰大胆久久久| 亚洲欧美在线视频观看| 欧美日韩国产在线播放| 18成人免费观看视频| 亚洲国产天堂网精品网站| 久久国产日韩| 欧美大片在线看| 久久精品国产欧美亚洲人人爽| 国产精品入口尤物| 亚洲欧美在线免费| 亚洲伊人色欲综合网| 欧美午夜www高清视频| 国产一区视频在线观看免费| 中日韩男男gay无套| 亚洲一区二区三区中文字幕| 亚洲电影观看| 亚洲全部视频| 亚洲一区日韩在线| 国产精品你懂的在线| 亚洲综合电影一区二区三区| 午夜免费电影一区在线观看| 亚洲无线视频| 国产亚洲精品福利| 亚洲精品免费在线| 欧美一级午夜免费电影| 久久综合狠狠综合久久激情| 性伦欧美刺激片在线观看| 国产视频一区二区三区在线观看| 一区二区三区在线高清| 久久亚洲免费| 免费在线看一区| 国产精品五月天| 久久久精品久久久久| 久久久久国产成人精品亚洲午夜| 欧美视频一二三区| 性色av一区二区三区在线观看| 亚洲欧美日韩视频二区| 狠狠做深爱婷婷久久综合一区 | 日韩视频在线一区二区三区| 日韩午夜精品视频| 欧美激情精品久久久久| 亚洲视频日本| 久久精视频免费在线久久完整在线看| 欧美精品日韩一区| 午夜日韩在线| 美女成人午夜| 欧美一区2区三区4区公司二百 | 一区二区电影免费观看| 国产亚洲一区二区三区| 欧美高清视频一区二区三区在线观看| 欧美日韩综合在线| 免费观看成人网| 欧美午夜精品理论片a级大开眼界 欧美午夜精品理论片a级按摩 | 最新中文字幕亚洲| 国产精品亚洲不卡a| 欧美搞黄网站| 国产日韩在线播放| 亚洲精品在线视频| 在线精品一区| 午夜精品亚洲| 亚洲在线观看免费| 欧美激情1区2区| 久久国产精品一区二区三区四区| 欧美成人在线免费视频| 久久米奇亚洲| 国产精品日韩精品| 亚洲精品免费一区二区三区| 韩国三级在线一区| 亚洲国产日韩一级| 免费看黄裸体一级大秀欧美| 国产精品久久久久高潮| 一本色道久久综合亚洲精品按摩| 欧美高清视频在线观看| 国产一区二区在线观看免费播放| 亚洲国产精品一区在线观看不卡| 蜜桃视频一区| 蜜臀av性久久久久蜜臀aⅴ四虎 | 在线观看欧美精品| 香蕉亚洲视频| 久久激情视频| 国产欧美精品va在线观看| 亚洲午夜在线观看| 亚洲在线中文字幕| 欧美日韩在线一区二区| 亚洲日本va午夜在线电影| 亚洲精选久久| 欧美高清在线一区二区| 欧美国产精品v| 亚洲国内高清视频| 蜜臀99久久精品久久久久久软件| 欧美a级一区| 亚洲精品日韩久久| 欧美片第一页| 亚洲欧美日韩精品久久亚洲区 | 亚洲影院免费观看| 国产精品久久久久久影院8一贰佰| 夜夜嗨av一区二区三区中文字幕| 亚洲天堂免费观看| 国产精品久久77777| 亚洲五月六月| 久久久精品999| 亚洲国产日韩欧美在线图片| 欧美精品日日鲁夜夜添| 夜夜嗨av色综合久久久综合网| 午夜精品久久久久久久男人的天堂| 国产精品入口| 麻豆精品网站| 亚洲日韩中文字幕在线播放| 9i看片成人免费高清| 欧美大成色www永久网站婷| 91久久精品国产91性色tv| 亚洲一区二区三区精品在线观看| 欧美视频一区在线| 欧美在线视频一区| 亚洲高清毛片| 亚洲午夜国产成人av电影男同| 欧美四级电影网站| 欧美一级大片在线免费观看| 久久久久亚洲综合| 亚洲欧洲在线免费| 午夜精品久久久久久久久久久久久| 亚洲欧美另类中文字幕| 国产亚洲欧洲997久久综合| 久久久久国产精品人| 亚洲人久久久| 一区二区视频免费在线观看| 欧美大色视频| 午夜欧美精品| 亚洲精品一区二区三区99| 欧美在线精品免播放器视频| 亚洲高清毛片| 99精品国产福利在线观看免费| 久久久久一区二区| 午夜精品www| 可以看av的网站久久看| 一本色道**综合亚洲精品蜜桃冫 | 国产精品国产三级国产专播精品人 | 亚洲午夜精品视频| 亚洲成色www久久网站| 国产精品国产a级| 男人的天堂亚洲| 午夜精品一区二区在线观看| 亚洲精品黄色| 亚洲高清av| 免费国产一区二区| 久久精品视频在线| 亚洲一区二区在线观看视频|