安装

$ sudo apt-get install git

### 配置
```
# 配置用户名和邮箱
$ git config --global user.name "Your Name"
$ git config --global user.email "email@example.com"
# 查看用户和邮箱配置
$ git config user.name
$ git config user.email
# 或者
$ git config --list
配置PGP签名私钥
git config --global user.signingkey
# 解决乱码问题
$ git config --global core.quotepath false
# 颜色配置
$ git config --global color.ui true
```


### 创建及删除版本库
```
# 创建版本库
$ git init
# 删除版本库
把.git文件删除
```


### 添加文件及删除文件
```
# 添加一个文件
$ git add readme.txt # 工作区-->暂存区
$ git commit -m "wrote a readme file" # 暂存区-->版本库
# 添加所有文件
$ git add .
$ git commit -m "add all files"
# 删除文件
$ git rm test.txt
# 根据私钥提交
$ git commit -S -m "GPG-sign"
```


### 查看工作区状态、修改内容及日志
```
# 查看工作区状态
$ git status
# 查看修改内容
$ git diff readme.txt
# 查看日志
$ git log
# 查看日志(可以显示出PGP签名)
git log --show-signature
$ git log --pretty=oneline
# 查看以往的命令记录
$ git reflog
```


### 时光穿梭
```
# 版本库回到上一个状态
$ git reset --hard HEAD^
# 版本库回到其他状态(可以重返之后的状态,配合git log或git reflog使用)
$ git reset --hard 3345674
```
#### 用版本库里的版本替换工作区的版本
```
# 1.还没有git add
# 把工作区的修改丢弃,回到最近一次git commit或git add时的状态,to discard changes in working directory
$ git checkout -- readme.txt
# 2.已经git add
# Git同样告诉我们,用命令git reset HEAD file可以把暂存区的修改撤销掉(unstage),重新放回工作区:
$ git reset HEAD readme.txt
# 然后
$ git checkout -- readme.txt
```


### 连接远程库
```
# 创建sshkey
$ ssh-keygen -t rsa -C "youremail@example.com"
# 登陆GitHub,打开“settings”,“SSH Keys”页面:然后,点“Add SSH Key”,填上任意Title,在Key文本框里粘贴id_rsa.pub文件的内容
# 添加远程库
$ git remote add origin git@github.com:saitama233/lxf-gitlearning
# 把本地内容推送到远程库(第一次需要加-u参数,之后就不需要了)
# 如果git push有冲突,可以先git pull解决冲突,再git push
$ git push -u origin master
# 把远程库克隆到本地
$ git clone git@github.com:saitama233/lxf-gitlearning
# 查看远程库
$ git remote
# 查看远程库(显示更详细的信息)
$ git remote -v
指定本地dev分支与远程origin/dev分支的链接
$ git branch --set-upstream dev origin/dev
```


### 分支管理
```
# 创建分支
$ git branch
# 切换分支
$ git checkout
# 创建+切换分支
$ git checkout -b
# 删除分支
$ git branch -d
# 强行删除分支(即删除还没有合并过的分支)
# 查看分支
$ git branch

合并某分支到当前分支

1.Fast forward模式,但这种模式下,删除分支后,会丢掉分支信息。

$ git merge

2.加上--no-ff参数就可以用普通模式合并,合并后的历史有分支,能看出来曾经做过合并

$ git merge --no-ff -m "merge with no-ff" dev

#### 分支中的冲突

先查看状态

$ git status

然后修改冲突文件

$ vi readme.txt

#### stash功能(把当前还未提交的工作现场“储藏”起来,然后切换到其他分支工作,之后回来再恢复现场)

暂存

$ git stash

恢复现场

1.一种方式是用git stash pop,恢复的同时把stash内容也删了

(这种貌似只能恢复到最后一个)

$ git stash pop

2.另一种方式是用git stash apply恢复,但是恢复后,stash内容并不删除,你需要用git stash drop来删除

这种可以指定恢复到哪个stash状态

$ $ git stash apply stash@{0}


### 标签管理
tag就是一个让人容易记住的有意义的名字,它跟某个commit绑在一起。

创建标签(为当前commit)

$ git tag v1.0

创建标签(为其他commit)

$ git tag v0.9 6224937

创建带说明文字的标签

$ git tag -a v0.1 -m "version 0.1 released" 3628164

用PGP私钥签名一个标签

1.-s使用默认私钥

$ git tag -s v0.2 -m "signed version 0.2 released" fec145a

2.-u指定私钥

$ git tag -u FCC61057 v0.2 -m "signed version 0.2" 3a367e8

推送某个标签到远程服务器

$ git push origin v1.0

推送所有标签到远程服务器

$ git push origin --tags

删除标签

$ git tag -d v0.1

删除远程的标签

$ git tag -d v0.1

$ git push origin :refs/tags/v0.9

显示某个标签

$ git show v0.9

显示所有标签

$ git tag


### 设置别名

--global参数是全局参数,也就是这些命令在这台电脑的所有Git仓库下都有用。

用st来代替status

$ git config --global alias.st status

用lg来代替那一长串

$ git config --global alias.lg "log --color --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit"

Git使用总结(廖雪峰git)的更多相关文章

  1. git学习笔记——廖雪峰git教程

    OK,先附上教程--廖雪峰的官方网站 友情连接:git官网 简介 这里我只想引用他的原文: Linus可以向BitMover公司道个歉,保证以后严格管教弟兄们,嗯,这是不可能的.实际情况是这样的: L ...

  2. 【学习总结】Git学习-参考廖雪峰老师教程-总

    公元2018-10-21 实验室台式机 win7 64位 参考教程: 廖雪峰Git教程 其他资料:Git-book 北大一只总结的笔记,最终整理的时候可以参考:Git笔记 评论区看到的另一个人,总结在 ...

  3. 廖雪峰Git入门教程

    廖雪峰Git入门教程  2018-05-24 23:05:11     0     0     0 https://www.liaoxuefeng.com/wiki/00137395163059296 ...

  4. 廖雪峰 Git 教程 + Git-Cheat-Sheet 学习总结

    廖雪峰 Git 教程 + Git-Cheat-Sheet 学习总结 本教程主要是个人的 Git 学习总结. 主要参考博客: 廖雪峰 Git 教程 Git-Cheat-Sheet 文章目录 廖雪峰 Gi ...

  5. 【学习总结】Git学习-参考廖雪峰老师教程六-分支管理

    学习总结之Git学习-总 目录: 一.Git简介 二.安装Git 三.创建版本库 四.时光机穿梭 五.远程仓库 六.分支管理 七.标签管理 八.使用GitHub 九.使用码云 十.自定义Git 期末总 ...

  6. git入门(廖雪峰老师)

    根据廖雪峰老师的git教程进行学习总结: 1.之前上班用的都是svn进行管理,那么svn和git有什么区别呢? svn是集中式的版本控制系统,而git是分布式版本控制系统,那么集中式和分布式版本控制系 ...

  7. [廖雪峰] Git 分支管理(3):分支管理策略

    通常,合并分支时,如果可能,Git 会用 Fast forward 模式,但这种模式下,删除分支后,会丢掉分支信息. 如果要强制 禁用 Fast forward 模式,Git 就会在 merge 时生 ...

  8. 《廖雪峰 . Git 教程》学习总结

    基本上,Git就是以下面的命令顺序学习的.文中笔记是从廖雪峰老师的 Git教程 中总结出来的,方面查阅命令. 1.基础 git config --global user.name "Your ...

  9. 【学习总结】Git学习-参考廖雪峰老师教程三-创建版本库

    学习总结之Git学习-总 目录: 一.Git简介 二.安装Git 三.创建版本库 四.时光机穿梭 五.远程仓库 六.分支管理 七.标签管理 八.使用GitHub 九.使用码云 十.自定义Git 期末总 ...

  10. 【学习总结】Git学习-参考廖雪峰老师教程四-时光机穿梭

    学习总结之Git学习-总 目录: 一.Git简介 二.安装Git 三.创建版本库 四.时光机穿梭 五.远程仓库 六.分支管理 七.标签管理 八.使用GitHub 九.使用码云 十.自定义Git 期末总 ...

随机推荐

  1. bat(续五)-获取批处理文件所在路径

    获取批处理文件所在路径        在开发时,经常需要使用批处理运行一些程序,java程序 犹其是这样,往往需要运行时根路径.Hardcode一个路径总是令自己觉得不自在,例如一个java程序从一台 ...

  2. /nagios/cgi-bin/cmd.cgi无法打开

    原因分析,nginx不支持post. 解决方法,重新编译nagios 1.vi /nagios-4.0.8/cgi/cmd.c 找到printf("<form method='post ...

  3. Nginx 与 tomcat 部署网站

    http://www.blogjava.net/libin2722/articles/355631.html http://congpeixue.iteye.com/blog/255011 keepa ...

  4. sonar总结--

    maven的setting.xml 配置  https://www.cnblogs.com/javawebsoa/p/3206504.html

  5. JavaScript高级程序设计-读书笔记(3)

    第8章 BOM 1.window对象 (1)全局作用域 BOM的核心对象是window,它表示浏览器的一个实例.在浏览器中,window对象既是通过JavaScript访问浏览器窗口的一个接口,又是E ...

  6. Markdown锚点使用

    为了使得博客看起来更加美观,我更倾向于使用索引,但是如何在Markdown使用索引跳到指定位置呢?以下是使用方法: 具体应用场景: (1)文献列表中链接--可以通过锚实现页面内的链接:引用文献中可能需 ...

  7. PHP数组合并:[“+”运算符]、[array_merge]、[array_merge_recursive]区别

    1.“+”运算符规则: 当两个数组的键名是数字键名或者字符串键名 $c = $a + $b 在$a后追加($b在$a中不存在的键名)键名和值注意: 1.不覆盖,只是追加不存在的键名和对应的值 2.键名 ...

  8. 利用Java.util.UUID来生成唯一ID(用来做数据库主键好用)

    UUID(Universally Unique Identifier)全局唯一标识符,是指在一台机器上生成的数字,它保证对在同一时空中的所有机器都是唯一的.按照开放软件基金会(OSF)制定的标准计算, ...

  9. [Vue]实例化Vue时的两种挂载方式el与$mount

    Vue 的$mount()为手动挂载,在项目中可用于延时挂载(例如在挂载之前要进行一些其他操作.判断等),之后要手动挂载上.new Vue时,el和$mount并没有本质上的不同. 1.el Vue实 ...

  10. 【程序员笔试面试必会——排序①】Python实现 冒泡排序、选择排序、插入排序、归并排序、快速排序、堆排序、希尔排序

    最近在准备笔试题和面试题,把学到的东西整理出来,一来是给自己留个笔记,二来是帮助大家学习. 题目: 给定一个int数组A及数组的大小n,请返回排序后的数组. 测试样例:  输入:[1,2,3,5,2, ...