好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > git 入門教程之本地倉庫和遠程倉庫的本質介紹

git 入門教程之本地倉庫和遠程倉庫的本質介紹

熱門標簽:蘇州呼叫中心外呼系統哪家強 400電話申請到底哪家好 宿遷怎么辦理400電話 谷歌地圖標注日期 外呼系統怎么群發短信 地圖標注項目幾個月 400電話辦理費用低 鶴壁高頻外呼系統多少錢一個月 聯通外呼系統電腦app軟件

本地倉庫和遠程倉庫在本質上沒有太大區別,只不過一個是本地電腦,一個是遠程電腦.

遠程倉庫不一定非得是 github 那種專門的"中央服務器",甚至局域網的另外一臺電腦也可以充當"中央服務器"的角色,因為它存在的最初目的只是方便大家交換彼此的提交記錄而已!

所以本地倉庫和遠程倉庫的基本行為應該是一致的,約定俗成的規定是遠程倉庫一般不直接參與日常開發工作,主要作為項目托管中心.

某些自動化持續集成環境中也可能會直接操作遠程倉庫,這時遠程倉庫就真的和本地倉庫沒什么區別了!

個人開發常用命令

個人開發看重的是效率,同時兼顧下版本控制的話算是是錦上添花,git 的本地倉庫是本地備份,而遠程倉庫則是網盤備份.

git init : 初始化本地項目

將本地項目初始化 git 項目,直觀表現是在該項目同級目錄下多了 .git 隱藏目錄,其存儲著 git 版本庫相關信息.

此后當前項目便具備了本地管理的能力,可以與 git 進行交互.

git clone : 克隆遠程項目

git init 一樣的作用,也是創建本地倉庫,只不過 git init 是直接將本地項目作為本地倉庫,而git clone 是將遠程項目克隆到本地并作為本地倉庫.

由此可見,git clonegit init 多了一層遠程倉庫的概念.

git add : 添加文件

將工作區的提交記錄添加到暫存區,暫存區是工作區和版本庫交互的橋梁,暫存區積累到一定量的提交記錄時可以批量提交到版本庫,這一點暫存區有點像緩存.

git commit : 提交文件

將暫存區的版本提交到版本庫,從而形成工作區->暫存區->版本庫的基本鏈路,本地工作區的版本控制流程大致如此.

git push : 推送文件

如果是使用 git clone 命令克隆的本地項目,當工作到一定程度時可能需要將這部分工作成果推送到遠程倉庫,這時候使用 git push 命令完成本地版本的推送流程.

如果是使用 git init 命令初始化的本地項目,可能沒有遠程倉庫,自然也就不需要推送.如果后來創建了遠程倉庫,那么你自然是想要將本地倉庫推送到遠程倉庫的,因此你需要準確告訴 git 你要推送到哪個遠程倉庫.
使用 git remote add origin git@github.com:username/repos.git 命令添加遠程倉庫信息,這樣就建立了本地倉庫和遠程倉庫的關聯,以后就可以正常推送到遠程倉庫了.

團隊開發常用命令

團隊開發注重的不僅是個人效率還有團隊的整體進度,隨著企業級開發的日趨復雜化,不再是一個人能夠獨立完成的,更何況時間也不允許慢慢完成,大多數公司采用的是人力換時間的方式,團隊并行開發來縮短整個項目周期,這種復雜需求下正是 git 大展拳腳的好機會.

項目整體采用并行開發模式,拆解成不同的功能模塊,每個人負責各自模塊,模塊之間相對獨立但也不排除存在交集的可能性.對于每一個個體開發者來說,既需要版本控制又需要團隊交流.這時候分支的作用就凸顯出來了.

根據項目的業務特點將其拆解成不同的功能模塊,這些功能模塊分別代表不同的分支,而這些功能模塊又組成了完整的項目,這就是主干和分支的關系.

初始時項目是一個整體,中間拆解成不同功能模塊,最后再合并成一個整---"分久必分合久必分".

git branch branch> : 創建分支

每一個獨立的功能模塊被定義成一個單獨分支,創建分支的過程其實是拆解項目的過程,創建本地分支后就在分支上開發特有功能,不再關心其他功能分支.

git checkout branch> : 切換分支

模塊拆解完成并創建了相應的分支后,需要切換到既定分支上才能開展自己的工作.

git merge branch> : 合并分支

沒有絕對的獨立,項目再怎么拆分也是整體的一部分,肯定需要和其他功能模塊發生關系,某些情況下需要其他分支的工作成果合并到自己的本地倉庫中,這樣才能完成一次小規模的組裝.

可以預期的是,當這種組裝足夠多的時候,最終便會演變成項目的終極形態,形成一個整體.

git fetch : 抓取遠程分支

合并目標分支首先需要能夠獲取到目標分支的提交記錄,既然每個功能模塊都是不同的項目成員負責開發的,也就不在我們電腦上,所以我們先要將目標分支下載到我們本地電腦,然后才能合并該分支到本地分支.

git pull : 拉取遠程分支

"先下載目標分支再合并到本地分支,從而小規模組成更復雜更強大的功能",每一次的組裝過程都需要兩步操作者顯然不符合懶人思維啊,git pull 就是這兩步操作的簡化命令,先下載再合并就是這么簡單!

本地和遠程倉庫的碰撞

不論是個人開發還是團隊開發,我們幾乎習慣慣站在主動方的角度來思考問題,有沒有想過當遠程倉庫接收到我們的git pushgit pull 請求時,遠程倉庫發什么了什么改變,這種改變對本地倉庫又有什么影響?

遠程倉庫(遠程電腦上的本地倉庫)只是眾多分布式電腦上本地倉庫中的一員,說它特殊也很特殊,充當著"中央服務器"作用,其余人統一從這里下載或推送;說它普通也很普通,和本地電腦上的本地倉庫沒有什么不同,因為它隨時可被任意電腦上的本地倉庫所取代!

揭開遠程倉庫的神秘面紗后,現在我們只需要將其視為普通的本地倉庫一樣對待即可,然而我們本地電腦上已經有了本地倉庫,故而需要將遠程倉庫做一下簡單標識區分(origin)稱之為遠程分支.

先說說 git push 命令做了什么?

  • 對于本地來說,git 將本地倉庫的指定分支推送到遠程倉庫的相應分支,同時更新了本地倉庫的遠程分支.
  • 對于遠程來說,git 接收到本地倉庫的推送請求時應該在相應分支上合并本地分支,同時更新遠程倉庫的相應分支.

只要本地的指定分支成功推送到遠程的相應分支時,對于本地來說,不論是指定分支還是遠程分支(origin/master)都應該是最新狀態,因為已經與服務器同步了.

而遠程接收到此次推送請求時,應該嘗試合并此次推送請求,再更新自己的相應分支,遠程合并完成后再通知本地此次推送結果,如此一來,三端同步,皆大歡喜!

再講講 git pull 命令發生了什么?

  • 對于遠程來說,接收到本地的拉取請求時,因為沒有新版本需要處理,所以無需任何操作.
  • 對于本地來說,當遠程倉庫的相應分支下載到本地時應該更新遠程分支狀態,再嘗試合并到本地的相應分支.

git pull 命令或者說是 git fetch 命令是本地和遠程通信的方式,所以 origin/master 會自動更新!

小結

本地倉庫和遠程倉庫本質上沒有太大區別, git fetch 是本地倉庫和遠程倉庫之間的通信途徑,本地倉庫中的遠程分支(origin/master)保存著它們之間最后一次的通信狀態.

到此這篇關于git 入門教程之本地倉庫和遠程倉庫的本質介紹的文章就介紹到這了,更多相關git 本地和遠程倉庫內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 詳解Git建立本地倉庫的兩種方法
  • Git本地倉庫基本操作及技巧
  • 微信小程序使用gitee進行版本管理
  • Git建立本地倉庫并上傳到Gitee的詳細步驟

標簽:雙鴨山 哈爾濱 丹東 錫林郭勒盟 遵義 鄂爾多斯 莆田 襄陽

巨人網絡通訊聲明:本文標題《git 入門教程之本地倉庫和遠程倉庫的本質介紹》,本文關鍵詞  git,入門教程,之,本地,倉庫,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《git 入門教程之本地倉庫和遠程倉庫的本質介紹》相關的同類信息!
  • 本頁收集關于git 入門教程之本地倉庫和遠程倉庫的本質介紹的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 亚洲精品日本高清中文字幕 | 日本护士xnxnxn视频| 亚洲视频一区二区| 色yeye香蕉凹凸一区二区下载| 白丝校花被c得合不拢腿H漫画| 男人吃奶摸下面挵进去高潮| 26uuu天天夜夜综合| 成人免费毛片视频| 免费黄色在线网址| 黄色免费软件| free性老太xx| 久久夜色精品亚洲AV| 欧日韩高清aV在线| 淫春院| 校花娇躯被学长抽搐呻吟| 故意坐公交忘穿内裤被挺进小说 | 亚洲综合在线观看一区| 97超碰国产亚洲精品理论电影 | 嗯灬啊灬快灬高潮啊灬水下载| 蜜桃my.1688.com| 成人无高清96免费| 临潭县| 体育生囊袋榨精虐睾调教| 中文字幕特黄A片毛片不卡| 成人午夜app| 日韩美女乱淫试看视频大| 色yeye成人免费视频| 图书馆的秘密+全部都是你| 粉嫩AV一区二区在线观看视频| 成人毛片18女人毛片免费看3D动漫| 国产成人精品国内自产拍游戏推荐| 免费**毛片夜夜看| 快穿若若情事| 久久亚洲精品玖玖玖玖| 性生交大片免费看狂欲| 苗族三级三级在线观看| 我的嫂子在线观看| 男同hd| 羞羞网站| 成 年 人 视频app免费无病毒| 韩国a级片在线观看|