




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
在Linux和Windows下搭建CVS服務(wù)器與CVS客戶端的詳細(xì)配置指南發(fā)布:2007-12-1110:23|作者:PHPDIY|來源:CSDN博客|查看:2次一、cvs2.5服務(wù)器+Eclipse配合使用(Windows)一個項目往往有多人參與,如何協(xié)調(diào)各個人的開發(fā)工作,就成為項目開發(fā)小組需要直接面對的問題。一般的解決方案是采用版本控制系統(tǒng),如微軟的VSS,開源的CVS以及Subversion等等。Eclipse對團(tuán)隊開發(fā)提供了默認(rèn)的支持,其內(nèi)置了CVS的客戶端。所以我們只需安裝一個CVS服務(wù)器端就可以進(jìn)行項目開發(fā)的版本控制了。這里我們選擇windows平臺下的cvsnt來作cvs服務(wù)器。一.服務(wù)器設(shè)置首先到/下載一個cvsnt,我下載的版本是cvsnt-2.5.03.2382是一個windows下的msi文件安裝下載號的cvsnt文件,然后點(diǎn)擊CVSNTControlPanel打開cvsnt的控制面板進(jìn)行相應(yīng)的參數(shù)設(shè)置仙匚加T?Documentation?所有程序(引、5erv-U?CV5NTControlPanel區(qū)注銷心回]關(guān)閉計碧CV5NTPasswordAgentWorkspaceViewer3.在控制面板的RepositoryConfiguration中進(jìn)行資源庫的設(shè)置CVS是一個C/S系統(tǒng),多個開發(fā)人員通過一個中心版本控制系統(tǒng)來記錄文件版本,從而達(dá)到保證文件同步的目的。工作模式如下:
CVS服務(wù)器(文件版本庫)/|\(版本同步)/|\開發(fā)者1開發(fā)者2開發(fā)者3作為一般開發(fā)人員挑選2,6看就可以了,CVS的管理員則更需要懂的更多一些,最后還簡單介紹了一些Windows下的cvs客戶端使用,CVS遠(yuǎn)程用戶認(rèn)證的選擇及與BUG跟蹤系統(tǒng)等開發(fā)環(huán)境的集成問題。CVS環(huán)境初始化:CVS環(huán)境的搭建管理員CVS的日常使用:日常開發(fā)中最常用的CVS命令,開發(fā)人員管理員CVS的分支開發(fā):項目按照不同進(jìn)度和目標(biāo)并發(fā)進(jìn)行管理員CVS的用戶認(rèn)證:通過SSH的遠(yuǎn)程用戶認(rèn)證,安全,簡單管理員CVSWEB:CVS的WEB訪問界面大大提高代碼版本比較的效率管理員CVSTAG:將$Id$加入代碼注釋中,方便開發(fā)過程的跟蹤開發(fā)人員CVSvsVSS:CVS和VirsualSourceSafe的比較開發(fā)人員管理員WinCVS:通過SSH認(rèn)證的WinCVS認(rèn)證設(shè)置基于CVSTrac的小組開發(fā)環(huán)境搭建:通過CVSTrac實(shí)現(xiàn)web界面的CVS用戶管理,集成的BUG跟蹤和WIKI交流CVS中的用戶權(quán)限管理:基于系統(tǒng)用戶的CVS權(quán)限管理和基于CVSROOT/passwd的虛擬用戶管理一個系統(tǒng)20%的功能往往能夠滿足80%的需求,CVS也不例外,以下是CVS最常用的功能,可能還不到它全部命令選項的20%,作為一般開發(fā)人員平時會用cvsupdate和cvscommit就夠了,更多的需求在實(shí)際應(yīng)用過程中自然會出現(xiàn),不時回頭看看相關(guān)文檔經(jīng)常有意外的收獲。環(huán)境設(shè)置:指定CVS庫的路徑CVSROOTtcshsetenvCVSROOT/path/to/cvsrootbashCVSROOT=/path/to/cvsroot;exportCVSROOT后面還提到遠(yuǎn)程CVS服務(wù)器的設(shè)置:CVSROOT=:ext:$USER@test.server.address#port:/path/to/cvsrootCVS_RSH=ssh;exportCVSROOTCVS_RSH初始化:CVS版本庫的初始化。cvsinit一個項目的首次導(dǎo)入cvsimport-m"writesomecommentshere"project_namevendor_tagrelease_tag執(zhí)行后:會將所有源文件及目錄導(dǎo)入到/path/to/cvsroot/project_name目錄下vender_tag:開發(fā)商標(biāo)記release_tag:版本發(fā)布標(biāo)記項目導(dǎo)出:將代碼從CVS庫里導(dǎo)出cvscheckoutproject_namecvs將創(chuàng)建project_name目錄,并將最新版本的源代碼導(dǎo)出到相應(yīng)目錄中。這Checkout和VirvualSourceSafe中的checkout不是一個概念,相對于VirvualSourceSafe的ch注意:第一次導(dǎo)出以后,就不是通過cvscheckout來同步文件了,而是要進(jìn)入剛才cvscheckoutproject_name導(dǎo)出的project_name目錄下進(jìn)行具體文件的版本同步(添加,修改,刪除)操作。eckouteckout是cvsupdate,checkin是cvscommit。將文件同步到最新的版本cvsupdate不制定文件名,cvs將同步所有子目錄下的文件,也可以制定某個文件名!錄進(jìn)行同步cvsupdatefile_name最好每天開始工作前或?qū)⒆约旱墓ぷ鲗?dǎo)入到VS庫里前都要做一次,并養(yǎng)成先同步后修改〃的習(xí)慣,和VirvualSourceSafe不同,CVS里沒有文件鎖定的概念,所有的沖突是iCommit之前解決,如果你修改過程中,有其他人修改Commit到了CVS庫中,CVS會通知你文件沖突,并自動將沖突部分用>>>>>>contentoncvsserver<<<<<<contentinyourfile>>>>>>標(biāo)記出來,由你確認(rèn)沖突內(nèi)容的取舍。版本沖突一般是在多個人修改一個文件造成的,但這種項目管理上的問題不應(yīng)該指望的來解決。確認(rèn)修改寫入到CVS庫里cvscommit-m"writesomecommentshere"file_name注意:3S的很多動作都是通過vscommit進(jìn)行最后確認(rèn)并修改的,最好每次只修改一個文件。在確認(rèn)的前,還需要用戶填寫修改注釋,以幫助其他開發(fā)人員了解修改的原因。如果不用寫-m"comments"而直接確認(rèn)'cvscommitfile_name'的話,cvs會自動調(diào)用系統(tǒng)缺省的文字編輯旅一般是vi)要求你寫入注釋。注釋的質(zhì)量很重要:所以不僅必須要寫,而且必須寫一些比較有意義的內(nèi)容以方便其他開發(fā)人員能夠很好的理解不好的注釋,很難讓其他的開發(fā)人員快速的理解:比如:-m"bugfixed"甚至-m""好的注釋,甚至可以用中文-m”在用戶注冊過程中加入了Email地址校驗(yàn)"修改某個版本注釋:每次只確認(rèn)一個文件到CVS庫里是一個很好的習(xí)慣,但難免有時候忘了指定文件名,把多個文件以同樣注釋commit到CVS庫里了,以下命令可以允許你修改某個文件某個版本的注釋:cvsadmin-m1.3:"writesomecommentshere"file_name添加文件創(chuàng)建好新文件后,比如:touchnew_filecvsaddnew_file注意:對于圖片,Wo廠d文檔等非純文本的項目,需要使用vsadd-kb選項按2進(jìn)制文件方式導(dǎo)入久表示擴(kuò)展選項,b表示binary),否則有可能出現(xiàn)文件被破壞的情況比如:cvsadd-kbnew_file.gifcvsadd-kbreadme.doc如果關(guān)鍵詞替換屬性在首次導(dǎo)入時設(shè)置錯了怎么辦?cvsadmin-kkvnew_file.css然后確認(rèn)修改并洋釋cvsci-m"writesomecommentshere"刪除文件將某個源文件物理刪除后,比如:rmfile_namecvsrmfile_name然后確認(rèn)修改并注釋cvsci-m"writesomecommentshere"以上面前2步合并的方法為:cvsrm-ffile_namecvsci-m"whydeletefile"注意:很多c/s命令都有縮寫形式:commit=>ci;update=>up;checkout=>co/get;remove=>rm;添加目錄cvsadddir_name杳看修改歷史cvslogfile_namecvshistoryfile_name杳看當(dāng)前文件不同版本的區(qū)別cvsdiff-r1.3-r1.5file_name查看當(dāng)前文件(可能已經(jīng)修改了)和庫中相應(yīng)文件的區(qū)別cvs的web界面提供了更方便的定位文件修改和比較版本區(qū)別的方法,具體安裝設(shè)置請看后面的cvsweb使用正確的通過CVS恢復(fù)舊版本的方法:如果用這個命令是給加一個STICKTAG:"1.2",雖然你的本意只是想將它恢復(fù)到1.2版本正確的恢復(fù)版本的方法是:cvsupdate-p-r1.2file_name>file_name如果不小心已經(jīng)加成STICKTAG的話:用cvsupdate-A解決移動文件/文件重命名cvs里沒有cvsmove或cvsrename,因?yàn)檫@兩個操作是可以由先cvsremoveold_file_name,然后cvsaddnew_file_name實(shí)現(xiàn)的。刪除/移動目錄最方便的方法是讓管理員直接移動,刪除CVSROOT里相應(yīng)目錄(因?yàn)镃VS一個項目下的子目錄都是獨(dú)立的,移動到$CVSROOT目錄下都可以作為新的獨(dú)立項目:好比一顆樹,其實(shí)砍下任意一枝都能獨(dú)立存活),對目錄進(jìn)行了修改后,要求其開發(fā)人員重新導(dǎo)出項目cvscheckoutproject_name或者用cvsupdate-dP同步。項目發(fā)布導(dǎo)出不帶CVS目錄的源文件做開發(fā)的時候你可能注意到了,每個開發(fā)目錄下,CVS都創(chuàng)建了一個CVS/目錄。里面有文件用于記錄當(dāng)前目錄和CVS庫之間的對應(yīng)信息。但項目發(fā)布的時候你一般不希望把文件目錄還帶著含有CVS信息的CVS目錄吧,這個一次性的導(dǎo)出過程使用cvsexport命令,不過export只能針對一個TAG或者日期導(dǎo)出,比如:cvsexport-D20021023project_namecvsexport-Dnowproject_nameCVSBranch:項目多分支同步開發(fā)確認(rèn)版本里程碑:多個文件各自版本號不一樣,項目到一定階段,可以給所有文件統(tǒng)一指定一個階段里程碑版本號,方便以后按照這個階段里程碑版本號導(dǎo)出項目,同時也是項目的多個分支開發(fā)的基礎(chǔ)。cvstagrelease_1_0開始一個新的里程碑:cvscommit-r2標(biāo)記所有文件開始進(jìn)入2.x的開發(fā)注意:CVS里的revsion和軟件包的發(fā)布版本可以沒有直接的關(guān)系。但所有文件使用和發(fā)布版本一致的版本號比較有助于維護(hù)。版本分支的建立在開發(fā)項目的2.x版本的時候發(fā)現(xiàn)1.x有問題,但2.x又不敢用,則從先前標(biāo)記的里程碑:release_1_0導(dǎo)出一個分支release_1_0_patchcvsrtag-b-rrelease_1_0release_1_0_patchproj_dir一些人先在另外一個目錄下導(dǎo)出release_1_0_patch這個分支:解決1.0中的緊急問題,cvscheckout-rrelease_1_0_patch而其他人員仍舊在項目的主干分支2.x上開發(fā)在release_1_0_patch上修正錯誤后,標(biāo)記一個1.0的錯誤修正版本號cvstagrelease_1_0_patch_1如果2.0認(rèn)為這些錯誤修改在2.0里也需要,也可以在2.0的開發(fā)目錄下合并release_1_0_patch_1中的修改到當(dāng)前代碼中:cvsupdate-jrelease_1_0_patch_1CVS的遠(yuǎn)程認(rèn)證通過SSH遠(yuǎn)程訪問CVS使用cvs本身基于pserver的遠(yuǎn)程認(rèn)證很麻煩,需要定義服務(wù)器和用戶組,用戶名,設(shè)置密碼等,常見的登陸格式如下:cvs-d:pserver:cvs_user_name@cvs.server.address:/path/to/cvsrootlogin例子:cvs-d:pserver:cvs@:/cvsrootlogin不是很安全,因此一般是作為匿名只讀CVS訪問的方式。從安全考慮,通過系統(tǒng)本地帳號認(rèn)證并通過SSH傳輸是比較好的辦法,通過在客戶機(jī)的/etc/profile里設(shè)置一下內(nèi)容:CVSROOT=:ext:$USER@cvs.server.address#port:/path/to/cvsrootCVS_RSH=ssh;exportCVSROOTCVS_RSH所有客戶機(jī)所有本地用戶都可以映射到CVS服務(wù)器相應(yīng)同名帳號了。比如:CVS服務(wù)器是,上面CVSROOT路徑是/home/cvsroot,另外一臺開發(fā)客戶機(jī)是,如果tom在2臺機(jī)器上都有同名的帳號,那么從上設(shè)置了:exportCVSROOT=:ext:tom@:/home/cvsrootexportCVS_RSH=sshtom就可以直接在上對的cvsroot進(jìn)行訪問了(如果有權(quán)限的話)cvscheckoutproject_namecvsupdatecvscommit如果CVS所在服務(wù)器的SSH端口不在缺省的22,或者和客戶端與CVS服務(wù)器端SSH缺省端口不一致,有時候設(shè)置了::ext:$USER@test.server.address#port:/path/to/cvsroot仍然不行,比如有以下錯誤信息:ssh:test.server.address#port:Nameorservicenotknowncvs[checkoutaborted]:endoffilefromserver(consultabovemessagesifany)解決的方法是做一個腳本指定端口轉(zhuǎn)向(不能使用alias,會出找不到文件錯誤):創(chuàng)建一個/usr/bin/ssh_cvs文件,假設(shè)遠(yuǎn)程服務(wù)器的SSH端口是非缺省端口:34567#!/bin/sh/usr/bin/ssh-p34567"$@"然后:chmod+x/usr/bin/ssh_cvs并CVS_RSH=ssh_cvs;exportCVS_RSH注意:port是指相應(yīng)服務(wù)器SSH的端口,不是指cvs專用的pserver的端口CVSWEB:提高文件瀏覽效率CVSWEB就是CVS的WEB界面,可以大大提高程序員定位修改的效率:使用的樣例可以看:/cgi/cvsweb.cgiCVSWEB的下載:CVSWEB從最初的版本已經(jīng)演化出很多功能界面更豐富的版本,這個是我個人感覺安裝設(shè)置比較方便的:原先在:http://www.spaghetti-code.de/software/linux/cvsweb/,但目前已經(jīng)刪除,目前仍可以在本站下載CVSWEB,其實(shí)最近2年FreeBSD的CVSWeb項目已經(jīng)有了更好的發(fā)展吧,而當(dāng)初沒有用FreeBSD那個版本主要就是因?yàn)闆]有彩色的文件Diff功能。下載解包:tarzxfcvsweb.tgz把配置文件cvsweb.conf放到安全的地方(比如和apache的配置放在同一個目錄下),修改:cvsweb.cgi讓CGI找到配置文件:$config=$ENV{'CVSWEB_CONFIG'}||'/path/to/apache/conf/cvsweb.conf';轉(zhuǎn)到到/path/to/apache/conf下并修改cvsweb.conf:修改CVSROOT路徑設(shè)置:%CVSROOT=('Development'=>'/path/to/cvsroot',#<==修改指向本地的CVSROOT);缺省不顯示已經(jīng)刪除的文檔:"hideattic"=>"1",#<==缺省不顯示已經(jīng)刪除的文檔在配置文件cvsweb.conf中還可以定制頁頭的描述信息,你可以修改$long_intro成你需要的文字CVSWEB可不能隨便開放給所有用戶,因此需要使用WEB用戶認(rèn)證:先生成passwd:/path/to/apache/bin/htpasswd-ccvsweb.passwduser修改httpd.conf:增加<Directory"/path/to/apache/cgi-bin/cvsweb/">AuthName"CVSAuthorization"AuthTypeBasicAuthUserFile/path/to/cvsweb.passwdrequirevalid-user</Directory>CVSTAGS:$Id$將$Id$加在程序文件開頭的注釋里是一個很好的習(xí)慣,cvs能夠自動解釋更新其中的內(nèi)容成:file_nameversiontimeuser_name的格式,比如:cvs_card.txt,v1.12002/04/0504:24:12chedongExp,可以這些信息了解文件的最后修改人和修改時間。幾個常用的缺省文件:default.php<?php/*Copyright(c)2002CompanyName.$Header$*/?>Default.java:注意文件頭一般注釋用/*開始JAVADOC注釋用/**開始的區(qū)別/*Copyright(c)2002MyCompanyName$Header$*/packagecom.mycompany;importjava.;/**commentshere*/publicclassDefault(/**Commentshere@param@return*/default.pl:#!/usr/bin/perl-w#Copyright(c)2002CompanyName.#$Header$#filecommentshereusestrict;CVSvsVSSCVS沒有文件鎖定模式,VSS在checkout同時,同時記錄了文件被導(dǎo)出者鎖定。CVS的update和commit,VSS是get_lastest_version和checkin對應(yīng)VSS的checkout/undocheckout的CVS里是edit和unedit在CVS中,標(biāo)記自動更新功能缺省是打開的,這樣也帶來一個潛在的問題,就是不用-kb方式添加binary文件的話在cvs自動更新時可能會導(dǎo)致文件失效。$Header$$Date$這樣的標(biāo)記在VirsualSourceSafe中稱之為KeywordExplaination,缺省是關(guān)閉的,需要通過OPITION打開,并指定需要進(jìn)行源文件關(guān)鍵詞掃描的文件類型:*.txt,*.java,*.html...對于VirsualSourceSafe和CVS都通用的TAG有:$Header$$Author$$Date$$Revision$我建議盡量使用通用的關(guān)鍵詞保證代碼在CVS和VSS都能方便的跟蹤。WinCVS下載:cvsWindows客戶端:目前穩(wěn)定版本為1.2sshWindows客戶端/openssh/安裝好以上2個軟件以后:WinCVS客戶端的admin==>preference設(shè)置1在general選單里設(shè)置CVSROOT:username@23:/home/cvsroot設(shè)置Authorization:選擇SSHserver2Port選單里鉤上:checkforalternatershname并設(shè)置ssh.exe的路徑,缺省是裝在C:\ProgramFiles\NetworkSimplicity\ssh\ssh.exe然后就可以使用WinCVS進(jìn)行cvs操作了,所有操作都會跳出命令行窗口要求你輸入服務(wù)器端的認(rèn)證密碼。當(dāng)然,如果你覺得這樣很煩的話,還有一個辦法就是生成一個沒有密碼的公鑰/私鑰對,并設(shè)置CVS使用基于公鑰/私鑰的SSH認(rèn)證(在general選單里)??梢赃x擇的diff工具:examdiff下載:/examdiff/examdiff.htm還是在WinCVS菜單admin==>preference的WinCVS選單里選上:Externeldiffprogram并設(shè)置diff工具的路徑,比如:C:\ProgramFiles\ed16i\ExamDiff.exe在對文件進(jìn)行版本diff時,第一次需要將窗口右下角的useexterneldiff選上。基于CVSTrac的小組開發(fā)環(huán)境搭建作為一個小組級的開發(fā)環(huán)境,版本控制系統(tǒng)和BUG跟蹤系統(tǒng)等都涉及到用戶認(rèn)證部分。如何方便的將這些系統(tǒng)集成起來是一個非常困難的事情,畢竟我們不能指望Linux下有像SourceOffsite那樣集成度很高的版本控制/BUG跟蹤集成系統(tǒng)。我個人是很反對使用pserver模式的遠(yuǎn)程用戶認(rèn)證的,但如果大部分組員使用WINDOWS客戶端進(jìn)行開發(fā)的話,總體來說使用CVSROOT/passwd認(rèn)證還是很難避免的,但CVS本身用戶的管理比較麻煩。本來我打算自己用perl寫一個管理界面的,直到我發(fā)現(xiàn)了CVSTrac:一個基于WEB界面的BUG跟蹤系統(tǒng),它外掛在CVS系統(tǒng)上的BUG跟蹤系統(tǒng),其中就包括了WEB界面的CVSROOT/passwd文件的管理,甚至還集成了WIKIWIKI討論組功能。這里首先說一下CVS的pserver模式下的用戶認(rèn)證,CVS的用戶認(rèn)證服務(wù)是基于inetd中的:cvspserverstreamtcpnowaitapache/usr/bin/cvscvs--allow-root=/home/cvsrootpserver一般在2401端口(這個端口號很好記:49的平方)CVS用戶數(shù)據(jù)庫是基于CVSROOT/passwd文件,文件格式:[username]:[crypt_password]:[mapping_system_user]由于密碼都用的是UNIX標(biāo)準(zhǔn)的CRYPT加密,這個passwd文件的格式基本上是apache的htpasswd格式的擴(kuò)展(比APACHE的PASSWD文件多一個系統(tǒng)用戶映射字段),所以這個文件最簡單的方法可以用apache/bin/htpasswd-bmynamemypassword創(chuàng)建。注意:通過htpasswd創(chuàng)建出來的文件會沒有映射系統(tǒng)用戶的字段例如:new:geBvosup/zKl2setup:aISQuNAAoY3qwtest:hwEpz/BX.rEDU映射系統(tǒng)用戶的目的在于:你可以創(chuàng)建一個專門的CVS服務(wù)帳號,比如用apache的運(yùn)行用戶apache,并將/home/cvsroot目錄下的所有權(quán)限賦予這個用戶,然后在passwd文件里創(chuàng)建不同的開發(fā)用戶帳號,但開發(fā)用戶帳號最后的文件讀寫權(quán)限都映射為apache用戶,在SSH模式下多個系統(tǒng)開發(fā)用戶需要在同一個組中才可以相互讀寫CVS庫中的文件。進(jìn)一步的,你可以將用戶分別映射到apache這個系統(tǒng)用戶上。new:geBvosup/zKl2:apachesetup:aISQuNAAoY3qw:apachetest:hwEpz/BX.rEDU:apacheCVSTrac很好的解決了CVSROOT/passwd的管理問題,而且包含了BUG跟蹤報告系統(tǒng)和集成WIKIWIKI交流功能等,使用的CGI方式的安裝,并且基于GNUPublicLicense在inetd里加入cvspserver服務(wù):cvspserverstreamtcpnowaitapache/usr/bin/cvscvs--allow-root=/home/cvsrootpserverxietd的配置文件:%catcvspserverservicecvspserver{disable=nosocket_type=streamwait=nouser=apacheserver=/usr/bin/cvsserver_args=-f--allow-root=/home/cvsrootpserverlog_on_failure+=USERID}注意:這里的用戶設(shè)置成apache目的是和/home/cvsroot的所有用戶一致,并且必須讓這個這個用戶對/home/cvsroot/下的CVSROOT/passwd和cvstrac初始化生成的myproj.db有讀取權(quán)限。安裝過程1.下載:可以從下載我用的是已經(jīng)在Linux上編譯好的應(yīng)用程序包:cvstrac-1.1.2.bin.gz,%gzip-dcvstrac-1.1.2.bin.gz%chmod+xcvstrac-1.1-2.bin#mvcvstarc-1.1-1.bin/usr/bin/cvstrac如果是從源代碼編譯:從/download.html下載SQLITE的rpm包:rpm-isqlite-devel-2.8.6-1.i386.rpm從/cvstrac/下載軟件包解包,假設(shè)解包到/home/chedong/cvstrac-1.1.2下,并規(guī)劃將cvstrac安裝到/usr/local/bin目錄下,cd/home/chedong/cvstrac-1.1.2編輯linux-gcc.mk:修改:SRCDIR=/home/chedong/cvstrac-1.1.2INSTALLDIR=/usr/local/bin然后mvlinux-gcc.mkMakefilemake#makeinstall2.初始化cvstrac數(shù)據(jù)庫:假設(shè)數(shù)據(jù)庫名是myproj在已經(jīng)裝好的CVS服務(wù)器上(CVS庫這時候應(yīng)該已經(jīng)是初始化好了,比如:cvsinit初始化在/home/cvsroot里),運(yùn)行一下%cvstracinit/home/cvsrootmyproj運(yùn)行后,/home/cvsroot里會有一個的myproj.db庫,使用CVSTRAC服務(wù),/home/cvsroot/myproj.db/home/cvsroot/CVSROOT/readers/home/cvsroot/CVSROOT/writers/home/cvsroot/CVSROOT/passwd這幾個文件對于web服務(wù)的運(yùn)行用戶應(yīng)該是可寫的,在RedHat8上,缺省就有一個叫apache用戶和一個apache組,所以在httpd.conf文件中設(shè)置了用apache用戶運(yùn)行web服務(wù):UserapacheGroupapache,然后設(shè)置屬于apache用戶和apache組#chown-Rapache:apache/home/cvsroot-rw-r--r--1apacheapache55296Jan519:40myproj.dbdrwxrwxr-x3apacheapache4096Oct2413:04CVSROOT/drwxrwxr-x2apacheapache4096Aug3019:47some_proj/此外還在/home/cvsroot/CVSROOT中設(shè)置了:chmod664readerswriterspasswd在apche/cgi-bin目錄中創(chuàng)建腳本cvstrac:#!/bin/sh/usr/bin/cvstraccgi/home/cvsroot設(shè)置腳本可執(zhí)行:chmod+x/home/apache/cgi-bin/cvstrac從http://cvs.server.address/cgi-bin/cvstrac/myproj進(jìn)入管理界面缺省登錄名:setup密碼setup對于一般用戶可以從:http://cvs.server.address/cgi-bin/cvstrac/myproj在setup中重新設(shè)置了CVSROOT的路徑后,/home/cvsroot如果是初次使用需要在/home/cvsroot/CVSROOT下創(chuàng)建passwd,readers,writers文件touchpasswdreaderswriters然后設(shè)置屬于apache用戶,chownapache.apachepasswdreaderswriters這樣使用setup用戶創(chuàng)建新用戶后會同步更新CVSROOT/passwd下的帳號修改登錄密碼,進(jìn)行BUG報告等,更多使用細(xì)節(jié)可以在使用中慢慢了解。對于前面提到的WinCVS在perference里設(shè)置:CVSROOT欄輸入:username@ip.address.of.cvs:/home/cvsrootAuthenitication選擇:usepasswdfileonserverside就可以了從服務(wù)器上進(jìn)行CVS操作了。CVS的用戶權(quán)限管理CVS的權(quán)限管理分2種策略:基于系統(tǒng)文件權(quán)限的系統(tǒng)用戶管理:適合多個在Linux上使用系統(tǒng)帳號的開發(fā)人員進(jìn)行開發(fā)。基于CVSROOT/passwd的虛擬用戶管理:適合多個在Windows平臺上的開發(fā)人員將帳號映射成系統(tǒng)帳號使用。為什么使用apache/apache用戶?首先RedHat8中缺省就有了,而且使用這個用戶可以方便通過cvstrac進(jìn)行WEB管理。chown-Rapache.apache/home/cvsrootchmod775/home/cvsrootLinux上通過ssh連接CVS服務(wù)器的多個開發(fā)人員:通過都屬于apache組實(shí)現(xiàn)文件的共享讀寫開發(fā)人員有開發(fā)服務(wù)器上的系統(tǒng)帳號:sysuser1sysuser2,設(shè)置讓他們都屬于apache組,因?yàn)橥ㄟ^cvs新導(dǎo)入的項目都是對組開放的:664權(quán)限的,這樣無論那個系統(tǒng)用戶導(dǎo)入的項目文件,只要文件的組宿主是apache,所有其他同組系統(tǒng)開發(fā)用戶就都可以讀寫;基于ssh遠(yuǎn)程認(rèn)證的也是一樣。apache(systemgroup)/|\sysuser1sysuser2sysuser3Windows上通過cvspserver連接CVS服務(wù)器的多個開發(fā)人員:通過在passwd文件種映射成apache用戶實(shí)現(xiàn)文件的共享讀寫他們的帳號通過CVSROOT/passwd和readerswriters這幾個文件管理;通過cvstrac設(shè)置所有虛擬用戶都映射到apache用戶上即可。apache(systemuser)/|\windev1windev2windev3利用CVSWinCVS/CVSWeb/CVSTrac構(gòu)成了一個相對完善的跨平臺工作組開發(fā)版本控制環(huán)境。相關(guān)資源:CVSHOME:CVSFAQ:http://www.loria.fr/~molli/cvs-index.html相關(guān)網(wǎng)站:/Top/Computers/Software/Configuration_Management/Tools/Concurrent_Versions_System/CVS--并行版本系統(tǒng)/cvsdoc/zh_CN/book1.htmlCVS免費(fèi)書:/CVS命令的速查卡片/refcards/cvs/WinCVS:/CVSTrac:AWeb-BasedBugAndPatch-SetTrackingSystemForCVSStatCVS:基于CVS的代碼統(tǒng)計工具:按代碼量,按開發(fā)者的統(tǒng)計表等/projects/statcvs如何在WEB開發(fā)中規(guī)劃CVS上:在Google上查"cvswebdevelopment"/bboard-archive/cvs_for_web_development/index.html一些集成了CVS的IDE環(huán)境:EclipseCVS服務(wù)器端:CVS下載地址:/(最新版本:hp:1.12.11,Linuxandwin32:1.11.17)cvsnt下載地址:/cvspro/(最新版本:2.0.58d)CVS客戶端:TortoiseCVS下載地址:/(最新版本:1.8.11)wincvs下載地址:/download.html(最新版本:)Python下載地址:/download/(最新版本:2.4)TCL下載地址:/Products/ActiveTCL/(最新版本:)SmartCVS下載地址:http://www.regnis.de/download.html(最新版本:3.0.6)或者:下載WinCVS中文版一一如果對WinCVS及的Python,TCL的安裝一點(diǎn)也不熟悉,請首先閱讀WinCVS安裝配置指南,在此下載?。?!如果您需要WinCVS中文版,請在此下載?。?!如果您需要WinCVS所需的PYTHON,請訪問(僅支持2.2.3以下的版本)??!!您也可以在本站直接下載!!!Python2.2.1Python2.2.3如果您需要WinCVS所需的TCL,請訪問TCL開發(fā)站點(diǎn)(TCLDeveloperSite)!!!您也可以在本站直接下載?。。VSWEB下載地址:/projects/cvsweb.html(最新版本:3.0.5)viewcvs下載地址:/(最新版本:0.9.2)CvsGraph下載地址:http://www.akhphd.au.dk/~bertho/cvsgraph/(最新版本:1.5.1)缺陷跟蹤:中文版CVSTrac下載地址/download.php?id=246&lang=zh-cn)(最新版本1.2)基于CVS的代碼統(tǒng)計工具:按代碼量,按開發(fā)者的統(tǒng)計表等:StatCVS下載地址:/projects/statcvs(最新版本:0.2.2)CVS權(quán)限管理(CVSACLisapatchforCVS):cvsacl下載地址:/(最新版本:1.2.2)subversion服務(wù)器端:subversion下載地址:http://subversion.tigris.Org/project_packages.html#binary-packages(最新版本:1.1.3)subversion客戶端:tortoisesvn下載地址:/(最新版本:1.1.3)rapidsvn下載地址:/(最新版本:0.7.0)遮定職潸4.點(diǎn)擊-Add按鈕即可增加一個新的資源庫Location是資源文件在文件系統(tǒng)的存儲位置,Name是客戶端訪問服務(wù)器的名字,可以接受默認(rèn)值,也可修改5.切換到ServerSetting
WindowNewWindowNewEditorI9;§1?帝,悖C1■T-OjjenPerspective>CustcmisePerspective...PerspectiveAs...Res已tP已rsp已!ztiu已ClosePerspectiveCloseAllPerspectives茴History任Navigator□1Outline=SynchronizeAlt+Shift+QjV圣Tasks'NaviQation卜Other...Alt+Shift+QjQ:WorkingSets?WebBrowser?PreFerences...2.在cvs視圖中右鍵空白區(qū)域,彈出如下菜單,New卜矗RepositoryLocation...了EjeFr■已shView3.點(diǎn)擊RepositoryLocation,彈出如下窗口
4.單擊|〔Finish這,樣一個客戶端連接就建好了。將項目提交到CVS服務(wù)器上右鍵選中一個項目,選擇Team,再選ShareProject,然后往下一路next即可,這里就不羅唆了從CVS服務(wù)器上下載項目到eclipse中新建一個項目時,選擇CVS|ProjectsfromCVS即可,下面就是一路的next卜NewProjectSelectawizardCreateanewprojectbycheckingoutanexistingprojectfromaCVSrepasitary.Wizards:typeFiltertextJavaProject-Z-JavaProjectfromExistingAntBuildhlePlug-inProject+._■1General+Busin游sIntelligenceandReportingTook-&CV5ProjectsfrarnCV5十、_Designer+EclipseModelingFramework+&EJB+._■GraphicalModelingFramework+&J2EEw?<Back[|Next>]FinishCancel把一個項目中的更改提交到CVS服務(wù)器右鍵選擇更改的項目(或其中的某一具體的包或者文件)然后Team|Commit下面就是next即可把CVS服務(wù)器中的更改更新到eclipse中右鍵選擇項目(或其中的某一具體的包或者文件)然后Team|SynchronizewithRepository,下面就是next即可其他幾個要點(diǎn)將項目提交到CVS服務(wù)器上,必須通過三中的方法,而不能直接把項目的文件夾拷貝到服務(wù)器的存儲庫目錄中
更改CVS存儲庫,如果一個項目本身就是通過CVS下載到本地的,現(xiàn)在想把該項目組織到新的存儲庫中,按照三的方法,默認(rèn)會提交到原來的存儲庫,這時,我們只需把項目中的根目錄下面的CVS文件夾刪除即可,再通過三中的方法即可提交到變更后的存儲庫中,如果還是提交不了,則右鍵項目,刷新一下即可。二、在Linux和Windows下搭建CVS服務(wù)器與CVS客戶端的配置指南摘要:本教程包含CVS的入門知識講解、在linux和windows下CVS服務(wù)器與CVS客戶端的配置指南,詳細(xì)介紹了配置過程,可以說是一篇組建CVS開發(fā)環(huán)境的入門、學(xué)習(xí)與提高的完美教程。通過本教程你可以在最短的時間里面最快的搭建好CVS服務(wù)器與CVS客戶端的的開發(fā)環(huán)境。如有不明之處,請聯(lián)系飄揚(yáng),你可以到我的博客(飄揚(yáng)博客)給我留言或QQ47720194,我會盡力解答你的問題。目錄:一、CVS入門知識詳解1、什么是CVS?2、CVS基本概念二、Linux下CVS服務(wù)器與客戶端的配置1、Linux下CVS服務(wù)器的配置2、Linux下CVS客戶端的配置三、Windows下CVS服務(wù)器與客戶端的配置1、windows下CVS服務(wù)器的配置2、windows下CVS客戶端的配置四、結(jié)束語
一、CVS入門知識詳解1、什么是CVS?CVS是一種客戶機(jī)/服務(wù)器系統(tǒng),類似于microsoftSourceSafe,可以讓開發(fā)人員將他們的項目存儲在稱為資源庫的中央位置。使用cvs客戶機(jī)工具,開發(fā)人員可以對資源庫的內(nèi)容進(jìn)行更改。CVS資源庫會依次記錄對每個文件所做的每個更改,并創(chuàng)建一個完整的項目開發(fā)進(jìn)展歷史。開發(fā)人員可以請求特定源文件的舊版本、查看更改日志,并根據(jù)需要執(zhí)行其它一些有用的任務(wù)。所有重要的免費(fèi)軟件項目都使用CVS作為其程序員之間的中心點(diǎn),以便能夠綜合各程序員的改進(jìn)和更改。這些項目包括:Gnome,KDE,TheGIMP,Wine,等等。CVS的基本工作思路是這樣的:在一臺服務(wù)器上建立一個倉庫,倉庫里可以存放許多不同項目的源程序。由倉庫管理員統(tǒng)一管理這些源程序.這樣,就好象只有一個人在修改文件一樣.避免了沖突.每個用戶在使用倉庫之前,首先要把倉庫里的項目文件下載到本地。用戶做的任何修改首先都是在本地進(jìn)行,然后用cvs命令進(jìn)行提交,由cvs倉庫管理員統(tǒng)一修改.這樣就可以做到跟蹤文件變化,沖突控制等等.CVS可以協(xié)助一組人共同開發(fā)一個工程。如果你是一個項目中的一組成員之一,CVS也能夠幫助你。除非你特別仔細(xì),你很容易覆蓋其他人的工作。一些編輯器,例如GNUEmacs,試圖去判定一個文件是否被兩人同時修改。不幸的是,如果一個人使用其它的編輯器時,這個安全方式將不再有效。CVS使用讓不同開發(fā)者獨(dú)立工作的方式解決了這個問題。每一個開發(fā)者的工作都在他自己的目錄內(nèi),并且CVS將在每個開發(fā)者的工作完成后進(jìn)行合并工作。由于CVS是典型的C/S結(jié)構(gòu)的軟件,因此它也分成服務(wù)器端和客戶端兩部分。不過大多數(shù)CVS軟件都把它們合二為一了。我們這里就分別從服務(wù)器和客戶端的角度討論cvs的使用。2、CVS基本概念Repository(倉庫)
CVS的倉庫存儲全部的版本控制下的文件copy,通常不容許直接訪問,只能通過cvs命令,獲得一份本地copy,改動后再checkin(commit)回倉庫。而倉庫通常為與工作目錄分離的。CVS通過多種方式訪問倉庫。每種方法有不同目錄表示形式。數(shù)據(jù)如何存放在repository中:隨著CVS版本的不同,存放結(jié)構(gòu)會發(fā)生變化,一般情況下用戶無需了解數(shù)據(jù)到底是如何存放的。Revision(修訂版)每一個file的各個revision都不相同,形如1.1,1.2.1,一般1.1是該文件的第一個revision,后面的一個將自動增加最右面的一個整數(shù),比如1.2,1.3,1.4...有時候會出現(xiàn),原因見后。revision總是偶數(shù)個數(shù)字。一般情況下將revision看作時CVS自己內(nèi)部的一個編號,而tag則可以標(biāo)志用戶的特定信息。Tag(標(biāo)簽)用符號化的表示方法標(biāo)志文件特定revision的信息。通常不需要對某一個孤立的文件作tag,而是對所有文件同時作一個tag,以后用戶可以僅向特定tag的文件提交或者checkout。另外一個作用是在發(fā)布軟件的時候表示哪些文件及其哪個版本是可用的;各文件不同revision可以包括在一個tag中。如果命名一個已存在的tag默認(rèn)將不會覆蓋原來的;Branch(分支)當(dāng)用戶修改一個branch時不會對另外的branch產(chǎn)生任何影響??梢栽谶m當(dāng)?shù)臅r候通過合并的方法將兩個版本合起來;branch總是在當(dāng)前revision后面加上一個偶數(shù)整數(shù)(從2開始,到0結(jié)束),所以branch總是奇數(shù)個數(shù)字,比如1.2后面branch為1.2.2,該分支下revision可能為,,...Conflict(沖突)完全是純文本的沖突,不包含邏輯上的矛盾,比如CVS不能解決如下問題:某人修改了函數(shù)f的參數(shù),而另外一個人在另外一個地方用老的參數(shù)調(diào)用該函數(shù)。文本沖突需要用戶自己參與解決,CVS無法自動解決。(如還有不明之處,請聯(lián)系飄揚(yáng),你可以到我的博客(飄揚(yáng)博客)給我留言或QQ47720194,我會盡力解答你的問題。)
Module(模塊):CVS服務(wù)器根目錄下的第一級子目錄。通常用于存放一個項目的所有文件Checkout(檢出):通常指將倉庫中的一整個模塊首次導(dǎo)出到本地。Checkin(導(dǎo)入)::通常指通過提交整個目錄結(jié)構(gòu)并創(chuàng)建一個新的模塊。Release(發(fā)行版本):整個產(chǎn)品的版本Update(更新):從模塊中下載其他人的修改過的文件。更新本地的拷貝。Commit(提交):將自己修改過的文件提交到模塊中。二、Linux下CVS服務(wù)器與客戶端的配置與使用1、Linux下CVS服務(wù)器的配置在RedHatLinux7.1之后的版本上,都有自動安裝CVS服務(wù)器軟件,只要對該軟件進(jìn)行設(shè)置,即可使用。此次配置我用的是虛擬機(jī)VMware環(huán)境下的linuxredhat9.0,下面是具體的配置過程。1.1創(chuàng)建cvs組并加入用戶在root權(quán)限下,創(chuàng)建一個cvs組并加入成員1)倉0建組:groupaddcvs2)打開/etc/group文件,找到該組,如cvs:x:514:,在后面添加要加入的用戶,比如piaoyang,chen等,以逗號隔開,編輯結(jié)果是:cvs:x:514:piaoyang,chen只有加入這個組中的成員才能進(jìn)行相關(guān)CVS操作。保存該文件。1.2創(chuàng)建一個倉庫假定將CVSROOT指向/usr/local(也可以指向別的目錄),用root登錄。1)倉0建cvsroot目錄:mkdir/usr/local/cvsroot
2)設(shè)置該目錄的模式:chmod1777/usr/local/cvsroot3)修改環(huán)境變量:exportCVSROOT=/usr/local/cvsroot4)cvsinit這樣就創(chuàng)建了CVSROOT。5)更新環(huán)境變量:#source/etc/profile此時系統(tǒng)已經(jīng)認(rèn)識$CVSROOT這樣的環(huán)境變量1.3裝入源代碼1)進(jìn)入代碼所在目錄:cd[sourcedir],如cdtest2)裝載cvsimport-m"[repositorytest]"[cvstest][vendortag][releasetag]-m后面引號內(nèi)填入log內(nèi)容,接下來是源代碼模塊名稱,接著是裝載者,最后是標(biāo)識符號,例如:cvsimport-m—CVStestllcvstestpiaoyangstartcvs組中的用戶也可以創(chuàng)建倉庫,但必須有寫權(quán)限,該權(quán)限的設(shè)置在下面將會提到。(如還有不明之處,請聯(lián)系飄揚(yáng),你可以到我的博客(飄揚(yáng)博客)給我留言或QQ47720194,我會盡力解答你的問題。)1.4設(shè)置權(quán)限cvs初始化結(jié)束以后,在管理員用戶(這里是cvs用戶)的主目錄/usr/local/cvsroot/下有一個CVSROOT目錄,這個目錄里有三個配置文件:readers,writers,passwd。我們可以通過設(shè)置這三個文件來配置CVS服務(wù)器用戶的權(quán)限,下面分別介紹這幾個文件的作用:readers文件:此文件中的用戶允許對模塊進(jìn)行讀取,不允許寫入;writers文件:此文件中的用戶允許對模塊進(jìn)行讀取和寫入;
passwd文件:此文件存儲用戶名和密碼,當(dāng)用戶登錄時進(jìn)行驗(yàn)證;readers和writers的格式如下,每個用戶占據(jù)一行:aaabbbcccpasswd文件的格式如下,每個用戶占據(jù)一行:[cvs用戶名]:[加密的口令]:[等效系統(tǒng)用戶名]如:piaoyang:$1$rPVPciBw$IK3fb4jO7hQbPXFjK3ee..:piaoyang其中—piaoyang:$1$rPVPciBw$IK3fb4jO7hQbPXFjK3ee..:||從/etc/shadow中拷貝過來。上面三個文件在缺省安裝的時候可能都不存在,需要我們自己創(chuàng)建,好吧,現(xiàn)在還是讓我們用一個例子來說明吧。假設(shè)我們有下面幾個用戶需要使用cvs:laser,gumpwu,henry,betty,anonymous其中l(wèi)aser和gumpwu是系統(tǒng)用戶,而henry,betty,anonymous我們都不想給系統(tǒng)用戶權(quán)限,并且betty和anonymous都是只讀用戶,而且anonymous更是連口令都沒有。然后編輯cvs管理員家目錄里CVSROOT/passwd文件,加入下面幾行:laser:$xxefajfka;faffa33:cvspubgumpwu:$ajfaal;323r0ofeeanv:cvspubhenry:$fajkdpaieje:cvspubbetty:fjkal;ffjieinfn/:cvspub
anonymous::cvspub注意:上面的第二個字段(分隔符為:)是密文口令,從/etc/shadow中拷貝過來即可(此方法適合cvs用戶較少的情況,如果用戶過多,則需要自己用程序生成密碼了)。編輯readers文件,加入下面幾行:anonymousbetty編輯writer文件,加入下面幾行:lasergumpwuhenry這樣就ok了,你再用幾個用戶分別登陸測試,就會發(fā)現(xiàn)一切都o(jì)k了。這里面的原理和說明我想就不多說了,其實(shí)很簡單,和系統(tǒng)管理用戶的概念是一樣的。1.5設(shè)置開機(jī)自動運(yùn)行CVS1)在/etc/xinetd.d目錄下生成一個文件cvspserver。輸入命令:touchcvspservervicvspserver在cvspserver文件里寫入如下內(nèi)容并保存:CVS:currentversioncontrlsystemDEFAULT:servicesisenable#
#servicecvspserver{socket_type=streamprotocol=tcpwait=nouser=rootserver=/usr/bin/cvsserver_args=-f--allow-root=/usr/local/cvsrootpserverlog_on_success+=USERIDlog_on_failure+=USERIDdisable=no}2)修改該文件權(quán)限:chmod644cvspserver3),到./etc/rc.d/init.d路徑下,運(yùn)行如下指令重新啟動xinetd即可:./xinetdrestart4)重啟后用root登錄,察看cvs服務(wù)器是否已經(jīng)運(yùn)行:netstat-l|grepcvspserver
如果返回tcp00*:cvspserver*:*LISTEN,則說明cvs服務(wù)器已經(jīng)運(yùn)行。2、Linux下CVS客戶端的配置為了連接到CVS資源庫,您需要知道稱為"CVSROOT"的路徑。CVSROOT是一個字符串,就象URL,它告訴CVS用戶遠(yuǎn)程資源庫在哪里,以及如何連接它。不僅如此,根據(jù)CVS資源庫是本地的還是遠(yuǎn)程的,以及連接到它的不同方式,CVS還有許多不同的CVSROOT格式。2.1連接CVS服務(wù)器當(dāng)然你必須擁有cvs用戶帳號和密碼,以及相關(guān)權(quán)限。在Linux環(huán)境下:1)本地CVSROOTexportCVSROOT=/usr/local/cvsroot(告訴CVS客戶端,存放代碼的資源庫在什么地方)一個實(shí)際的例子,在版本管理員將代碼庫存放在的機(jī)器上,路徑為:/usr/local/cvsroot(如果你tel
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 福州英華職業(yè)學(xué)院《專項理論與實(shí)踐II》2023-2024學(xué)年第二學(xué)期期末試卷
- 2025河北省建筑安全員C證考試(專職安全員)題庫附答案
- 蘇州市職業(yè)大學(xué)《渦輪發(fā)動機(jī)飛機(jī)結(jié)構(gòu)與系統(tǒng)》2023-2024學(xué)年第二學(xué)期期末試卷
- 遼寧科技學(xué)院《起重機(jī)械結(jié)構(gòu)力學(xué)》2023-2024學(xué)年第二學(xué)期期末試卷
- 南陽師范學(xué)院《網(wǎng)絡(luò)經(jīng)濟(jì)》2023-2024學(xué)年第二學(xué)期期末試卷
- 浙江科技學(xué)院《環(huán)境數(shù)據(jù)處理》2023-2024學(xué)年第二學(xué)期期末試卷
- 滄州幼兒師范高等專科學(xué)?!对\斷學(xué)基礎(chǔ)A》2023-2024學(xué)年第二學(xué)期期末試卷
- 宿州航空職業(yè)學(xué)院《基地社工服務(wù)與田野基地建設(shè)》2023-2024學(xué)年第二學(xué)期期末試卷
- 重慶城市管理職業(yè)學(xué)院《口腔固定修復(fù)學(xué)》2023-2024學(xué)年第二學(xué)期期末試卷
- 江西冶金職業(yè)技術(shù)學(xué)院《內(nèi)燃機(jī)學(xué)》2023-2024學(xué)年第二學(xué)期期末試卷
- 氬氣安全技術(shù)說明書MSDS
- 汽車運(yùn)行材料ppt課件(完整版)
- 四年級數(shù)學(xué)下冊教案-練習(xí)一-北師大版
- GB∕T 1732-2020 漆膜耐沖擊測定法
- 2022《化工裝置安全試車工作規(guī)范》精選ppt課件
- Q∕GDW 12067-2020 高壓電纜及通道防火技術(shù)規(guī)范
- 汽車系統(tǒng)動力學(xué)-輪胎動力學(xué)
- 《經(jīng)濟(jì)研究方法論》課程教學(xué)大綱
- 10T每天生活污水處理設(shè)計方案
- 中國民航國內(nèi)航空匯編航路314系列航線
- 山西特色文化簡介(課堂PPT)
評論
0/150
提交評論