- 浏览: 213193 次
- 性别:
- 来自: 深圳
文章分类
- 全部博客 (391)
- java (18)
- python (3)
- ruby (4)
- linux (48)
- 网络 (9)
- 前端 (2)
- 社会、文化、哲学、人生、百态 (0)
- 工具 (10)
- 下载 (0)
- 常用地址 (0)
- tracert (0)
- mysql (8)
- 开源相关收藏 (1)
- 模块查看依懒 (1)
- watch使用 (1)
- Tcpdump (2)
- easy_install安装 (1)
- 构造redis批量删除脚本 (1)
- MYSQL 性能测试 (1)
- JAVA code encode utf-8 (1)
- linux nginx awk 实时 每妙 (1)
- mkpasswd (1)
- spring security oauth (1)
- jmap dump java memory Analyzer (1)
- JAVA DUMP (1)
- swap linux 过高 解决 (1)
- SWAP (1)
- jmap jstat jstack dump (1)
- java jconsole 的使用 (1)
- git 常用 (1)
- MYSQL 索引 动态 唯一 (1)
- TCP 三次握手 四次挥手 (1)
- linux date (1)
- 删除 空行 注释行 (1)
- maven3 yum linux install repository (1)
- linux git 搭建 (1)
- linux sar eth1 查看 流量 (1)
- sar (1)
- netstat ip 过滤 常用脚本 (1)
- Tcpdump 包分析网络连接过程 (1)
- net ipv4 tcp time wait tw recycle (0)
- /etc/sysctl.conf linux 网络 配置 (1)
- ss 网络连接查看 (比netstat 快很多,实时性牺牲) (1)
- MYSQL 关键字 (1)
- Linux 下多核CPU知识 (1)
- top (1)
- 令牌 证书 (1)
- mysql unix timestamp (1)
- 端口扫描 nc nmap (1)
- 204 http code 状态码 (1)
- ss -s ss -l (1)
- linux 常用 curl (1)
- linux sed 替换 换行 (1)
- centos yum install rpm install (1)
- spring-mvc源码解读 (1)
- 使用iftop查看实时的网络流量 (0)
- linux 命令 expect (1)
- HTTP (1)
- openssl ddif 加密 (1)
- iptables 详解 (1)
- python 虚拟化 VirtualEnv virtualenvwrapper (1)
- nginx (2)
- more less 实用技巧 (1)
- linux nginx (2)
- linux curl https ssl 证书 ca (1)
- openssl (1)
- php mysql linux (1)
- linux 虚拟机 虚拟 xen (0)
- linux 虚拟机 虚拟 xen kvm (1)
- linux perl 单行执行技巧 (1)
- mysql 查看库占用空间 表查用空间 (1)
- linux tcpdump (1)
- maven (1)
- sun.misc.Unsafe (1)
- OpenSSL生成证书 (1)
- http://blog.csdn.net/zzulp/article/details/8018751 (1)
- maven 本地 jar dependency (1)
- 计算JAVA代码行数最简单命令 sed (1)
- 常用的证书格式转换 rsa eg (1)
- 加密 解密 签名 (1)
- 分析jar包冲突 (1)
- 使用JMockit编写java单元测试 (1)
- Linux 技巧:让进程在后台可靠运行的几种方法 (1)
- 环境变量控制 (1)
- 5+ 个 tar 命令的用法,附示例 (1)
- scp自动输入密码 (1)
- ps axo pid (1)
- ppid (1)
- comm (1)
- pmem (1)
- lstart|grep mysql (0)
- lstart (1)
- etime|grep mysql (1)
- UML类图字少好理解 (1)
- HTTP经典文章 (1)
- git (1)
- Git常用命令 (1)
- LINUX 系统被攻击的分析过程 (1)
- NIO (1)
- LINUX 操作快捷键使用 (1)
- openSSL命令、PKI、CA、SSL证书原理 (1)
- shell (2)
- 转载 (1)
- mysqldump 可以直接dump->xml (1)
- VIM比较全面的文章 (1)
- eclipse regex 正则表达式 (1)
- synchronized (1)
- 锁 (1)
- java 正则表达式 regex (1)
- Reference Queue 引用 源码 (1)
- spring aop 源码 分析 (1)
- java @Cache @Transaction 注解 (1)
- spring aop (1)
- spring jdk proxy cglib 动态代理 性能比较 (1)
- spring proxy private public 代理限制 (1)
- spring transaction aop 事务 (1)
- spring autowire 注解注入 (1)
- 桥接 NAT NAT地址转换 内部网络 虚拟网络 (1)
- spring-web-mvc 源码解读 之 RequestMappingHandlerMapping (1)
- find atime mtime ctime -n n +n (1)
- android studio 快捷键初探 (1)
- android 源码阅读的计划 (1)
- 计算机网络学习-VLAN (1)
- sed 高级 合并行 (1)
- CAP 一致性 可用性 分布式容错性 (1)
- android lib so 库文件 (0)
- android lib so 库文件 移植 (1)
- android 不错的博文 (1)
- sourceinsight 源码 阅读 (1)
- Android Tab UI (1)
- 诗 (1)
- mysql 批处理 (0)
- netty 堆外内存 DirectByteBuffer (1)
- netty 并发 百万 推送 (1)
- Linux操作系统中内存buffer和cache的区别 (1)
- maven intellij target bytecode version (1)
- linux sleep()的实现原理 (1)
- android (2)
- javadoc 代码注释规范 (1)
- spring 自动注入bean auto (1)
- Photoshop CS6常用快捷键 (1)
- 股票 数据 机器 分析 (1)
- 批处理 (1)
- mysql -e (1)
- char (1)
- Unicode (1)
- 编码 (1)
- utf8 (1)
- utf-8 (1)
- utf16 (1)
- utf-16 (1)
- IntelliJ IDEA (1)
- ide (1)
- idea (1)
- intellij (1)
- 文件 (1)
- 目录 (1)
- 源代码 (1)
- CountDownLatch (1)
- CyclicBarrier (1)
- Semaphore (1)
- spring (1)
- linux 查看不同进制文件 (1)
- WebMvcConfigurationSupport (1)
- sdkman工具的使用 (1)
- http header (1)
- LINUX系统优化 (1)
最新评论
-
gelongmei:
威武我大酒神
shell脚本不换行刷新数据
10 个很有用的高级 Git 命令
1. 输出最后一次提交的改变
这个命令,我经常使用它 来发送其他没有使用git的人来检查或者集成所修改的。它会输出最近提交的修改内容到一个zip文件中。
1
git archive -o ../updated.zip HEAD $(git diff --name-only HEAD^)
2. 输出两个提交间的改变
类似的,如果你需要输出某两个提交间的改变时,你可以使用这个。
1
git archive -o ../latest.zip NEW_COMMIT_ID_HERE $(git diff --name-only OLD_COMMIT_ID_HERE NEW_COMMIT_ID_HERE)
3. 克隆 指定的远程分支
如果你渴望只克隆远程仓库的一个指定分支,而不是整个仓库分支,这对你帮助很大。
1
git init
2
git remote add -t BRANCH_NAME_HERE -f origin REMOTE_REPO_URL_PATH_HERE
3
git checkout BRANCH_NAME_HERE
4. 应用 从不相关的本地仓库来的补丁
如果你需要其它一些不相关的本地仓库作为你现在仓库的补丁,这里就是通往那里的捷径。
1
git --git-dir=PATH_TO_OTHER_REPOSITORY_HERE/.git format-patch -k -1 --stdout COMMIT_HASH_ID_HERE| git am -3 -k
5. 检测 你的分支的改变是否为其它分支的一部分
cherry命令让我们检测你的分支的改变是否出现在其它一些分支中。它通过+或者-符号来显示从当前分支与所给的分支之间的改变:是否合并了(merged)。.+ 指示没有出现在所给分支中,反之,- 就表示出现在了所给的分支中了。这里就是如何去检测:
1
git cherry -v OTHER_BRANCH_NAME_HERE
2
#例如: 检测master分支
3
git cherry -v master
6.开始一个无历史的新分支
有时,你需要开始一个新分支,但是又不想把很长很长的历史记录带进来,例如,你想在公众区域(开源)放置你的代码,但是又不想别人知道它的历史记录。
1
git checkout --orphan NEW_BRANCH_NAME_HERE
7. 无切换分支的从其它分支Checkout文件
不想切换分支,但是又想从其它分支中获得你需要的文件:
1
git checkout BRANCH_NAME_HERE -- PATH_TO_FILE_IN_BRANCH_HERE
8.忽略已追踪文件的变动
如果您正在一个团队中工作,而且大家都在同一条branch上面工作,那么您很有可能会经常用到fetch和merge。但是有时候这样会重置您的环境配置文件,如此的话,您就得在每次merge后修改它。使用这一命令,您就能要求git忽视指定文件的变动。这样,下回你再merge的话,这个文件就不会被修改了。
1
git update-index --assume-unchanged PATH_TO_FILE_HERE
9.检查提交的变动是否是release的一部分
name-rev命令能告诉您一个commit相对于最近一次release的位置。使用这条命令,您就可以检查您所做出的改动是否是release的一部分了。
1
git name-rev --name-only COMMIT_HASH_HERE
10.使用rebase推送而非merge
如果您正在团队中工作并且整个团队都在同一条branch上面工作,那么您就得经常地进行fetch/merge或者pull。Git中,分支的合并以所提交的merge来记录,以此表明一条feature分支何时与主分支合并。但是在多团队成员共同工作于一条branch的情形中,常规的merge会导致log中出现多条消息,从而产生混淆。因此,您可以在pull的时候使用rebase,以此来减少无用的merge消息,从而保持历史记录的清晰。
1
git pull --rebase
您也可以将某条branch配置为总是使用rebase推送:
1
git config branch.BRANCH_NAME_HERE.rebase true
本文地址:https://www.oschina.net/translate/10-useful-advanced-git-commands
原文地址:http://webdeveloperplus.com/general/10-useful-advanced-git-commands/
1. 输出最后一次提交的改变
这个命令,我经常使用它 来发送其他没有使用git的人来检查或者集成所修改的。它会输出最近提交的修改内容到一个zip文件中。
1
git archive -o ../updated.zip HEAD $(git diff --name-only HEAD^)
2. 输出两个提交间的改变
类似的,如果你需要输出某两个提交间的改变时,你可以使用这个。
1
git archive -o ../latest.zip NEW_COMMIT_ID_HERE $(git diff --name-only OLD_COMMIT_ID_HERE NEW_COMMIT_ID_HERE)
3. 克隆 指定的远程分支
如果你渴望只克隆远程仓库的一个指定分支,而不是整个仓库分支,这对你帮助很大。
1
git init
2
git remote add -t BRANCH_NAME_HERE -f origin REMOTE_REPO_URL_PATH_HERE
3
git checkout BRANCH_NAME_HERE
4. 应用 从不相关的本地仓库来的补丁
如果你需要其它一些不相关的本地仓库作为你现在仓库的补丁,这里就是通往那里的捷径。
1
git --git-dir=PATH_TO_OTHER_REPOSITORY_HERE/.git format-patch -k -1 --stdout COMMIT_HASH_ID_HERE| git am -3 -k
5. 检测 你的分支的改变是否为其它分支的一部分
cherry命令让我们检测你的分支的改变是否出现在其它一些分支中。它通过+或者-符号来显示从当前分支与所给的分支之间的改变:是否合并了(merged)。.+ 指示没有出现在所给分支中,反之,- 就表示出现在了所给的分支中了。这里就是如何去检测:
1
git cherry -v OTHER_BRANCH_NAME_HERE
2
#例如: 检测master分支
3
git cherry -v master
6.开始一个无历史的新分支
有时,你需要开始一个新分支,但是又不想把很长很长的历史记录带进来,例如,你想在公众区域(开源)放置你的代码,但是又不想别人知道它的历史记录。
1
git checkout --orphan NEW_BRANCH_NAME_HERE
7. 无切换分支的从其它分支Checkout文件
不想切换分支,但是又想从其它分支中获得你需要的文件:
1
git checkout BRANCH_NAME_HERE -- PATH_TO_FILE_IN_BRANCH_HERE
8.忽略已追踪文件的变动
如果您正在一个团队中工作,而且大家都在同一条branch上面工作,那么您很有可能会经常用到fetch和merge。但是有时候这样会重置您的环境配置文件,如此的话,您就得在每次merge后修改它。使用这一命令,您就能要求git忽视指定文件的变动。这样,下回你再merge的话,这个文件就不会被修改了。
1
git update-index --assume-unchanged PATH_TO_FILE_HERE
9.检查提交的变动是否是release的一部分
name-rev命令能告诉您一个commit相对于最近一次release的位置。使用这条命令,您就可以检查您所做出的改动是否是release的一部分了。
1
git name-rev --name-only COMMIT_HASH_HERE
10.使用rebase推送而非merge
如果您正在团队中工作并且整个团队都在同一条branch上面工作,那么您就得经常地进行fetch/merge或者pull。Git中,分支的合并以所提交的merge来记录,以此表明一条feature分支何时与主分支合并。但是在多团队成员共同工作于一条branch的情形中,常规的merge会导致log中出现多条消息,从而产生混淆。因此,您可以在pull的时候使用rebase,以此来减少无用的merge消息,从而保持历史记录的清晰。
1
git pull --rebase
您也可以将某条branch配置为总是使用rebase推送:
1
git config branch.BRANCH_NAME_HERE.rebase true
本文地址:https://www.oschina.net/translate/10-useful-advanced-git-commands
原文地址:http://webdeveloperplus.com/general/10-useful-advanced-git-commands/
相关推荐
以上只是Git命令的一部分,实际的"Git命令参考手册"包含更多细节和高级用法,如子模块、钩子、工作流策略等。通过深入学习并熟练掌握这些命令,开发者可以在团队协作和项目管理中更加高效地利用Git。对于任何想要...
这个压缩包包含了多个关于Git命令学习的资源,如图像、PDF文档等,旨在帮助用户深入理解和掌握Git的基本及高级操作。 首先,"git_cmd.jpg"可能是一张包含常见Git命令的图片,通常这种图片会用图形化的方式直观展示...
### Git命令汇总及详解 #### 一、Git基础命令 **1. `git branch`** - **功能**: 查看本地所有分支。 - **示例**: `git branch` - **用途**: 快速了解当前项目的分支结构。 **2. `git status`** - **功能**: ...
在您新建了一个项目或想要开始使用Git管理现有项目时,这组命令是非常有用的。 #### 四、启动Git守护进程(用于网络共享) - **命令:** ```bash git daemon --export-all --enable=receive-pack --detach ```...
- **`git reflog`**: 记录每一个Git命令及其效果。这是非常有用的一个命令,可以帮助你跟踪所有的操作记录,尤其是在你需要找回某个特定版本时。 #### 三、撤销更改与文件删除 - **`git checkout -- <file>`**: ...
### Git命令及基础概念详解 #### 一、Git简介 Git 是一个开源的分布式版本控制系统,主要用于跟踪文件的更改历史,支持从简单的文本文件到复杂的多媒体项目等多种类型的文件。通过 Git,开发人员可以轻松地追踪代码...
### Git常用命令总结 #### 一、准备工作 **1.1 初始化仓库** ...以上是关于Git常用命令的一个较为全面的总结,涵盖了从基本操作到高级技巧的各种方面。掌握这些命令对于有效地使用Git进行版本控制是非常重要的。
Git是分布式版本控制系统,它在软件开发中扮演着至关重要的角色,帮助开发者追踪代码更改、...掌握Git命令的使用,能够有效提升开发效率和协作体验。通过不断实践和学习,你将更加熟练地运用Git来管理和维护你的项目。
除了上述基础命令,Git 还提供了许多高级功能,如子模块、cherry-pick、rebase、bisect 等,这些在解决特定问题或优化工作流程时非常有用。掌握这些命令不仅能够提升开发效率,还能确保团队之间的代码协同更加顺畅。...
- **说明**: 通过`git diff`命令可以查看指定文件的具体改动情况,这对于确认提交前的修改非常有用。 #### 五、版本回溯 **6. 版本穿梭** - **命令**: `git reset --hard <commit_id>` - **说明**: 使用`git ...
Porcelain命令是面向用户的高级接口,如`git commit`、`git push`等,它们简化了用户与Git交互的过程。而plumbing命令则是底层命令,用于实现Git的基本功能,如`git hash-object`、`git update-index`等,它们构成了...
当开发者对文件进行修改后,这些修改会被Git跟踪,并且可以通过Git命令来管理这些修改。 #### 二、基本工作流程 1. **初始化Git仓库**:使用`git init`命令可以在当前目录下创建一个新的Git仓库。执行此命令后,...
Git是世界上最流行的...这份Git命令速查表涵盖了从基础操作到高级技巧的大部分内容,是学习和记忆Git命令的好帮手。无论你是初学者还是经验丰富的开发者,都可以通过这份PDF快速查找和理解Git命令,提升工作效率。
GitTool.zip是一个包含Git操作功能的压缩包,主要用于通过编程方式而非命令行接口来执行Git命令。这个工具可能特别适用于那些需要在其他编程语言中集成Git功能的应用程序。以下是关于Git、GitPython以及如何通过...
此外,Git还有许多高级特性,如Stash(暂存区)、Rebase(变基)、Submodule(子模块)等,对于协同开发和项目管理非常有用。 总之,Git是开发者必备的工具,它强大的版本控制功能可以帮助团队有效地管理代码,跟踪...
这个“git:有用的Git命令”主题将深入探讨Git的一些核心和实用命令,这些命令对于日常的软件开发工作至关重要。 1. **初始化Git仓库**: 使用`git init`命令在本地目录中创建一个新的Git仓库。这会生成一个隐藏的...
Git是世界上最流行的分布式版本控制系统,它允许开发者对代码进行版本管理,协同...通过深入学习和实践这些高级Git技术,你将能够更高效地管理项目,提高团队协作的流畅性,同时也能更好地追踪和控制代码的历史演变。
安装完成后,Git的命令行工具Git Bash将被添加到系统PATH环境变量中,使得用户可以在命令行窗口直接使用Git命令。 在使用Git之前,你需要在本地创建一个仓库(repository)。这可以通过在目标目录下运行`git init`...
Git 是一个快速、可扩展的分布式修订控制系统,具有异常丰富的命令集,可提供高级操作和对内部功能的完全访问。 有关有用的最小命令集,请参阅 gittutorial[7]以开始,然后查看 giteveryal[7]。Git 用户手册有更...
在安装Git后,开发者可以开始使用基本的Git命令,例如`git init`初始化一个新的仓库,`git clone`克隆远程仓库,`git add`将更改添加到暂存区,`git commit`提交更改,`git push`将本地更改推送到远程仓库,以及`git...