源代码管理工具
?
一. 源代碼管理工具概述
1. 源代碼管理工具的作用?
> 能追蹤一個(gè)項(xiàng)目從誕生一直到定案的過(guò)程 > 記錄一個(gè)項(xiàng)目的所有內(nèi)容變化,無(wú)限制返回 > 查看特定版本的修訂情況2. 常見(jiàn)的源代碼管理工具有哪些?
> CVS- 開(kāi)啟版本控制之門(mén)- 1990年誕生,“遠(yuǎn)古時(shí)代”的主流源代碼管理工具 > SVN- 全稱是Subversion,集中式版本控制之王者- 是CVS的接班人,速度比CVS快,功能比CVS多且強(qiáng)大- 在國(guó)內(nèi)軟件企業(yè)中使用最為普遍(70%-90%) > GIT- 一款偉大的分布式源代碼管理工具- 目前被越來(lái)越多的開(kāi)源項(xiàng)目使用- 不過(guò)在國(guó)內(nèi)企業(yè)尚未大范圍普及3. 集中式和分布式的區(qū)別
集中式和分布式資料鏈接
集中式和分布式資料鏈接
集中式和分布式資料鏈接
二. SVN的基本介紹
1. 工作場(chǎng)景
2. 角色解釋
> 服務(wù)器: 用于存放所有版本的代碼,供客戶端上傳下載更新 > 客戶端: 通過(guò)客戶端下載上傳本地代碼 > 用戶名/密碼: 驗(yàn)證人員身份,判斷是否有操作權(quán)限;3. 項(xiàng)目開(kāi)發(fā)中的基本操作
> 1. 項(xiàng)目經(jīng)理初始化項(xiàng)目結(jié)構(gòu)并上傳到服務(wù)器 > 2. 苦逼程序猿根據(jù)地址+用戶名+密碼下載一份完整代碼到本地 > 3. 開(kāi)始開(kāi)發(fā),任務(wù)完成后,提交任務(wù)代碼到服務(wù)器 > 4. 從服務(wù)器上更新其他同事的代碼到本地4. 以上操作對(duì)應(yīng)到SVN操作體現(xiàn)
> 1. svn import (項(xiàng)目經(jīng)理做的) > 2. svn checkout : 將服務(wù)器所有代碼下載到本地 > 3. svn commit : 提交本地最新代碼到服務(wù)器 > 4. svn update : 從服務(wù)器更新最新被修改的代碼5. 版本控制策略(補(bǔ)充)
> svn : 更新-修改-合并* 弊端:合并時(shí)容易產(chǎn)生沖突 > 其他版本控制策略: 鎖定-修改-解鎖* 弊端:不能并行開(kāi)發(fā)三. SVN服務(wù)器配置
服務(wù)器作用
> 用于存儲(chǔ)/備份各個(gè)版本的代碼> 供客戶端下載/上傳/刪除代碼服務(wù)器環(huán)境搭建
Mac 下直接配置(Mac 下安裝SVN), (Mac下配置SVN 服務(wù)器
Windows下安裝Visual SVN Server(Visual SVN Server下載地址
?因?yàn)樽鳛樾氯诉M(jìn)到公司無(wú)法接觸服務(wù)器,而且大部分公司都是使用windows 作為服務(wù)器,所以此處只講第二種,作學(xué)習(xí)測(cè)試使用!
安裝步驟
> 全程”下一步”,傻瓜式安裝.控制區(qū)幾個(gè)選項(xiàng)的作用
> Repository- 代碼倉(cāng)庫(kù):存放不同版本的代碼> Users- 用戶列表:創(chuàng)建或者刪除用戶,代碼倉(cāng)庫(kù)設(shè)置訪問(wèn)權(quán)限時(shí)使用> Groups- 分組列表:將用戶分組,可以針對(duì)每組進(jìn)行代碼倉(cāng)庫(kù)訪問(wèn)授權(quán)操作訪問(wèn)測(cè)試
> 可以通過(guò)瀏覽器,輸入代碼倉(cāng)庫(kù)地址進(jìn)行訪問(wèn)- 注意:在客戶端瀏覽器訪問(wèn)時(shí),注意地址需要使用對(duì)應(yīng)的IP地址,不能使用計(jì)算機(jī)名稱.操作補(bǔ)充
在windows下面查看ip 地址開(kāi)始 —> 運(yùn)行 cmd 在命令行里面 運(yùn)行 ipconfig四. UNIX基本命令
1. 必學(xué)命令
help [子命令] : 查看某一個(gè)具體的子命令的使用方法2. 常用命令
- cd path : 將當(dāng)前路徑切換到path路徑 - pwd :查看當(dāng)前所在路徑 - ls (-a / -l / -G) : 查看當(dāng)前文件夾下所有文件及文件夾 - touch filename1 filename2 : 創(chuàng)建一個(gè)或者多個(gè)文件 - rm filename : 刪除文件 - open filename :打開(kāi)文件 - cat filename :查看文件內(nèi)容 - more filename :分頁(yè)查看文件內(nèi)容 - mkdir 文件夾名稱 :創(chuàng)建一個(gè)文件夾 - mv oldFilePath newFilePath :移動(dòng)文件(可借助此命令給文件重命名)3. 補(bǔ)充
. 代表當(dāng)前文件路徑 .. 代表上級(jí)目錄以 .開(kāi)頭的文件,代表隱藏文件* 顯示隱藏文件defaults write com.apple.finder AppleShowAllFiles Yes && killall Finder* 不顯示隱藏文件defaults write com.apple.finder AppleShowAllFiles No && killall Finder4. 使用注意
1> 命令和參數(shù)之間需要添加空格 2> 如果要使用當(dāng)前目錄中的文件名,輸入到一半時(shí),按TAB鍵能夠補(bǔ)全五. SVN終端演練(個(gè)人開(kāi)發(fā))
1. 命令格式
命令行格式:svn <subcommand> [options] [args]svn 子命令 [選項(xiàng)] [參數(shù)]其中中括號(hào)里面的內(nèi)容可以省略2. 必學(xué)命令
svn [子命令] --help svn help [子命令]3. 實(shí)戰(zhàn)演練
項(xiàng)目經(jīng)理初始化項(xiàng)目,并上傳到SVN服務(wù)器
方案1: (1) 創(chuàng)建臨時(shí)項(xiàng)目(2) svn import [path] URL --username=用戶名 --password=密碼 -m "注釋"方案2:(1) svn checkout URL [path] --username=用戶名 --password=密碼 : 初始化本地倉(cāng)庫(kù)(2) 創(chuàng)建項(xiàng)目(3) 使用 svn add 命令將項(xiàng)目所有文件添加到本地版本控制(4) 使用 svn commit 提交本地項(xiàng)目到遠(yuǎn)程服務(wù)器程序猿從服務(wù)器下載一份完整代碼到本地開(kāi)始開(kāi)發(fā)
svn checkout URL [path] --username=用戶名 --password=密碼修改文件提交
(1) 修改文件(2) 使用svn commit -m "注釋" : 提交本地文件到服務(wù)器新建文件提交
(1) 新建文件(2) 使用 svn add 命令將項(xiàng)目所有文件添加到本地版本控制(3) 使用 svn commit -m "注釋" : 提交本地項(xiàng)目到遠(yuǎn)程服務(wù)器刪除文件提交
一定不要手動(dòng)刪除文件
(1) svn remove filename 或者 svn delete filename 從本地版本控制以及對(duì)應(yīng)文件刪除(2) svn commit -m "注釋" : 提交本地操作到服務(wù)器, 使服務(wù)器也刪除對(duì)應(yīng)的文件常用命令補(bǔ)充
1. svn status 查看當(dāng)前工作空間內(nèi), 所有 有變化的文件 的狀態(tài)如果執(zhí)行此命令什么都沒(méi)輸出, 代表本地沒(méi)有東西要提交2. svn log 查看當(dāng)前版本的操作日志(什么人, 什么時(shí)間, 做了什么操作)版本控制中,各個(gè)文件狀態(tài)參考
' ' 沒(méi)有修改'A' 被添加到本地代碼倉(cāng)庫(kù)'C' 沖突'D' 被刪除(通過(guò)svn命令刪除的文件)'I' 被忽略'M' 被修改'R' 被替換‘G’ 被合并‘U’ 已經(jīng)更新‘E’ 已經(jīng)存在'X' 外部定義創(chuàng)建的版本目錄'?' 文件沒(méi)有被添加到本地版本庫(kù)內(nèi)'!' 文件丟失或者不完整(不是通過(guò)svn命令刪除的文件)'' 受控文件被其他文件阻隔注意事項(xiàng)
* 任何本地的操作, 如果想讓服務(wù)器也做同樣的操作, 就直接通過(guò) commit操作 提交到服務(wù)器*?任何向服務(wù)器提交的操作,都要加注釋 添加 -m參數(shù)六. SVN終端演練(多人開(kāi)發(fā))
準(zhǔn)備工作
熊大和熊二,分別通過(guò)svn checkout URL [path] --username=用戶名 --password=密碼 命令初始化本地版本控制庫(kù)添加文件同步
1. 熊大創(chuàng)建文件并提交到服務(wù)器svn add fileNamesvn commit -m "新增文件"2. 熊二從服務(wù)器更新文件svn update修改文件同步
1. 熊大修改文件并提交到服務(wù)器svn commit -m "修改文件"2. 熊二從服務(wù)器更新文件svn update刪除文件同步
1. 熊大刪除文件并提交到服務(wù)器svn delete fileNamesvn commit -m "刪除文件"2. 熊二從服務(wù)器更新文件svn update多人合作開(kāi)發(fā)中的常見(jiàn)問(wèn)題
* 問(wèn)題一 : 超時(shí)問(wèn)題描述:當(dāng)本地文件版本小于服務(wù)器文件版本時(shí), 如果要提交本地文件,就會(huì)報(bào) out of date 超時(shí)錯(cuò)誤產(chǎn)生原因:SVN通過(guò)版本號(hào)管理每一個(gè)文件,如果一個(gè)文件被修改并提交到服務(wù)器,那么服務(wù)器上的對(duì)應(yīng)文件版本號(hào)就會(huì)加1, 如果你的版本號(hào)小于服務(wù)器版本號(hào),就說(shuō)明,肯定有別人在后來(lái)又修改了那個(gè)文件解決方案:針對(duì)于超時(shí)問(wèn)題,對(duì)應(yīng)的解決方案,就是先從服務(wù)器更新下最新版本, 保證本地版本號(hào)與服務(wù)器版本號(hào)一致,這是文件可以提交的前提* 問(wèn)題二 : 沖突問(wèn)題描述:為了解決超時(shí)問(wèn)題,只能更新.而在更新過(guò)程中,如果幾個(gè)人修改了同一文件的同一行代碼,此時(shí)就會(huì)產(chǎn)生沖突產(chǎn)生原因:版本控制器不會(huì)那么智能, 去決定應(yīng)該使用誰(shuí)的代碼作為最終代碼,只能將選擇權(quán)拋給用戶,讓用戶解決解決方案:系統(tǒng)提供三種解決方案:(p) postpone, 延遲處理(待會(huì)我自己處理), 如果選擇這一種, 會(huì)自動(dòng)生成三個(gè)文件供用戶參考決策. 并將沖突部分代碼塊合并到一起. 而一旦解決完畢, 需要執(zhí)行 svn resloved fileName 來(lái)告訴版本控制器已經(jīng)解決, 然后版本控制器就會(huì)自動(dòng)刪除三個(gè)參考文件(mc) mine-conflict使用我的(本地的), 如果代碼產(chǎn)生沖突, 則以本地代碼為準(zhǔn)(tc) theirs-conflict使用他人的(服務(wù)器), 如果代碼產(chǎn)生沖突, 則以服務(wù)器代碼為準(zhǔn)七. SVN終端演練-版本回退
版本回退概念以及原因?
概念: 是指將代碼(本地代碼或者服務(wù)器代碼), 回退到之前記錄的某一特定版本原因: 如果代碼做錯(cuò)了, 想返回之前某個(gè)狀態(tài)重做;修改了,但未提交的情況下, 回退代碼
方案1: (大力推薦)svn revert (作用:返回到上次提交后版本對(duì)應(yīng)的最原始的狀態(tài))方案2: (不推薦)刪除整個(gè)項(xiàng)目,重新checkout修改了,并且提交了的情況反悔
方案1: 大力推薦- svn update (作用: 將本地代碼更新到與服務(wù)器相同的版本)- svn merge 文件名 -r 版本1:版本2(作用: 把版本1 -> 版本2 的 diff 作用在當(dāng)前版本)- svn commit -m “本地和服務(wù)器都回退到某一指定版本”(作用: 讓服務(wù)器代碼也退回到之前某個(gè)版本狀態(tài))方案2: - svn update -r 指定版本號(hào)(此時(shí)本地代碼已經(jīng)變化,但是服務(wù)器沒(méi)有改變)*--------以下步驟是為了讓服務(wù)器代碼也回滾到以前的版本----------*- 修改部分文件- svn update (此時(shí)會(huì)產(chǎn)生沖突, 選擇使用自己的代碼即可)- 再次提交代碼方案3:- 手動(dòng)保存需要回退的文件內(nèi)容- 刪除文件,提交到服務(wù)器- 重新添加文件,上傳到服務(wù)器八.Cornerstone基本使用
九. Xcode管理SVN
開(kāi)發(fā)經(jīng)驗(yàn): 最好忽略沒(méi)必要提交的文件
**?過(guò)濾不需要上傳的文件, 忽略文件(xcuserdata文件夾)**> 文件打開(kāi)狀態(tài)> 斷點(diǎn)信息> 文件夾關(guān)閉打開(kāi)狀態(tài) **?注意:projct setting文件不要忽略?**> 存放一些文件順序和文件夾結(jié)構(gòu),文件引用等信息十. SVN目錄規(guī)范
文件目錄作用?
trunk : 主干,當(dāng)前開(kāi)發(fā)項(xiàng)目的主目錄;我們之前更新代碼,提交代碼都是在這個(gè)文件夾進(jìn)行操作brannches:分支目錄添加非主線功能時(shí)使用,開(kāi)發(fā)測(cè)試之后,可以合并到主干項(xiàng)目中。修復(fù)Bug,研發(fā)不確定的新功能都在這里做tags:標(biāo)記目錄,通常作為重大版本的備份;如果有發(fā)布版本出現(xiàn)Bug,可以快速的找到對(duì)應(yīng)版本的項(xiàng)目備份,然后開(kāi)一個(gè)分支,進(jìn)行Bug修復(fù),用于與主干區(qū)分掌握利用圖形客戶端版本備份流程
轉(zhuǎn)載于:https://www.cnblogs.com/fangwenkai/p/5659771.html
總結(jié)
- 上一篇: QPushButton
- 下一篇: 批处理打开共享路径