這些GIT經驗夠你用一年了

使用git在本地創建一個項目的過程

$ mkdir ~/hello-world //創建一個項目hello-world$ cd ~/hello-world //打開這個項目$ git init //初始化 $ touch README$ git add README //更新README文件$ git commit -m first commit //提交更新,並注釋信息「first commit」$ git remote add origin git@github.test/hellotest.git //連接遠程github項目 $ git push -u origin master //將本地項目更新到github項目上去

git設置關閉自動換行

$ git config --global core.autocrlf false

為了保證文件的換行符是以安全的方法,避免windows與unix的換行符混用的情況,最好也加上這麼一句

$ git config --global core.safecrlf true

git tag 使用

git tag # 列出當前倉庫的所有標籤git tag -l v0.1.* # 搜索符合當前模式的標籤git tag v0.2.1-light # 創建輕量標籤git tag -a v0.2.1 -m 0.2.1版本 # 創建附註標籤git checkout [tagname] # 切換到標籤git show v0.2.1 # 查看標籤版本信息git tag -d v0.2.1 # 刪除標籤git tag -a v0.2.1 9fbc3d0 # 補打標籤git push origin v0.1.2 # 將v0.1.2標籤提交到git伺服器git push origin --tags # 將本地所有標籤一次性提交到git伺服器git tag # 查看當前分支下的標籤

git pull問題

You asked me to pull without telling me which branch youwant to merge with, and branch.content_api_zhangxu.merge inyour configuration file does not tell me, either. Pleasespecify which branch you want to use on the command line andtry again (e.g. git pull <repository> <refspec>).See git-pull(1) for details.If you often merge with the same branch, you may want touse something like the following in your configuration file: [branch "content_api_zhangxu"] remote = <nickname> merge = <remote-ref> [remote "<nickname>"] url = <url> fetch = <refspec>See git-config(1) for details.git pull origin new_branch

怎樣遍歷移除項目中的所有 .pyc 文件

sudo find /tmp -name "*.pyc" | xargs rm -rf

替換/tmp目錄為工作目錄

git rm *.pyc

這個用著也可以

避免再次誤提交,在項目新建.gitignore文件,輸入*.pyc過濾文件

git變更項目地址

git remote set-url origin git@192.168.6.70:res_dev_group/test.git git remote -v

查看某個文件的修改歷史

git log --pretty=oneline 文件名 # 顯示修改歷史 git show 356f6def9d3fb7f3b9032ff5aa4b9110d4cca87e # 查看更改

git push 時報錯 warning: push.default is unset

『matching』 參數是 Git 1.x 的默認行為,其意是如果你執行 git push 但沒有指定分支,它將 push 所有你本地的分支到遠程倉庫中對應匹配的分支。而 Git 2.x 默認的是 simple,意味著執行 git push 沒有指定分支時,只有當前分支會被 push 到你使用 git pull 獲取的代碼。

根據提示,修改git push的行為:

git config –global push.default matching

再次執行git push 得到解決

git submodule的使用拉子項目代碼

開發過程中,經常會有一些通用的部分希望抽取出來做成一個公共庫來提供給別的工程來使用,而公共代碼庫的版本管理是個麻煩的事情。今天無意中發現了git的git submodule命令,之前的問題迎刃而解了。

添加

為當前工程添加submodule,命令如下:

git submodule add 倉庫地址 路徑

其中,倉庫地址是指子模塊倉庫地址,路徑指將子模塊放置在當前工程下的路徑。

注意:路徑不能以 / 結尾(會造成修改不生效)、不能是現有工程已有的目錄(不能順利 Clone)

命令執行完成,會在當前工程根路徑下生成一個名為「.gitmodules」的文件,其中記錄了子模塊的信息。添加完成以後,再將子模塊所在的文件夾添加到工程中即可。

刪除

submodule的刪除稍微麻煩點:首先,要在「.gitmodules」文件中刪除相應配置信息。然後,執行git rm –cached命令將子模塊所在的文件從git中刪除。

下載的工程帶有submodule

當使用git clone下來的工程中帶有submodule時,初始的時候,submodule的內容並不會自動下載下來的,此時,只需執行如下命令:

git submodule update --init --recursive

即可將子模塊內容下載下來後工程才不會缺少相應的文件。

一些錯誤

「pathspec 『branch』 did not match any file(s) known to git.」錯誤

git checkout mastergit pullgit checkout new_branch

使用git提交比較大的文件的時候可能會出現這個錯誤

error: RPC failed; result=22, HTTP code = 411 fatal: The remote end hung up unexpectedly fatal: The remote end hung up unexpectedly Everything up-to-date

這樣的話首先改一下git的傳輸位元組限制

git config http.postBuffer 524288000

然後這時候在傳輸或許會出現另一個錯誤

error: RPC failed; result=22, HTTP code = 413 fatal: The remote end hung up unexpectedly fatal: The remote end hung up unexpectedly Everything up-to-date

這兩個錯誤看上去相似,一個是411,一個是413

下面這個錯誤添加一下密鑰就可以了

首先key-keygen 生成密鑰

然後把生成的密鑰複製到git中自己的賬號下的相應位置

git push ssh://192.168.64.250/eccp.git branch

git add文件取消

在git的一般使用中,如果發現錯誤的將不想提交的文件add進入index之後,想回退取消,則可以使用命令:

git reset HEAD <file>...

同時git add完畢之後,git也會做相應的提示。

git reset(回退add操作)

git刪除文件

刪除文件跟蹤並且刪除文件系統中的文件file1

git rm file1

提交剛才的刪除動作,之後git不再管理該文件

git commit

刪除文件跟蹤但不刪除文件系統中的文件

file1git rm --cached file1

提交剛才的刪除動作,之後git不再管理該文件,但是文件系統中還是有file1

git commit

版本回退

版本回退用於線上系統出現問題後恢復舊版本的操作,回退到的版本。

git reset --hard 248cba8e77231601d1189e3576dc096c8986ae51

回退的是所有文件,如果後悔回退可以git pull就可以了。

歷史版本對比

查看日誌git log

查看某一歷史版本的提交內容,這裡能看到版本的詳細修改代碼。

git show 4ebd4bbc3ed321d01484a4ed206f18ce2ebde5ca

對比不同版本

git diff c0f28a2ec490236caa13dec0e8ea826583b49b7a 2e476412c34a63b213b735e5a6d90cd05b014c33

Git常用命令和場景(三)--版本差別查看

分支的意義與管理

創建分支可以避免提交代碼後對主分支的影響,同時也使你有了相對獨立的開發環境。分支具有很重要的意義。

創建並切換分支,提交代碼後才能在其它機器拉分支代碼

git checkout -b new_branch

查看當前分支

git branch

切換到master分支

git checkout master

合併分支到當前分支,合併分支的操作是從new_branch合併到master分支,當前環境在master分支。

git merge new_branch

刪除分支

git branch -d new_branch

git衝突文件編輯

衝突文件衝突的地方如下面這樣

a123<<<<<<< HEADb789=======b45678910>>>>>>> 6853e5ff961e684d3a6c02d4d06183b5ff330dccc

衝突標記<<<<<<< (7個<)與=======之間的內容是我的修改,=======與>>>>>>>之間的內容是別人的修改。

此時,還沒有任何其它垃圾文件產生。

你需要把代碼合併好後重新走一遍代碼提交流程就好了。

不順利的代碼提交流程

在git push後出現錯誤可能是因為其他人提交了代碼,而使你的本地代碼庫版本不是最新。

這時你需要先git pull代碼後,檢查是否有文件衝突。

沒有文件衝突的話需要重新走一遍代碼提交流程add —> commit —> push。

解決文件衝突在後面說。

git順利的提交代碼流程

查看修改的文件

git status

為了謹慎檢查一下代碼

git diff

添加修改的文件,新加的文件也是直接add就好了

git add dirname1/filename1.py dirname2/filenam2.py

添加修改的日誌

git commit -m "fixed:修改了上傳文件的邏輯"

提交代碼git push,如果提交失敗的可能原因是本地代碼庫版本不是最新。

理解github的pull request

有一個倉庫,叫Repo A。你如果要往裡貢獻代碼,首先要Fork這個Repo,於是在你的Github賬號下有了一個Repo A2,。然後你在這個A2下工作,commit,push等。然後你希望原始倉庫Repo A合併你的工作,你可以在Github上發起一個Pull Request,意思是請求Repo A的所有者從你的A2合併分支。如果被審核通過並正式合併,這樣你就為項目A做貢獻了。

github的pull request是指什麼意思

創建和使用git ssh key

首先設置git的user name和email

git config --global user.name "xxx"git config --global user.email "xxx@gmail.com"

查看git配置

git config --list

然後生成SHH密匙

查看是否已經有了ssh密鑰:cd ~/.ssh

如果沒有密鑰則不會有此文件夾,有則備份刪除

生成密鑰

ssh-keygen -t rsa -C "noogel666@gmail.com"

按3個回車,密碼為空這裡一般不使用密鑰。

最後得到了兩個文件:id_rsa和id_rsa.pub

注意:密匙生成就不要改了,如果已經生成到~/.ssh文件夾下去找。

打個小廣告,歡迎大家關注我的個人微信公眾號:軟體開發那點事

我會不定期的與大家分享一些當下熱門的軟體開發動向和一些軟體開發技能,歡迎大家關注~~

weixin.qq.com/r/lzn44ET (二維碼自動識別)

推薦閱讀:

零基礎小白學編程多久能達到接私活的水平?
如何避免無意識裝B?
目標檢測筆記一:演算法入門與優缺對比
如何从拉勾网往里面来看互联网企业里面的数据挖掘现状如何?

TAG:Git | 版本控制 | Python |