下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、svn分支管理與增量更新 項(xiàng)目中經(jīng)常出現(xiàn)需求優(yōu)先級(jí)和進(jìn)度不同產(chǎn)生的代碼混亂,決該問題實(shí)施 svn 分支管理和增量更新。 使用環(huán)境:MyEclipseEnterpriseWorkbenchVersion:2014 svn分支管理 使用分支最主要的目的是,多個(gè)分支可以并行,相互不干擾,而且任何時(shí)候都可以合并。其 次,容易保證主干的穩(wěn)定性。 1.創(chuàng)建分支 (1)在主干項(xiàng)目右擊-Team-分支標(biāo)記。如圖所示: 無法打出需要的測(cè)試包問題。為解 ,svn插件 next。如圖所示: (3)選擇復(fù)制的版本,一般選擇最新修訂版,就是 HEAD修訂版, 點(diǎn)擊 next。如圖所示: 彈出分支 URL信息編輯框輸入
2、svn:3/sengnon/ land3,紅色部分為分支名稱,點(diǎn)擊 (4)填寫創(chuàng)建分支原因,如需要馬上切換到新分支則勾選切換選項(xiàng) 點(diǎn)擊 finish。如圖: 10復(fù)本(分支/六)I三:回雙 Branch/TagComment Enterthebranch/tagcomment. 埔人分支/標(biāo)懿注程; 若胃麥葭脆* V 選擇以前的;據(jù) A CunflQUiruRrniniuritTemHmtu%口噫L忤復(fù)本為新物濃/標(biāo)記 FinishCancel (5)切換之后結(jié)果如圖: 金島landlgengnorvl呂rid3 0費(fèi)src test Rmv.re*;t(6)在分支上修改
3、提交比較等功能與 svn普通操作一致 2.合并分支 (1)項(xiàng)目右擊-Team-切換(s), (2)切換時(shí)會(huì)彈出下圖,默認(rèn)選擇是標(biāo)記本地和要切換的地址內(nèi)容 沖突 Switch 切換至分支/標(biāo)記 Updatetheworkingegpytosnptherrevisknand/c?rlection. 至URL:svn;/l92.168r2.73/sengnon/land1 y:SwitchtoHEADrevision Revision;顯示日于 Depth:Workingcopy /Chargeworkingcopytospecifieddepth |._iIgnoreexternal? _Allo
4、wuriversionedobstructions Ignoreancest7 Conflicthandling: Textfile5: PromptmeforeachconflictandletmedecideqMarkconflicts,letmeresolvethemlater Binary制es: Promptm旺foreachconflictandletmedecideuMarkconflictsletmeresolvethemlater Resolvetheconflictbyusingmyversionofthefile REEOIvetheconflictbyLiningthe
5、inconningverEionofthefile Propertyconflicts; PromptmefcreachconflictndletmedecideoMarkconflicts,letmeresolvtthemlater Treeconflkt5: Promptmefor呼白匚hconflictandletmedecide uMarkconflicts,letmeresolvethemlater RMolvetheconflictuWngfddeofHieronflirt(keepIcealmove?1 MarkMarkresolved(localresolved(localmo
6、veswillmoveswillbecomebecomecopiedcopied CanceJOK (3)點(diǎn)擊 ok,切換成功 Jland!5erqr-T-irdl .Stsrc 由com.land (4)選擇項(xiàng)目-右擊選擇 team-合并 (5) 合 并 方 式 選 擇 , 選 擇mergearangeofrevisions, 去 掉performpre-mergebeatpracticeschecks 默認(rèn)勾選(該默認(rèn)勾選不靈活無法具體指定分支和配置),點(diǎn)擊 next。如圖: CollabNetK/lergeCollabNetK/lerge Mergeinput QMergearangeo
7、frevisio ChangeChange- -setteasedmergesetteasedmerge1 1 Mergetwodifferenttrtes IVl/initllyIVl/initllyrecordinfrrrrriFtirin(recordinfrrrrriFtirin(B B- -lockonpormort=rFlockonpormort=rF- -visionvision;) ) ,Manuallyremovemergeinfcrmatiori(unblockoneormorerevisions rgekrangeofreviiiori? 叵S3 Selectthemer
8、getype Usethismethodtocatch-upmfeaturebranchiiththechangesintrunkoranoth&rbranch.Youcanmergeaspecific5etofrevisionsoraIIeligiblerexdsions. Performpre-merebestprarticeschecks V VZeactZeact L L FinisnFinisn CancelCancel (6)在彈窗中選擇要合并的分支,以及默認(rèn)的所有合適的版本點(diǎn)擊 next。如圖: (7)彈出沖突處理設(shè)置,選擇默認(rèn)的通知我來處理點(diǎn)擊 finish。如 圖: (8)生
9、成合并結(jié)果日志。如圖: |Q|Q|MergeResultsNummaryMergeResultsNummary MergeResultsSummaty Mwrgefaultssummaryfor13ndi Filestatistic5; Updarted:0 Added:0 Exsting:0 0 Merged:0 Conflicts:0 Resolvedconflicts:0 Sldppedfile#0 Skippedfolder5:0 Prop-ert/ststistiC5i Updated:1 Merged:0 Conflits;Q ResolvedconlLcts:0 Cancel 增
10、量更新 1.生成差異文件 生成差異文件必須在提交代碼之前! (1)提交前創(chuàng)建補(bǔ)丁,右擊項(xiàng)目-Team-創(chuàng)建補(bǔ)丁。如圖: (2)設(shè)置創(chuàng)建補(bǔ)丁的配置,選擇保存到文件系統(tǒng)并指定具體的目錄 文件,在 changes 中選擇變更文件,點(diǎn)擊 next。如圖: (3)選擇要比較的根目錄,選擇 project,點(diǎn)擊 finish。如圖: 配置用于SVNd的超3的造項(xiàng) PatchRoot WorkQS(MuH-profectApplyPatchwizardspecific) 篁Project Selection 2.生成增量包 (1)使用這個(gè) Java 代碼來生成一個(gè)更新包。在 Java 類中需根據(jù)本 地情況修
11、改patchFile,projectPath,webContent,classPath,desPath。 packagemy.test; importjava.io.BufferedInputStream; importjava.io.BufferedOutputStream; importjava.io.BufferedReader; importjava.io.File; importjava.io.FileInputStream; importjava.io.FileOutputStream;BackBack FinihFinih CanceiCancei java.io.IOExcep
12、tion; java.io.InputStreamReader; java.text.SimpleDateFormat; java.util.ArrayList; java.util.Date; java.util.List; /* *paramargs * *throwsException */ publicstaticvoidgetversion()SimpleDateFormatdf=newSimpleDateFormat(yyyyMMddHHmmss);/設(shè) 置 日期格式version=df.format(newDate(); System.out.println(df.format(
13、newDate();/newDate()為 獲取當(dāng)前索統(tǒng)時(shí)間 importimportimportimportimportimport public classDeployAddTest publicstaticString patchFile=D:/patch.txt;/補(bǔ)丁文件,由 eclipsesvnplugin ,生成 publicstatic 目文件夾路徑 String projectPath=F:/wk20170221/land1;/項(xiàng) public static String webContent=WebRoot;/web應(yīng)用文件夾名 publicclassPaths存放路徑 s
14、tatic String =F:/wk20170221/land1/WebRoot/WEB-INF/classes ;/clas public staticString desPath=D:/deploy;/補(bǔ)丁文件包存放路徑 public staticString version;/補(bǔ)丁版本 */ publicstatic void main(String口args) throwsException getversion(); copyFiles(getPatchFileList (); /* * 根據(jù)時(shí)間生成版本號(hào) /* *獲取svn補(bǔ)丁文件中的變更文件列表 * */publicstati
15、cListgetPatchFileList()throws Exception ListfileList=newArrayList(); FileInputStreamf=newFileInputStream(patchFile); BufferedReaderdr=_newBufferedReader(new InputStreamReader(f,utf-8); Stringline; /根據(jù)文件中的index有效文件和版本來過濾哪些是需要打在增量包里面的文件 while(line=dr.readLine()!=null) if(line.indexOf(Index:)!=-1) line
16、=line.replaceAll(,); line=line.substring(line.indexOf(:)+1,line.length(); if(line.length()1) fileList.add(line); returnfileList; /找到變更文件列表根據(jù)路徑復(fù)制對(duì)應(yīng)class文件到更新文件夾 publicstaticvoidcopyFiles(Listlist) for(StringfullFileName:list)if(fullFileName.indexOf(src/)!=-1)/對(duì)源文件目錄下的文件處理 StringfileName=fullFileName.
17、replace(src,); fullFileName=classPath+fileName; if(fileName.endsWith(.java)fileName=fileName.replace(.java,.class); fullFileName=fullFileName.replace(.java,.class); )String tempDesPath=fileName.substring(0,fileName.lastIndexOf(/); StringdesFilePathStr=desPath+/+version+/+webContent+/WEB-INF/classes+
18、tempDesPath;StringdesFileNameStr=desPath+/+version+/+webContent+/WEB-INF/classes+fileName;FiledesFilePath=newFile(desFilePathStr); if(!desFilePath.exists()desFilePath.mkdirs(); ) copyFile(fullFileName,desFileNameStr); System.out.println(fullFileName+復(fù)制完成); else/對(duì)普通目錄的處理String desFileName=fullFileNam
19、e.replaceAll(webContent,);fullFileName=projectPath+/+fullFileName;/將要 復(fù)制的文件全路徑 StringfullDesFileNameStr=desPath+/+version+/+webContent+/+desFileName; String desFilePathStr=fullDesFileNameStr.substring(0,fullDesFileNameStr.lastIndexOf(/);FiledesFilePath=newFile(desFilePathStr); if(!desFilePath.exists()desFilePath.mkdirs();copyFile(fullFileName,fullDesFileNameStr); System.out.println(fullDesFileNameStr+復(fù)制完成 ); voidcopyFile(StringsourceFileNameStr, newFile(sourceFileNameStr); newFile(desFileNameStr);privatestat
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 廣東水利電力職業(yè)技術(shù)學(xué)院《微波技術(shù)與天線》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣東生態(tài)工程職業(yè)學(xué)院《教育活動(dòng)設(shè)計(jì)與應(yīng)用》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣東青年職業(yè)學(xué)院《設(shè)計(jì)制造綜合實(shí)訓(xùn)》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣東女子職業(yè)技術(shù)學(xué)院《功能高分子材料概論》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣東南華工商職業(yè)學(xué)院《基礎(chǔ)俄語四外方》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣東梅州職業(yè)技術(shù)學(xué)院《第二外語日語(二)》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣東嶺南職業(yè)技術(shù)學(xué)院《藥品生產(chǎn)質(zhì)里管理工程》2023-2024學(xué)年第一學(xué)期期末試卷
- 大學(xué)信息技術(shù)基礎(chǔ)福建農(nóng)林大學(xué)學(xué)習(xí)通測(cè)試及答案
- 幼兒園中班心理健康教育工作總結(jié)
- 《結(jié)直腸癌早篩早治》課件
- 2024時(shí)事政治考試100題及參考答案
- 醫(yī)療廢物轉(zhuǎn)移實(shí)施方案
- (賽斯資料)健康之道(全本)
- 工程師個(gè)人年終總結(jié)
- 汽車常識(shí)課件教學(xué)課件
- 【學(xué)易金卷】2023-2024學(xué)年四年級(jí)數(shù)學(xué)上冊(cè)期末全真模擬提高卷(三)(A4版)(北師大版)
- GB 17353-2024摩托車和輕便摩托車防盜裝置
- 學(xué)校膳食管理委員會(huì)工作制度和職責(zé)
- 房租收條格式(3篇)
- 期末試卷(試題)2024-2025學(xué)年培智生活語文二年級(jí)上冊(cè)
- 2024秋期國(guó)家開放大學(xué)本科《中國(guó)當(dāng)代文學(xué)專題》一平臺(tái)在線形考(形考任務(wù)一至六)試題及答案
評(píng)論
0/150
提交評(píng)論