Linux系统下Git操作命令整理
1.显示当前的配置信息
git config --list
2. 创建repo
从别的地方获取
git clone git://git.kernel.org/pub/scm/git/git.git
自己建立
mkdir test
cd test
git init
3. 显示状态
git status
4. commit
git add file.1 file.2 先增加文件,增加到index中。这样commit的时候才知道要commit哪些文件。
或者
git add -p
用来interactively选择哪些改变需要被commit
git commit -m "log message"
或者
git commit -a
自动检查应该commit什么文件。如果是新增的文件,仍然要使用git add来添加。
5. 显示以前的工作
git log
输出格式
git log
git log -p
显示patch
git log --stat
显示改动的一个总结
git log --graph
只显示当前branch的
git log --graph --all
显示所有branch的
git log --graph --all --decorate
显示branch的名字
git log --pretty=oneline, short, full, fuller
输出的log 形式不同
git log --pretty=format:"%h - %an, %ar : %s"
按照指定的格式输出。关于--pretty的其他选项和具体的format格式,参考 git log --help中PRETTY FORMAT这部分。
git log --follow file.c
这个功能很有意思,尤其是当file.c被移动后。
通常我们会移动某个文件到某个目录下。如果这么做,git log是不能显示目录移动前的记录的。
那就加上 --follow吧。
git log的筛选
git log -2 -p 显示最近两次commit的log 和 diff
git log --author="Author Name" 筛选特定作者的log
git log --since="2012-2-23" --before="2012-2-24" 筛选时间段
git log --grep="key word" 在commit 的message中查找关键字
git log branch --not master 查看在branch上的,但不在master上的记录。
git log -S"func_name" 查找某个字符出现,或者移出的commit。 比如可以查找一个函数是什么时候添加,或者删除的。
git show sha1 这个sha1是每个commit的sha1,这样显示某个commit的完全信息,包括diff
6. 撤销改动
git checkout -- file.1
撤销了file.1的这次改动。只是撤销了没有staged的改动.
中间的 -- 表明了这是一个文件 而不是一个branch的名字
git reset --hard HEAD
撤销了所有没有commit的改动,包括了stage的和没有stage的。
这条命令的结果一样
git checkout HEAD file.1
包括了staged 和没有staged的都会清除。
有时候我们发现,之前做个一个commit有问题,不想要,想要去掉。
git revert HEAD 自动得重新做一个commit,将最后一次的commit返回回来。
git revert HEAD^ 自动得重新做一个commit,将最后第二次的commit 返回回来。
7. 删除一个commit
git reset --hard HEAD~1
删除了最近的commit
8. 修改最近的一个commit
git commit --amend
7.显示所做的改动
git diff
显示所有的改动。 没有add到index中的。
git diff --staged或者 git diff --cached
显示staged改动,也就是add的东东,也就是将要commit的东东。
git diff commit1 commit2
显示这两个commit之间的变动, 从commit1到commit2的变动。
git diff commit1..commit2
两个点,效果跟上面的一样
git diff commit1...commit2
三个点,表示的是发生在commit2分支,一直到commit1和commit2共同父亲的变化。
git blame -C file1.c
显示文件具体的改动。。。。恩,好像是用来找是谁的错?
git blame -Ln,m file1.c
查看n,m两行间的改动。
git blame commit1~1 -Ln,m file1.c
查看commit1版本前的改动. 追查之前的log。
git blame commit1~1 -Ln,m -- old/file.c
如果这个文件被重命名过,或者移动过位置,就要输入旧的文件的名字。
而且一定要加上 -- , 一定。
8. 删除某个文件
git rm file-name
从库和当前的working directory中删掉这个文件
git rm --cached file-name
只从库中删除,保留当前的本地文件。
9. 重命名一个文件
git mv file file-new
10. 应用patch
git apply patch-file
这样做从patch-file中应用这个patch。 效果和patch命令类似。
但是好处是,git apply要么成功,要么不成功。不想patch,有可能有部分的patch打上了,但是有的没有打上。
git apply后,并没有自动生成一个commit.
git apply --check 可以用来检测这个patch 是不是会产生冲突或者失败。
git am patch-file
这是专门为git 设计的命令。 patch-file是通过git format-patch 生成的。
其中包含了作者信息和简单描述。
git am后,会自动的生成一个commit.
git am --resolved
git am 过程中可能会有conflict. 如过遇到conflict, 那就需要手动修改code, git add 后
用git am --resolved
11 删除一些没有git add的文件;
git clean
参数
-n 显示将要删除的文件和目录
-f 删除文件
-df 删除文件和目录
git clean -df alps/
git remote
git是一个分布式代码管理工具,所以可以支持多个仓库,在git里,服务器上的仓库在本地称之为remote。
直接clone一个仓库:
$: git clone git@search.ued.taobao.net:projects/search.git
另外一种clone方式:
# 创建目录初始化本地仓库
$: mkdir search && cd search
$: git init
# 添加远程仓库路径
$: git remote add github git@github.com:yyfrankyy/search.git
# 实际上,pull 就是 fetch + merge
$: git pull github --all --tags
把工作目录迁移到github上面:
$: git remote add github git@github.com:yyfrankyy/search.git
$: git push github --all --tags
显示所有的远程仓库
$: git remote -v
origin git@search.ued.taobao.net:projects/search.git (fetch)
origin git@search.ued.taobao.net:projects/search.git (push)
github git@github.com:yyfrankyy/search.git (fetch)
github git@github.com:yyfrankyy/search.git (push)
重命名远程仓库
$: git remote rename github gh
$: git remote
origin
gh
删除远程仓库
$: git remote rm github
$: git remote
origin
从远程仓库抓取数据,更新本地仓库:
$: git fetch origin
remote: Counting objects: 58, done.
remote: Compressing objects: 100% (41/41), done.
remote: Total 44 (delta 24), reused 1 (delta 0)
Unpacking objects: 100% (44/44), done.
From git://search.ued.taobao.net:projects/search.git
* [new branch] product -> origin/product
查看远程仓库信息,可用于跟踪别人的push:
$: git remote show origin
* remote origin
Fetch URL: git@search.ued.taobao.net:projects/search.git
Push URL: git@search.ued.taobao.net:projects/search.git
HEAD branch: master
Remote branches:
master tracked
p4popt tracked
prepub tracked
product tracked
Local branches configured for 'git pull':
master merges with remote master
p4popt merges with remote p4popt
prepub merges with remote prepub
product merges with remote product
Local refs configured for 'git push':
master pushes to master (up to date)
p4popt pushes to p4popt (up to date)
prepub pushes to prepub (up to date)
product pushes to product (up to date)
Linux系统下Git操作命令整理的更多相关文章
- 在linux系统下Git源码系统的文件下载
Git是一个开源的分布式版本控制系统,在linux系统中下载git中的文件使用repo的很多. 网上有很多repo下载的地址失效,目前可用的链接在这里记录一下. 没有安装git的安装一下: sudo ...
- linux系统下git使用
转载:http://www.cnblogs.com/bear2flymoon/p/4335364.html?ADUIN=563508762&ADSESSION=1430887070&A ...
- linux系统下 git 使用教程
一.初始化 1.首先安装git软件,安装环境是centos 7.x下的云服务器.使用命令: #yum install git 2.设置用户名和邮箱(必须): # git config --global ...
- linux系统下本地搭建git服务器
linux系统下如何搭建本地git服务器,用于存放团队的开发代码,如下步骤: 1.先用一台服务器来安装git,安装好linux以后,在这里选用的是Ubuntu 14.04.然后配置静态IP:172.1 ...
- linux系统下svn服务器操作命令
linux系统下svn服务器操作命令 .输出指定文件或URL的内容. svncat 目标[@版本]…如果指定了版本,将从指定的版本开始查找. svncat -r PREV filename > ...
- linux系统下的权限知识梳理
下面对linux系统下的有关权限操作命令进行了梳理总结,并配合简单实例进行说明.linux中除了常见的读(r).写(w).执行(x)权限以外,还有其他的一些特殊或隐藏权限,熟练掌握这些权限知识的使用, ...
- Linux系统下权限管理和命令详解
下面对linux系统下的有关权限操作命令进行了梳理总结,并配合简单实例进行说明.linux中除了常见的读(r).写(w).执行(x)权限以外,还有其他的一些特殊或隐藏权限,熟练掌握这些权限知识的使用, ...
- Linux系统下MongoDB的简单安装与基本操作
这篇文章主要介绍了Linux系统下MongoDB的简单安装与基本操作,需要的朋友可以参考下 Mongo DB ,是目前在IT行业非常流行的一种非关系型数据库(NoSql),其灵活的数据存储方式,备 ...
- Linux系统下安装Gitlab
Linux系统下安装Gitlab 一.简介 GitLab是利用 Ruby on Rails 一个开源的版本管理系统,实现一个自托管的Git项目仓库,可通过Web界面进行访问公开的或者私人项目.它拥有与 ...
随机推荐
- python中函数参数*args和**kw的区别
1.函数与参数(实参) 在python中创建函数是def,创建函数名是def f(),f函数名字,def f(a,b),这里的a,b是两个参数,函数名是自定义的,参数也是自定义,随意就好.看图如下效果 ...
- MYSQL批量插入数据库实现语句性能分析【转】 批量插入!程序里面对于数据库插入的功能尽量用【异步处理+批量插入+(事务)】
假定我们的表结构如下 代码如下 CREATE TABLE example (example_id INT NOT NULL,name VARCHAR( 50 ) NOT NULL,value VA ...
- Linux下自动调整时间和时区与Internet时间同步
(原文链接) 调整linux系统时间和时区与Internet时间同步一.修改时区:# cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime修改为中国的 ...
- windows安装oracle11g
windows上安装oracle11g 1.下载Oracle 11g R2 for Windows的版本 下载地址:https://www.oracle.com/technetwork/datab ...
- JavaWeb项目(SSM)准备工作
1.新建dynamic web project(Maven project也行) 我用的Eclipse + ssm + mysql 2.准备jar包 整合ssm的包1. springmvc: ...2 ...
- 支付宝app支付提示 系统繁忙,请稍后重试
v2版本的支付宝支付,无论怎么调试返回的都是系统繁忙,请稍后重试提示.经过对给的示例代码的仔细研究,最后发现是由于老版本的sign_type 不加入签名计算,而新版本的支付签名它是加入签名计算的.供大 ...
- mysql ErrorNo:1449
ErrorMsg:The user specified as a definer ('root'@'%') does not exist解决方法:权限问题,授权 给 root 所有sql 权限 mys ...
- JavaScript dotAll模式
JavaScript正则表达式中点(.)是一个特殊字符,它可以匹配除了一下条件的任意字符. 四个字节的UTF-16字符 换行符(\n) 回车符(\r) 行分隔符 段分隔符 为了使点(.)可以匹配任意字 ...
- linux7开机自启动东方通tongweb
自启动服务: 可以通过把TongWeb设置为系统服务来实现. 具体实现: 以root用户进行操作,在/etc/init.d目录下编写TongWeb的服务脚本tongweb,用来控制TongWeb的启动 ...
- 《深入理解Linux内核》阅读笔记 --- 第四章 中断和异常
1.中断的作用:中断信号提供了一种方式,使处理器转而去运行正常控制流之外的代码.当一个中断信号到达时,CPU必须停止它当前所做的事,并切换到一个新的活动.为了做到这一点,就要在内核态堆栈保存程序计数器 ...