git寶典—應付平常工做使用足夠的指北手冊

最近公司gitlab又遷移,一堆git的命令騷操做,然鵝git命令,感受仍是得複習下——其實,git如今界面操做工具蠻多,好比intellij 自帶的git操做插件就不錯,gitlab github 插件市場也有不少,——可是,基本命令仍是整理彙總,記下筆記!php

創建本地倉庫git

git init  建立本地倉庫 git init [project-name]github

git remote add origin git@github.com:UserName/yourProjectName.git   把本地倉庫和遠程倉庫關聯起來, 若是不執行這個命令的話,每次 push 的時候都須要指定遠程服務器的地址shell

 

git clone https://github.com/zhoulujun/yourProjectName.git緩存

提交本地修改到遠程倉庫中:

git add -- 將改動添加到本地倉庫中  服務器

  • git add [file1] [file2] ...  ||  git add [dir] 添加指定文件||目錄到暫存區ssh

  • git add -A ||  git add .添加當前目錄的全部文件到暫存區ide

  • git add -p 添加每一個變化前,都會要求確認,對於同一個文件的多處變化,能夠實現分次提交工具

git rm xxx      -- 從本地倉庫中刪除指定文件gitlab

  • git rm -r xxx   -- 從本地倉庫中刪除指定文件夾

  • git rm --cached [file]

  • git mv [file-original] [file-renamed]  更名文件,而且將這個更名放入暫存區

 

git commit -m "註釋"    -- 把本機緩存中的內容提交到本機的 HEAD 裏面

  • git commit -a 提交工做區自上次commit以後的變化,直接到倉庫區

  • git commit -v 提交時顯示全部diff信息

  • git commit --amend -m [message] 使用一次新的commit,替代上一次提交,若是代碼沒有任何新變化,則用來改寫上一次commit的提交信息

  • git commit --amend [file1] [file2] ... 重作上一次commit,幷包括指定文件的新變化

 

git push origin master  -- 把本地的 commit(提交) push 到遠程服務器上, origin 也就是以前 git remote add origin 那個命令裏面的 origin,origin 替代了服務器倉庫地址:git@github.com:zhoulujun/yourProjectName.git 

 

git push remoteBranchName tagName提交指定tag

git push remoteBranchName --tags 提交全部tag

git轉態查看

git status 查看狀態

git branch 查看本地全部分支

  • git branch -r查看遠程全部分支

  • git branch -a查看本地和遠程全部分支

git tag  列出全部tag

git show tagName 查看tag信息

git log --stat 顯示commit歷史,以及每次commit發生變動的文件

分支操做

git checkout branchName 切換到指定分支,並更新工做區

git merge branchName 合併指定分支到當前分支

git branch newBranchName 新建一個分支,但依然停留在當前分支

git branch --track branch remote-branch 新建一個分支,與指定的遠程分支創建追蹤關係

git branch -D branchName //刪除目標分支

git checkout -b branchName 新建並切換至新分支

git branch -d -r branchName 刪除遠程分支,其中

git branch -m oldbranchname newbranchname  重命名分支 使用-M則表示強制重命名

重命名遠程分支

  • git branch -m old_name new_name 重命名分支

  • git checkout -b new_branch_name from_branch_name 本地創建 branch 並當即 checkout 切換過去

  • git push origin –delete old_name

git強制覆蓋本地代碼

與git遠程倉庫保持一致

git fetch --all

git reset --hard origin/master

git pull

git強制覆蓋本地命令(單條執行):

git fetch --all && git reset --hard origin/master && git pull

git修改遠程倉庫地址

方法有三種:

1.修改命令

git remote origin set-url [url]

2.先刪後加

git remote rm origin

git remote add origin [url]

3.直接修改config文件

.git文件夾,找到config,編輯,把就的項目地址替換成新的。

 

git 配置

git config --list        查看配置列表

git config --global user.name "xxx"   -- 配置用戶名,上傳本地 repository 到服務器上的時候,在 Github 上會顯示這裏配置的上傳者信息

git config --global user.email "xxx"    -- 配置郵箱

配置 sshkey : 上傳代碼時使用這個 sshkey 來確認是否有上傳權限

    1. 建立本地 ssh : ssh-keygen -t rsa -C "Github 的註冊郵箱"

    2. 在 Github 中添加這個 sshkey : 

        複製  C:\Documents and Settings\Administrator\.ssh\id_rsa.pub 文件中的內容;

        登陸 Github --> Account Setting  --> SSH-KEY --> Add SSH-KEY --> 粘貼id_rsa.pub中的內容;

    3. 驗證: ssh -T git@github.com

        出現 Hi xxx! You've successfully authenticated, but GitHub does not provide shell access. 說明配置成功,能夠鏈接上 Github

 

使用 .gitignore 文件忽略指定的內容

    1. 在本地倉庫根目錄建立 .gitignore 文件。Win7 下不能直接建立,能夠建立 ".gitignore." 文件,後面的標點自動被忽略;

    2. 過濾文件和文件夾: [Tt]emp/ 過濾 Temp\temp 文件夾; *.suo 過濾 .suo 文件;

    3. 不過濾文件和文件夾: !*.c

原文地址:git寶典-應付平常工做使用足夠的指北手冊 - git使用的的一些平常小結合集 - 周陸軍的我的網站

不按期更新,文有不妥之處,請留言告知,多謝

相關文章
相關標籤/搜索