git使用

一、下载安装

二、相关概念

  1.工作区:写代码的地方

  2.暂存区:存储添加修改的地方

  3.版本库:存储主分支的地方,里面有第一次提交时完整的代码,并用HEAD指针指向当前最新版本,每次修改提交就是一个新的版本。

三、命令

  (1)设置版本库全局变量

  git config --global user.name 'user1'  #用户名

  git config --global user.email 'mail'  #邮箱,确定仓库用户身份

  git config --list  #全局变量列表(.git/config)

  git config --global --replace-all user.name 'user2'  #修改全局变量

  git config --global --unset user.name       #删除全局变量

  (2)初始化仓库

  git init  #会在当前目录中生成.git文件。当前目录就是一个仓库了,可以对目录下所有文本文件进行版本控制

  (3)查看状态

  git status  #查看当前状态

  git log    #查看提交信息

  git reflog  #查看历史记录

  gti diff  #比较工作区和暂存区所有文件的差异。

  git diff filename  #比较工作区和暂存区指定文件的差异。

  git diff 版本1 版本2 文件名  #比较该文件这2个版本的差异

  git diff HEAD -- filename  #比较工作区和版本库最新版的差异

  (4)添加修改和提交

  git add filename  #将文件的修改提交到暂存区

  git commit -m 'message'  #将暂存区的修改更新到主分支,HEAD指向分支的最新版本

  (5)版本回退

  git reset --hard HEAD^  #将工作区的内容回退到上一个版本

  git reset --hard HEAD~10  #将工作区内容回退到前10个版本

  (6)撤销提交的修改

  git reset HEAD filename  #将当前版本添加的所有修改取消(这些修改都未提交)。

  (7)撤销工作区的修改(相对于最近一次git add后的修改)

  git checkout  --filename  #将指定文件工作区内容恢复为暂存区最新内容(最新一次git add 时的样子)。

  git restore file  

  (8)文件删除

  git rm filename   #删除工作区指定文件,并将文件的修改添加到暂存区(文件没有了,不能用git add filename添加修改)

  git commit -m 'message'  #将修改(删除文件也是修改)提交到版本库,此时产生了一个不包含该文件的最新版本

  (9)远程仓库

  ssh-keygen -t rsa -C '用户名@邮箱' #创建ssh密钥,在C盘用户目录,生成.ssh文件,里面 id_rsa 私钥,id_rsa.pub 公钥 

  git remote add origin git@github.com:github用户名/仓库名.git  #以ssh方式连接到仓库

  git remote add origin https://github.com/git用户名/仓库名.git  #以https协议连接到仓库

  git push -u origin master   #将主分支(master)推送到远程仓库,若远程仓库也有内容,会报错

  git pull origin master  #合并分支

  git pull origin master --allow-unrelated-historys  #允许合并2个不相关的分支  

  git push origin master  #将新分支推送到远程仓库

  git clone git@github.com:用户名/blog.git  #将远程仓库克隆到本地目录下,创建的本地仓库名和远程仓库名相同

  (10)分支管理

  git checkout -b 新分支名  #创建新分支,并指向新分支

  git switch -c 新分支名  #创建新分支并指向新分支(新版支持的命令,推荐使用)

  git switch 分支名  #切换到某个分支

  git branch 新分支名  #创建新分支

  git checkout 分支名  #切换某个分支

  git branch  #查看当前分支

  git branch -d  分支名  #删除分支

  git merge 分支名  #将指定分支与当前分支合并,有冲突则处理冲突文件后自动合并成功。以fast forword模式合并,没有合并的痕迹

  git --graph --pretty=online --abbrev-commit  #查看分支合并状况

  git merge --no-ff commit -m 'message' 分支名  #将指定分支与当前分支合并,禁用fast forword模式

    git pull --rebase origin master  #远程仓库和本地合并,pull=fetch+merch

    (10)标签

  git tag tagname  #快速创建

  git tag -a tagname -m 'message'  #创建完整标签

  git tag   #查看所有标签

  git show tagname  #查看标签信息

  git push origin v1.5  #向远程推送标签

  git tag -d tagname  #删除标签

  (10)自定义GIT

  git config --global color.ui ture  #显示颜色

  (11)设置忽略文件

  1. 创建.gitignore #里面写入要忽略的内容,并推送到远程。‘#’是注释

  git check-ignore -v 文件名  #查看该文件是否被忽略

  git add -f 文件名      #强制添加文件,无视ignore规则

  (12)配置别名

  git config --global alias.st status  #将status用st代替

  git config --global alias.lg "log --color --graph --pretty=format:'%Cred%h%creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Cresset' --abbrev-commit"

 

   (13)好用的git别名

  alias gpm='git push origin master' alias ...=../.. alias ....=../../.. alias .....=../../../.. alias ......=../../../../.. alias 1='cd -' alias 2='cd -2' alias 3='cd -3' alias 4='cd -4' alias 5='cd -5' alias 6='cd -6' alias 7='cd -7' alias 8='cd -8' alias 9='cd -9' alias _=sudo alias afind='ack -il' alias d='dirs -v | head -10' alias g=git alias ga='git add' alias gaa='git add --all' alias gapa='git add --patch' alias gau='git add --update' alias gb='git branch' alias gba='git branch -a' alias gbd='git branch -d' alias gbda='git branch --no-color --merged | command grep -vE "^(*|\s(master|develop|dev)\s$)" | command xargs -n 1 git branch -d' alias gbl='git blame -b -w' alias gbnm='git branch --no-merged' alias gbr='git branch --remote' alias gbs='git bisect' alias gbsb='git bisect bad' alias gbsg='git bisect good' alias gbsr='git bisect reset' alias gbss='git bisect start' alias gc='git commit -v' alias 'gc!'='git commit -v --amend' alias gca='git commit -v -a' alias 'gca!'='git commit -v -a --amend' alias gcam='git commit -a -m' alias 'gcan!'='git commit -v -a --no-edit --amend' alias 'gcans!'='git commit -v -a -s --no-edit --amend' alias gcb='git checkout -b' alias gcd='git checkout develop' alias gcf='git config --list' alias gcl='git clone --recursive' alias gclean='git clean -fd' alias gcm='git checkout master' alias gcmsg='git commit -m' alias 'gcn!'='git commit -v --no-edit --amend' alias gco='git checkout' alias gcount='git shortlog -sn' alias gcp='git cherry-pick' alias gcpa='git cherry-pick --abort' alias gcpc='git cherry-pick --continue' alias gcs='git commit -S' alias gcsm='git commit -s -m' alias gd='git diff' alias gdca='git diff --cached' alias gdct='git describe --tags git rev-list --tags --max-count=1' alias gdt='git diff-tree --no-commit-id --name-only -r' alias gdw='git diff --word-diff' alias gf='git fetch' alias gfa='git fetch --all --prune' alias gfo='git fetch origin' alias gg='git gui citool' alias gga='git gui citool --amend' alias ggpull='git pull origin $(git_current_branch)' alias ggpur=ggu alias ggpush='git push origin $(git_current_branch)' alias ggsup='git branch --set-upstream-to=origin/$(git_current_branch)' alias ghh='git help' alias gignore='git update-index --assume-unchanged' alias gignored='git ls-files -v | grep "^[[:lower:]]"' alias git-svn-dcommit-push='git svn dcommit && git push github master:svntrunk' alias gk='\gitk --all --branches' alias gke='\gitk --all $(git log -g --pretty=%h)' alias gl='git pull' alias glg='git log --stat' alias glgg='git log --graph' alias glgga='git log --graph --decorate --all' alias glgm='git log --graph --max-count=10' alias glgp='git log --stat -p' alias glo='git log --oneline --decorate' alias globurl='noglob urlglobber ' alias glog='git log --oneline --decorate --graph' alias gloga='git log --oneline --decorate --graph --all' alias glol='git log --graph --pretty='\''%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset'\'' --abbrev-commit' alias glola='git log --graph --pretty='\''%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset'\'' --abbrev-commit --all' alias glp=_git_log_prettily alias glum='git pull upstream master' alias gm='git merge' alias gmom='git merge origin/master' alias gmt='git mergetool --no-prompt' alias gmtvim='git mergetool --no-prompt --tool=vimdiff' alias gmum='git merge upstream/master' alias gp='git push' alias gpd='git push --dry-run' alias gpoat='git push origin --all && git push origin --tags' alias gpristine='git reset --hard && git clean -dfx' alias gpsup='git push --set-upstream origin $(git_current_branch)' alias gpu='git push upstream' alias gpv='git push -v' alias gr='git remote' alias gra='git remote add' alias grb='git rebase' alias grba='git rebase --abort' alias grbc='git rebase --continue' alias grbi='git rebase -i' alias grbm='git rebase master' alias grbs='git rebase --skip' alias grep='grep --color=auto --exclude-dir={.bzr,CVS,.git,.hg,.svn}' alias grh='git reset HEAD' alias grhh='git reset HEAD --hard' alias grmv='git remote rename' alias grrm='git remote remove' alias grset='git remote set-url' alias grt='cd $(git rev-parse --show-toplevel || echo ".")' alias gru='git reset --' alias grup='git remote update' alias grv='git remote -v' alias gsb='git status -sb' alias gsd='git svn dcommit' alias gsi='git submodule init' alias gsps='git show --pretty=short --show-signature' alias gsr='git svn rebase' alias gss='git status -s' alias gst='git status' alias gsta='git stash save' alias gstaa='git stash apply' alias gstc='git stash clear' alias gstd='git stash drop' alias gstl='git stash list' alias gstp='git stash pop' alias gsts='git stash show --text' alias gsu='git submodule update' alias gts='git tag -s' alias gtv='git tag | sort -V' alias gunignore='git update-index --no-assume-unchanged' alias gunwip='git log -n 1 | grep -q -c "--wip--" && git reset HEAD~1' alias gup='git pull --rebase' alias gupv='git pull --rebase -v' alias gwch='git whatchanged -p --abbrev-commit --pretty=medium' alias gwip='git add -A; git rm $(git ls-files --deleted) 2> /dev/null; git commit --no-verify -m "--wip-- [skip ci]"' alias history='fc -l 1' alias l='ls -lah' alias la='ls -lAh' alias ll='ls -lh' alias ls='ls --color=tty' alias lsa='ls -lah' alias md='mkdir -p' alias please=sudo alias po=popd alias pu=pushd alias rd=rmdir alias which-command=whence

 

 

 

 

 

  

posted on 2019-11-23 21:29  反射弧  阅读(182)  评论(0编辑  收藏  举报

导航