git2--常用命令
Git 命令详解及常用命令
Git作为常用的版本控制工具,多了解一些命令,将能省去很多时间,下面这张图是比较好的一张,贴出了看一下:
关于git,首先需要了解几个名词,如下:
1
2
3
4
|
Workspace // 工作区 Index / Stage // 暂存区 Repository // 仓库区(或本地仓库) Remote // 远程仓 |
一、新建代码库
1
2
3
4
5
6
7
8
|
// 在当前目录新建一个Git代码库 $ git init // 新建一个目录,将其初始化为Git代码库 $ git init [project-name] // 下载一个项目和它的整个代码历史 $ git clone [url] |
二、配置
Git的设置文件为.gitconfig,它可以在用户主目录下(全局配置),也可以在项目目录下(项目配置)。
1
2
3
4
5
6
7
8
9
|
// 显示当前的Git配置 $ git config --list // 编辑Git配置文件 $ git config -e [--global] // 设置提交代码时的用户信息 $ git config [--global] user.name "[name]" $ git config [--global] user.email "[email address]" |
三、增加/删除文件
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
// 添加指定文件到暂存区 $ git add [file1] [file2] ... // 添加指定目录到暂存区,包括子目录 $ git add [ dir ] // 添加当前目录的所有文件到暂存区 $ git add . // 添加每个变化前,都会要求确认 // 对于同一个文件的多处变化,可以实现分次提交 $ git add -p // 删除工作区文件,并且将这次删除放入暂存区 $ git rm [file1] [file2] // 停止追踪指定文件,但该文件会保留在工作区 $ git rm --cached [ file ] // 改名文件,并且将这个改名放入暂存区 $ git mv [ file -original] [ file -renamed] |
四、代码提交
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
// 提交暂存区到仓库区 $ 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 commit --amend [file1] [file2] |
五、分支
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
|
// 列出所有本地分支 $ 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 branch -dr [remote /branch ] |
六、标签
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
// 列出所有tag $ 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 checkout -b [branch] [tag] |
七、查看信息
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
|
// 显示有变更的文件 $ 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 reflog |
八、远程同步
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
# 下载远程仓库的所有变动 $ 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 |
九、撤销
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
|
// 恢复暂存区的指定文件到工作区 $ 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 stash pop |
十、其他
1
2
|
// 生成一个可供发布的压缩包 $ git archive |
git2--常用命令的更多相关文章
- git在windows及linux环境下安装及常用命令
git在windows下安装 下载地址:https://git-scm.com/ 默认安装即可 验证 git --version git在linux下安装 下载地址:https://mirrors.e ...
- 学习Git过程中常用命令的总结
复制远程库git clone git@github.com:Hconly/learngit.git在GitHub上,可以任意Fork开源仓库:自己拥有Fork后的仓库的读写权限:可以推送pull re ...
- Git深入浅出使用教程:Git安装、远程控制、常用命令(全)
一.软件安装 1.先安装[Git-2.24.1.2-64-bit.exe]软件.(官网下载的很慢,可以在百度云盘下载我的) 链接:https://pan.baidu.com/s/1uoIS9DWSBp ...
- Linux 常用命令(持续补充)
常用命令: command &:将进程放在后台执行 ctrl + z:暂停当前进程 并放入后台 jobs:查看当前后台任务 bg( %id):将任务转为后台执行 fg( %id):将任务调回前 ...
- LVM基本介绍与常用命令
一.LVM介绍LVM是 Logical Volume Manager(逻辑卷管理)的简写,它是Linux环境下对磁盘分区进行管理的一种机制LVM - 优点:LVM通常用于装备大量磁盘的系统,但它同样适 ...
- Linux学习笔记(一):常用命令
经过统计Linux中能够识别的命令超过3000种,当然常用的命令就远远没有这么多了,按照我的习惯,我把已经学过的Linux常用命令做了以下几个方面的分割: 1.文件处理命令 2.文件搜索命令 3.帮助 ...
- git常用命令(持续更新中)
git常用命令(持续更新中) 本地仓库操作git int 初始化本地仓库git add . ...
- 【原】npm 常用命令详解
今年上半年在学习gulp的使用,对npm的掌握是必不可少的,经常到npm官网查询文档让我感到不爽,还不如整理了一些常用的命令到自己博客上,于是根据自己的理解简单翻译过来,终于有点输出,想学习npm这块 ...
- npm常用命令
npm常用命令 环境:win7 npm 是什么 NPM(node package manager),通常称为node包管理器.顾名思义,它的主要功能就是管理node包,包括:安装.卸载.更新.查看.搜 ...
- Git 常用命令
一.初始環境配置 git config --global user.name "John Doe"git config --global user.email johndoe@ex ...
随机推荐
- 101 Symmetric Tree 判断一颗二叉树是否是镜像二叉树
给定一个二叉树,检查它是否是它自己的镜像(即,围绕它的中心对称).例如,这个二叉树 [1,2,2,3,4,4,3] 是对称的. 1 / \ 2 2 / \ / \3 4 4 3但是 ...
- nodejs express 设置html后缀模板
express 框架的默认渲染模板的后缀是 ejs ,由于编译器在ejs的文件里写html代码没有高亮显示,所以使用html模板. 示例: var app = express(); app.set(' ...
- MongoDB自动递增序列
MongoDB没有像SQL数据库外开箱即用自动递增功能.默认情况下,它采用了12字节的ObjectId为_id字段作为主键来唯一地标识文档.然而,可能存在的情况,我们可能希望_id字段有一些其它的自动 ...
- {ubuntu}乱七八糟重命名为1 2 3.....png
i=; for f in *.png; do mv "$f" ${i}.png; ((i++)); done 网上找了个测试的数据集,发现读取时候,要重命名一下 一片帖子问了类似的 ...
- Verilog 参数化设计
为了提高模块的重复利用,关键就在于避免硬编码(hard literal),使模块参数化.参数化建模的好处是可以使代码清晰,便于后续维护和修改.只需要修改参数,不用修改其他代码就可以适用于不同的环境中. ...
- jmeter分布式测试配置
jmeter分布式测试 说明:1台8核16G的windows2008的机器,只能器6000个线程,否则效果不是很好:并且负载机器需要做如下设置: 1.打开注册表:regedit 2.HKEY_LOCA ...
- codevs 1487 大批整数排序(水题日常)
时间限制: 3 s 空间限制: 16000 KB 题目等级 : 黄金 Gold 题目描述 Description !!!CodeVS开发者有话说: codevs自从换了评测机,新评测机的内存计算 ...
- Android串口通信
前段时间因为工作需要研究了一下android的串口通信,网上有很多讲串口通信的文章,我在做的时候也参考了很多文章,现在就将我学习过程中的一些心得分享给大家,希望可以帮助大家在学习的时候少走一些弯路,有 ...
- XDU——受教了
存在的问题还是很多的 GG 突然觉得刷题的目的并不是追求A.我们应该在那个过程中提高代码能力和建立模型解题能力 会的算法会巧妙应用才是王道 吐槽自己两句,写高数了
- 转过来的Xpath语法
XPath 是XML的查询语言,和SQL的角色很类似.以下面XML为例,介绍XPath 的语法. <?xml version="1.0" encoding="I ...