• <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>

            牽著老婆滿街逛

            嚴(yán)以律己,寬以待人. 三思而后行.
            GMail/GTalk: yanglinbo#google.com;
            MSN/Email: tx7do#yahoo.com.cn;
            QQ: 3 0 3 3 9 6 9 2 0 .

            GIT學(xué)習(xí)筆記(一)

            版權(quán)聲明:轉(zhuǎn)載時請以超鏈接形式標(biāo)明文章原始出處和作者信息及本聲明
            http://jjuan-flake.blogbus.com/logs/106556090.html

            由于之前配過CSV使用過SVN,剛接觸GIT時不能區(qū)分GIT與前類版本控制系統(tǒng)之間的區(qū)別,使用對SVN的了解來試圖直接使用GIT。但其實兩者之間后較大的區(qū)別,他們功能相同,實現(xiàn)方式卻差異很大。
            1.部署差異:
            1.1.集中式版本控制系統(tǒng)
             SVN與CSV同屬于集中式版本控制系統(tǒng),所謂集中式即進(jìn)行版本控制權(quán)限在服務(wù)器上,服務(wù)器保存所有文件的修訂版,各開發(fā)終端只是將服務(wù)器上最新的修訂版取回,然后提交更改后的版本。終端并不保存文件的所有修訂版。
             示意圖:點擊查看原始尺寸
                
             這種方式對系統(tǒng)穩(wěn)定性要求較高,因為只有服務(wù)器存儲了一個完整的版本。
            1.2 分布式版本控制系統(tǒng)
             GIT屬于分布式版本控制系統(tǒng),顧名思義,分布式即各終端都參與到整個版本控制系統(tǒng)中來。開發(fā)終端保存的不是最新版本的鏡像,而是整個版本庫,是整個版本控制系統(tǒng)的完整備份。因此每次加入一個已有的代碼庫時使用的是clone【克隆】操作。
             示意圖:
             
            2. 存儲差異
            2.1 差異存儲(CVS,SVN)
             CVS,SVN這類版本控制系統(tǒng)中,各版本存儲的是修改后的文件與原之間的差異信息,每次記錄文件內(nèi)容的具體哪個部分發(fā)生了什么變化。

            2.2 快照存儲
             GIT則只關(guān)心文件的整體變化,在每次版本變化時將此時的文件狀態(tài)做一個快照,只保存指向這個快照的索引信息。

            3. 對網(wǎng)路的依賴
             使用CVS和SVN需時時連接到遠(yuǎn)程服務(wù)器,而git則是在本地維護(hù)一個版本庫,所以提交等都在本地進(jìn)行,除非將更改一次性push到遠(yuǎn)程服務(wù)器,否則都不需要連接網(wǎng)絡(luò)。


            一、安裝配置(windows)
             git 擁有針對各個平臺的版本。windows下的有一個模擬shell的版本 msysgit 【http://code.google.com/p/msysgit/】在此下載最新版本。
             git的安裝過程就是經(jīng)典的windows的下一步點擊過程,如果沒有特殊選擇,使用默認(rèn)選項即可。
             git安裝之后需要做幾個配置。配置文件均在msysgit安裝目錄中etc下。

            1 shell終端的配置
             msysgit安裝之后會在開始菜單里進(jìn)入shell終端的目錄。此shell terminal 使用ls命令時不能列出中文文件。
             為了讓ls能夠列出中文文件,需要加上 --show-control-char 選項,--color=auto 選項時目錄和文件有顏色區(qū)分。為了可以直接使用ls達(dá)到我們所需效果,可在git-completion.bash文件中加入:
              alias ls='ls --show-control-char --color=auto'
              alias ll='ls -al --show-control-char --color=auto'
             給ls命令定義別名

            2 git的配置 gitconfig
             
            [gui]
             encoding=utf-8
            # 設(shè)置成代碼庫一樣的編碼,以便在git gui中正常顯示中文
            [i18n]
             commitencoding=GB2312
            #設(shè)置commit說明的編碼,windows一般是gb2312
            [user]
             email = jjuan_flake@sina.com
             name = kunjuan
            #說明提交用戶


            3 配置輸入終端 inputrc
              
              set output-meta on
              set convert-meta off 
            #使得git bash終端可輸入中文

             


            二、git的使用

            1. git init
             在本地建立版本庫時使用此命令處事化一個代碼版本控制庫
            2. git clone [url] [myname]
             在本地克隆一個已有的網(wǎng)絡(luò)上的版本庫,url協(xié)議可以是git,https等。如果加了myname則重命名版本庫的名字為myname,否則使用原名。使用clone命令時無需在本地先為代碼庫建立一個目錄,執(zhí)行clone后當(dāng)前目錄自動生成代碼庫的目錄。
             類似于svn checkout,只是此命令克隆的是整個版本庫
            3.  git add 
             把新建的一個或多個文件設(shè)定成跟蹤狀態(tài),git開始跟蹤這個文件的狀態(tài)信息。將以跟蹤的修改文件暫存。
            4. git commit [-m '注釋']
             提交暫存文件到本地代碼庫
            5. git status 
             查看本分之中文件跟蹤狀態(tài)
            6. git pull
             用遠(yuǎn)程庫更新本地庫
            7. git checkout 
             git checkout 分支名:切換到某分支下
             git checkout 文件名:更新本文件到上次提交的版本
             checkout切換分支后,此事文件狀態(tài)是此分支的,編輯某個文件,則編輯的只是這個分支的文件狀態(tài),不會碰觸其他分支的本文件。在此文件commit之前checkout到另外的分支后,還是可以看見此文件更改后的信息,在更改的分支commit之后,則切換回之前的分支后就看不見另一個分支更改的部分了。
            8. git branch 
             不加名字即查看所有分支,列表中有*的是當(dāng)前分支
             加名字則新建一個分支,
              -b 則 新建并切換至此分分支
            9.  git merge branchname
              將branchname合并到本分支
            git的工作流程
              檢出遠(yuǎn)程版本庫到本地=》[新增文件(設(shè)置跟蹤)]=》修改=》暫存【add】=》提交到本地代碼庫的本分支【commit】=》合并的master分支=》在master分支中推到服務(wù)器。

            分支
             一個指向快照的指針。


            posted on 2011-07-12 16:06 楊粼波 閱讀(900) 評論(0)  編輯 收藏 引用


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


            日本免费久久久久久久网站| 欧美日韩精品久久免费| 久久夜色精品国产噜噜麻豆| 无码久久精品国产亚洲Av影片| 亚洲国产精品一区二区久久| 久久免费视频观看| 久久免费视频6| 久久久无码一区二区三区| 国产精品永久久久久久久久久 | 精品久久久久久国产91| 久久免费国产精品| 91精品国产色综合久久| 国产精品久久久久久久app| 色综合久久88色综合天天| 久久精品国产亚洲αv忘忧草| 国产精品九九久久精品女同亚洲欧美日韩综合区 | 国产精品久久久天天影视香蕉| 久久精品极品盛宴观看| 99久久精品免费看国产| 久久精品中文字幕无码绿巨人| 亚洲国产成人精品久久久国产成人一区二区三区综 | 久久久艹| 国产精品热久久无码av| 色综合久久精品中文字幕首页| 久久久无码精品亚洲日韩按摩| 久久久久久精品免费看SSS | 91亚洲国产成人久久精品| 亚洲va久久久噜噜噜久久狠狠| 性高湖久久久久久久久AAAAA| 国内精品久久久久久久亚洲| 2021久久国自产拍精品| 中文字幕无码免费久久| 久久亚洲sm情趣捆绑调教| 亚洲欧洲久久久精品| 四虎影视久久久免费观看| 色婷婷久久综合中文久久一本| 久久精品成人欧美大片| 久久毛片免费看一区二区三区| 欧美精品丝袜久久久中文字幕| 久久精品国产精品亚洲| 亚洲精品国产自在久久|