这些常用的Git命令你都知道吗?

配置

  • git config <--local | --global | --system> -l

    查看配置信息(--local:仓库级,--global:全局级,--system:系统级)

  • git config -l

    查看当前生效的配置信息

  • git config <--local | --global | --system> -e

    编辑配置文件(--local:仓库级,--global:全局级,--system:系统级)

  • git config <--local | --global | --system> --add <name> <value>

    添加配置项(--local:仓库级,--global:全局级,--system:系统级)

  • git config <--local | --global | --system> --get <name>

    查看指定配置项信息

  • git config <--local | --global | --system> --unset <name>

    删除配置项

  • git config --global user.name <用户名>

    全局配置Git的用户名

  • git config --global user.email <邮箱地址>

    全局配置Git的邮箱

  • git config --global http.postBuffer <缓存大小>

    更改Git缓存区的大小,缓存大小单位:B,例如:524288000(500MB)

  • git config --global credential.helper 'cache --timeout=<缓存时间>'

    配置密码的缓存时间,默认缓存时间单位为秒

克隆

  • git clone <git地址>

    从远程仓库克隆项目到当前目录下

  • git clone <git地址> <本地目录>

    从远程仓库克隆项目到本地指定的目录

  • git clone <git地址> -b <远程分支名> <本地目录>

    从远程仓库克隆指定的分支到本地指定目录

初始化本地仓库

  • git init

    初始化本地仓库,在当前目录下生成 .git文件夹

提交变化到本地分支

  • git add <文件路径>

    添加指定文件到暂存区

  • git add .

    提交修改文件和新文件到暂存区,不包括删除文件

  • git add -u

    提交修改文件和被删除文件到暂存区,不包括新增文件

  • git add -A

    提交所有变化到暂存区,上面两个add的功能合集

  • git commit -m "提交说明"

    提交变化到本地分支

还原提交记录

  • git reset <commit ID> / git reset --mixed <commit ID>

    改变HEAD的指向,撤销到指定的提交记录,但是不会还原项目文件

  • git reset --hard <commit ID>

    改变HEAD的指向,撤销到指定的提交记录并还原项目文件

从远程分支拉取最新代码到本地

  • git fetch <远程仓库名> <远程分支名>:<本地分支名>

    拉取远程分支最新代码到本地分支,但是不会进行合并,如需合并可以参考下方示例:

    • 先使用git diff <本地分支名>比较本地代码与拉取的远程代码的区别</li>
    • 再使用git merge <本地分支名>进行合并</li>
# 在本地新建一个temp分支,并将远程origin仓库的master分支代码下载到本地temp分支
git fetch origin master:temp

# 比较当前的本地分支代码与刚刚从远程下载下来的本地temp分支代码的区别
git diff temp

# 将temp分支到当前的本地分支
git merge temp

# 如果不想保留temp分支,则删除
git branch -d temp
  • git pull <远程仓库名> <远程分支名>:<本地分支名>

拉取远程分支最新代码并合并到本地分支,例如:git pull origin master即将远程originmaster分支拉取到本地并合并

提交代码到远程分支

  • git push <远程仓库名> <本地分支名>:<远程分支名>

    提交本地分支到指定远程分支

将本地仓库与远程分支建立联系

  • git add remote <远程仓库名> <git地址>

    将本地仓库与远程仓库建立一个连接

  • git remote set-url <远程仓库名> <新的git地址>

    修改本地仓库绑定的远程仓库地址

本地分支的查看、创建、切换、删除等操作

  • git branch

    查看所有本地分支

  • git branch -a

    查看所有本地与远程分支

  • git branch <本地分支名>

    创建本地分支

  • git branch -d <本地分支名>

    删除本地分支

  • git branch -m <旧本地分支名> <新本地分支名>

    修改本地分支名

  • git checkout <本地分支名>

    切换到指定的本地分支

  • git checkout -b <本地分支名> <远程仓库名>/<远程分支名>

    创建本地分支并切换到新创建的本地分支,新创建的本地分支从指定的远程分支拉取代码

  • git merge <本地分支名>

    将指定的本地分支合并到当前的本地分支上

远程分支的查看、删除等操作

  • git branch -r

    查看所有远程分支

  • git push <远程仓库名> --delete <远程分支名>

    删除远程分支,但不能删除远程的default分支

PS:如需重命名远程分支,可以先删除远程分支,在从本地提交新的分支到远程仓库

标签的查看、新建、删除等操作

  • git tag

    查看所有的本地标签

  • git tag <标签名称> [<commit ID>]

    基于Commit ID新建本地标签,如果不写Commit ID,默认为基于最新一次的提交新建本地标签

  • git tag -a <标签名称> -m <标签描述信息> [<commit ID>]

    创建一个带描述信息的本地标签

  • git checkout <标签名称>

    切换到指定的标签

  • git tag -d <标签名称>

    删除本地标签

  • git show <标签名称>

    查看标签的详细信息,包括Commit ID

  • git push <远程仓库名> <标签名称>

    将指定的本地标签提交到远程仓库

  • git push <远程仓库名> –tags

    将所有的本地标签提交到远程仓库

  • git push <远程仓库名> --delete <标签名称>

    删除指定的远程标签

  • git fetch <远程仓库名> tag <标签名称>

    拉取指定的远程标签到本地

  • git ls-remote --tags <远程仓库名>

    查看所有的远程标签

查看日志

  • git log

    查看所有的提交记录

  • git log -<指定的数量>

    查看指定数量的最新提交记录

比较版本之间的差异

  • git diff <commit ID>

    查看从指定的版本之后改动的内容

  • git diff <本地分支名> <本地分支名>

    比较两个分支之间的差异

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容