GIT 工作流程常用用命令大全
一、Git基本工作流程
1、Git工作区域
2、向仓库中添加文件流程

二、Git初始化及仓库创建和操作
1、Git安装之后需要进行一些基本信息设置
a、设置用户名:git config -- global user.name '你再github上注册的用户名';
b、设置用户邮箱:git config -- global user.email '注册时候的邮箱';
c、显示当前的Git配置 git config --list

$ git add [file1] [file2] ...
#
添加指定目录到暂存区,包括子目录
$ git add [dir]
# 添加当前目录的所有文件到暂存区
$ git add
.
# 添加每个变化前,都会要求确认
# 对于同一个文件的多处变化,可以实现分次提交
$ git add -p
#
删除工作区文件,并且将这次删除放入暂存区
$ git rm [file1] [file2] ...
#
停止追踪指定文件,但该文件会保留在工作区
$ git rm --cached [file]
#
改名文件,并且将这个改名放入暂存区
$ git commit -m [message]
# 提交暂存区的指定文件到仓库区
$ git
commit [file1] [file2] ... -m [message]
# 提交工作区自上次commit之后的变化,直接到仓库区
$
git commit -a
# 提交时显示所有diff信息
$ git commit -v
#
使用一次新的commit,替代上一次提交
# 如果代码没有任何新变化,则用来改写上一次commit的提交信息
$ git commit
--amend -m [message]
# 重做上一次commit,并包括指定文件的新变化
$ git branch
# 列出所有远程分支
$ git branch -r
#
列出所有本地分支和远程分支
$ git branch -a
# 新建一个分支,但依然停留在当前分支
$ git branch
[branch-name]
# 新建一个分支,并切换到该分支
$ git checkout -b [branch]
#
新建一个分支,指向指定commit
$ git branch [branch] [commit]
#
新建一个分支,与指定的远程分支建立追踪关系
$ git branch --track [branch] [remote-branch]
#
切换到指定分支,并更新工作区
$ git checkout [branch-name]
# 切换到上一个分支
$ git
checkout -
# 建立追踪关系,在现有分支与指定的远程分支之间
$ git branch --set-upstream
[branch] [remote-branch]
# 合并指定分支到当前分支
$ git merge [branch]
#
选择一个commit,合并进当前分支
$ git cherry-pick [commit]
# 删除分支
$ git branch
-d [branch-name]
# 删除远程分支
$ git push origin --delete
[branch-name]
$ git tag
# 新建一个tag在当前commit
$ git tag
[tag]
# 新建一个tag在指定commit
$ git tag [tag] [commit]
#
删除本地tag
$ git tag -d [tag]
# 删除远程tag
$ git push origin
:refs/tags/[tagName]
# 查看tag信息
$ git show [tag]
# 提交指定tag
$
git push [remote] [tag]
# 提交所有tag
$ git push [remote] --tags
#
新建一个分支,指向某个tag
$ git status
# 显示当前分支的版本历史
$ git log
#
显示commit历史,以及每次commit发生变更的文件
$ git log --stat
# 搜索提交历史,根据关键词
$ git
log -S [keyword]
# 显示某个commit之后的所有变动,每个commit占据一行
$ git log [tag] HEAD
--pretty=format:%s
# 显示某个commit之后的所有变动,其"提交说明"必须符合搜索条件
$ git log [tag]
HEAD --grep feature
# 显示某个文件的版本历史,包括文件改名
$ git log --follow
[file]
$ git whatchanged [file]
# 显示指定文件相关的每一次diff
$ git log -p
[file]
# 显示过去5次提交
$ git log -5 --pretty --oneline
#
显示所有提交过的用户,按提交次数排序
$ git shortlog -sn
# 显示指定文件是什么人在什么时间修改过
$ git
blame [file]
# 显示暂存区和工作区的差异
$ git diff
#
显示暂存区和上一个commit的差异
$ git diff --cached [file]
#
显示工作区与当前分支最新commit之间的差异
$ git diff HEAD
# 显示两次提交之间的差异
$ git diff
[first-branch]...[second-branch]
# 显示今天你写了多少行代码
$ git diff --shortstat
"@{0 day ago}"
# 显示某次提交的元数据和内容变化
$ git show [commit]
#
显示某次提交发生变化的文件
$ git show --name-only [commit]
# 显示某次提交时,某个文件的内容
$
git show [commit]:[filename]
# 显示当前分支的最近几次提交
$ git fetch [remote]
# 显示所有远程仓库
$ git remote
-v
# 显示某个远程仓库的信息
$ git remote show [remote]
#
增加一个新的远程仓库,并命名
$ git remote add [shortname] [url]
#
取回远程仓库的变化,并与本地分支合并
$ git pull [remote] [branch]
# 上传本地指定分支到远程仓库
$
git push [remote] [branch]
# 强行推送当前分支到远程仓库,即使有冲突
$ git push [remote]
--force
# 推送所有分支到远程仓库
$ git push [remote] --all
$ git checkout [file]
#
恢复某个commit的指定文件到暂存区和工作区
$ git checkout [commit] [file]
#
恢复暂存区的所有文件到工作区
$ git checkout .
#
重置暂存区的指定文件,与上一次commit保持一致,但工作区不变
$ git reset [file]
#
重置暂存区与工作区,与上一次commit保持一致
$ git reset --hard
#
重置当前分支的指针为指定commit,同时重置暂存区,但工作区不变
$ git reset [commit]
#
重置当前分支的HEAD为指定commit,同时重置暂存区和工作区,与指定commit一致
$ git reset --hard
[commit]
# 重置当前HEAD为指定commit,但保持暂存区和工作区不变
$ git reset --keep
[commit]
# 新建一个commit,用来撤销指定commit
# 后者的所有变化都将被前者抵消,并且应用到当前分支
$ git
revert [commit]
# 暂时将未提交的变化移除,稍后再移入
$ git stash
GIT 工作流程常用用命令大全的更多相关文章
- git详情、git工作流程、常用命令、忽略文件、分支操作、gitee远程仓库使用
今日内容概要 git详情 git工作流程 git常用命令 过滤文件 分支操作 git远程仓库使用 可参照:https://www.cnblogs.com/liuqingzheng/p/15328319 ...
- git的介绍、git的功能特性、git工作流程、git 过滤文件、git多分支管理、远程仓库、把路飞项目传到远程仓库(非空的)、ssh链接远程仓库,协同开发
Git(读音为/gɪt/)是一个开源的分布式版本控制系统,可以有效.高速地处理从很小到非常大的项目版本管理. [1] 也是Linus Torvalds为了帮助管理Linux内核开发而开发的一个开放源码 ...
- git工作流程
git工作流程 一般工作流程如下: 克隆 Git 资源作为工作目录. 在克隆的资源上添加或修改文件. 如果其他人修改了,你可以更新资源. 在提交前查看修改. 提交修改. 在修改完成后,如果发现错误,可 ...
- Windows常用shell命令大全
Windows常用shell命令大全 基于鼠标操作的后果就是OS界面外观发生改变, 就得多花学习成本.更主要的是基于界面引导Path与命令行直达速度是难以比拟的.另外Geek很大一部分是键盘控,而非鼠 ...
- Windows常用shell命令大全(转)
[Windows常用shell命令大全] 基于鼠标操作的后果就是OS界面外观发生改变, 就得多花学习成本.更主要的是基于界面引导Path与命令行直达速度是难以比拟的.另外Geek很大一部分是键盘控,而 ...
- CentOS常用基础命令大全
这篇文章主要介绍了CentOS常用基础命令大全,学习centos的朋友需要掌握的知识,需要的朋友可以参考下 1.关机 (系统的关机.重启以及登出 ) 的命令shutdown -h now 关闭系统(1 ...
- mac 终端 常用命令,MacOS 常用终端命令大全,mac 在当前目录打开终端
MacOS 常用终端命令大全:目录操作dircmp——比较两个目录的内容——dircmp dir1 dir2文件操作pg分页格式化显示文件内容——pg filenameod——显示非文本文件的内容—— ...
- 漫谈Github与开源,Git介绍以及Git的思想和基本工作原理 Git工作流程
漫谈Github与开源 文字亮点: 为什么这些优秀的工程师会开源自己的项目? 因为开源是一种精神. 无数的软件开发者苦心积虑保护自己的代码不被破解,而还是被聪明绝顶的脚本小子破解了,但破解无数软件的脚 ...
- 常用cmd命令大全
最早的电脑系统是从DOS系统开始,DOS时代没有现在Windows这样的视窗操作界面,让你输入命令.随着电脑的发展至今,学习一些常用cmd命令大全是很有必要.大多数的程序员高手们或计算机专家在DOS系 ...
随机推荐
- 使用Java实现hello/hi的简单网络聊天程序
Socket又称套接字,是基于应用服务与TCP/IP通信之间的一个抽象,它是计算机之间进行通信的一种约定或一种方式.通过socket这种约定,一台计算机可以接收其他计算机的数据,也可以向其他计算机发送 ...
- [Nowcoder212D]禁书目录_概率期望
禁书目录 题目大意:清教需要定期给Index清除记忆,在此之前需要把当中的十万三千本禁书取出来......不幸的是,禁书一旦离开了Index就非常脆弱,具体来说,每一本禁书都有一个魔力值 ai ,其记 ...
- 高并发网络编程之epoll详解(转载)
高并发网络编程之epoll详解(转载) 转载自:https://blog.csdn.net/shenya1314/article/details/73691088 在linux 没有实现epoll事件 ...
- Redis(1.7)Redis高可用架构(理论篇)
[0]常用架构种类 (0.1)单机Redis (0.2)单纯的Redis主从复制 (0.3)哨兵Sentinel+Redis主从复制集群(实现高可用自动故障转移) (0.4)Redis Cluster ...
- Docker的网络模式和跨主机通信
文章转载自:http://www.a-site.cn/article/169899.html Docker的四种网络模式Bridge模式 当Docker进程启动时,会在主机上创建一个名为docke ...
- 二叉树(Java实现)
一.常见用语 1.逻辑结构:描述数据之间逻辑上的相关关系.分为线性结构(如,字符串),和非线性结构(如,树,图). 2.物理结构:描述数据的存储结构,分为顺序结构(如,数组)和链式结构. 3.结点的度 ...
- 【原创】大叔经验分享(63)kudu vs parquet
一 对比 存储空间对比: 查询性能对比: 二 设计方案 将数据拆分为:历史数据(hdfs+parquet+snappy)+ 近期数据(kudu),可以兼具各种优点: 1)整体低于10%的磁盘占用: 2 ...
- pycharm2017.3.3永久激活(转载)
pycharm是很强大的开发工具,但是每次注册着实让人头疼.网络上很多注册码.注册服务器等等.但都只是一年或者不能用:为次有如下解决方案.亲测有效!!! 如果想让pycharm永久被激活,比如截止日到 ...
- scrapy操作指南
Scrapy安装:(scrapy依赖包过多推荐使用下面的方法) 先安装Anaconda,然后 运行conda install Scrapy 创建scrapy项目: 1,scrapy startproj ...
- Presto基础知识
背景 MapReduce不能满足大数据快速实时adhoc查询计算的性能要求. Facebook的数据仓库存储在少量大型Hadoop/HDFS集群.Hive是Facebook在几年前专为Hadoop打造 ...