git学习笔记:常用命令总结
本文根据廖雪峰的博客,记录下自己的学习笔记。主要记录常用的命令,包括仓库初始化、添加文件、提交修改、新建分支、内容暂存、分支管理、标签管理等内容。
git是分布式版本控制系统。
首先是安装,从官网下载安装包,按照提示安装即可,安装好后可以在 开始 菜单找到 Git bash,同时 右键菜单也可以看到 Git bash here。
基本概念:
工作区 Working Directory :电脑里面能看到的目录
版本库 Repository:工作区中一个隐藏目录.git,这个不算工作区,而是git的版本库。
暂存区 Stage:版本库中的一块区域
主分支 master:在创建版本库时默认创建的一个分支
指针 HEAD:指向某个分支中的某个commit
创建版本库
新建一个目录,通过如下命令可以将这个目录变成git可以管理的仓库
git init
提交修改
如果新增或者修改了一个或者多个文件,采用add命令是添加到stage(暂存区),如果没有git add到暂存区,那就不会加入到commit中。
git add file01.txt file02.txt
git commit -m "add two file"
查看工作空间的状态
git status
查看修改的内容
git diff
删除文件,先从工作区删除文件,然后用下面的命令,接着在commit,就可以从版本库中删除
git rm file01.txt
撤销误删除,可以从版本库里面恢复误删文件到工作区
git checkout -- file01.txt
版本管理
查看提交日志和分支历史
git log
git log --graph --pretty=oneline --abbrev-commit
回退到上一个版本
git reset --hard HEAD^
回退到某个版本,下面命令中1094a的是在log中看到某个版本号
git reset --hard 1094a
查看所有的命令历史
git reflog
撤销在工作区的修改文件,注意是双短横杠--
git checkout --file01.txt
撤销在暂存区的修改文件,执行后,修改的文件会保存在工作区
git reset HEAD file01.txt
远程仓库
可以将本地仓库的内容和远程仓库关联起来。
用如下命令将本地的内容和远程的仓库关联起来,添加后,远程仓库的名字就是origin
git remote add origin git@github.com:colin/learngit.git
推送本地内容到远程库,参数-u会把本地的master分支内容推送并且关联
git push -u origin master
每次本地提交后,可以采用如下命令推送最新修改
git push origin master
克隆远程仓库地址
git clone git@github.com:colin/learngit
分支管理
创建dev分支,并切换到dev分支
git checkout -b dev
相当于如下两条命令
git branch dev
git checkout dev
查看所有本地分支
git branch
查看所有本地和远程分支
git branch -a
查看本地分支和远程分支的跟踪关系
git branch -vv
切换回master分支
git checkout master
把dev分支合并到master分支上,前提是当前在master分支上
git merge dev
合并分支时禁用Fast forward
git merge --no-ff -m "some message" dev
删除分支
git branch -d dev
临时储藏工作区
git stash
查看stash list
git stash list
恢复临时储藏的工作区
git stash pop
创建本地分支和远程分支的链接关系
git branch --set-upstream-to <branch-name> origin/<branch-name>
标签管理
在最新的一次commit上打上标签
git tag v1.0
查看所有标签
git tag
在某次commit上打上标签,其中f5367是某次commit的id号
git tag v0.9 f5367
查看标签信息
git show v0.9
创建信息较多的标签,其中-a指定标签名,-m指定说明文字
git tag -a v0.1 -m "some message" f5367
删除标签
git tag -d v0.1
推送某个标签到远程
git push origin v1.0
一次性推送全部尚未推送到远程的本地标签
git push origin --tags
删除远程的标签,先删除本地,在push一下
git tag -d v0.9
git push origin :refs/tags/v0.9
END
git学习笔记:常用命令总结的更多相关文章
- GIT学习笔记——常用命令
最近使用使用GIT较多,但命令很容易就忘记了,于是整理下,大多整理与一些文档和他人博客 在当前目录新建建一个纯git代码库 $ git --bare init 在当前目录新建一个Git代码库 $ gi ...
- git 学习笔记(常用命令)
1.新建一个文件,如果没有使用git add 命令将它提交到暂存区,那么这个文件就还没有被跟踪. 2.通过配置.gitignore文件可以指定要忽略的文件,被忽略的文件夹是不会被提交到暂存区的.所以这 ...
- Git学习 --> 个人常用命令add,commit以及push
Git命令行配置1 安装Github2 安装msysgit3 要配置用户名和油箱 git config --global user.name <用户名> 我的命令就是:git confi ...
- Hexo学习笔记--常用命令及部署步骤
参考资料: Hexo搭建Github静态博客:http://www.cnblogs.com/zhcncn/p/4097881.htmlHexo:独立博客新玩法:http://www.aips.me/h ...
- Redis学习笔记--常用命令
以下为本人学习Redis的备忘录,记录了大部分常用命令 1.客户端连接redis服务端: ===启动Redis服务端 redis-server /yourpath/redis.conf ===启动Re ...
- SQL学习笔记---常用命令
常用命令 变量 1.声明 declare @变量名 类型,… 2.赋值 1.同时赋值多个变量(可以结合查询) select @变量名=表达式1,表达式2 2.单个赋值(推荐) set @变量名=表达式 ...
- ionic学习笔记—常用命令
Ionic CLI介绍 Ionic CLI是开发Ionic应用程序过程中使用的主要工具.它就像一个瑞士军刀:它在一个界面下汇集了大量工具. CLI包含许多对Ionic开发至关重要的命令,例如start ...
- Git学习笔记-相关命令记录
内容来自:https://www.liaoxuefeng.com/wiki/896043488029600/896067074338496 1.Linux安装Git 首先,你可以试着输入git,看看系 ...
- Redis学习笔记~常用命令总结
回到目录 客户端redis-cli常用的命令总结 连接到服务器 redis-cli -h 127.0.0.1 -p 6379 --连接指定的redis服务器 发布/订阅, pub/sub模式运行在re ...
- MongoDB学习笔记—常用命令
这里记录一下MongoDB常用的命令 数据库相关 创建数据库 use DATABASE_NAME 如果数据库不存在,则创建数据库,否则切换到指定数据库. 删除数据库:切换到要删除的数据库下,执行命令即 ...
随机推荐
- windows快速搭建FTP工具Serv-U FTP Server
本文介绍一个简单的FTP工具,当然windows系统自带FTP工具,但是配置方法没有第三方工具来的简单可操作性好. 此工具用于搭建FTP环境,对于需要测试FTP上传功能具有极大帮助.例如球机抓拍图片上 ...
- 一行js代码识别Selenium+Webdriver及其应对方案
有不少朋友在开发爬虫的过程中喜欢使用Selenium + Chromedriver,以为这样就能做到不被网站的反爬虫机制发现. 先不说淘宝这种基于用户行为的反爬虫策略,仅仅是一个普通的小网站,使用一行 ...
- shiro初识
shiro 可以做认证.授权.加密.会话管理.与web集成.缓存. 在本文中,主要使用认证和授权这两个功能. 在shiro框架中,有些很重要的概念: Subject 很多人把它理解为当前用户,这 ...
- Mysql 创建用户授权
MySQL创建用户与授权 一. 创建用户 命令: CREATE USER 'username'@'host' IDENTIFIED BY 'password'; 说明: username:你将创建的用 ...
- 系统设计与架构笔记:ETL工具开发和设计的建议
最近项目组里想做一个ETL数据抽取工具,这是一个研发项目,但是感觉公司并不是特别重视,不重视不是代表它不重要,而是可能不会对这个项目要求太高,能满足我们公司的小需求就行,想从这个项目里衍生出更多的东西 ...
- windows cmd.exe 将程序 stdout 输出到文件中
问题背景:通过 cmd.exe 调用程序,会有一些输出信息,在 cmd 中不方便查阅,所以需要导入文件中. 例如 方法: 可以在其路径下看到
- CString类型与其他类型的转换
1.BSTR转CString BSTR bstr; CString cstr; cstr = (LPCTSTR)bstr; 2.Cstring 转BSTR CString cstr = _T(&qu ...
- 尚硅谷springboot学习34-整合SpringData JPA
SpringData简介
- Python 中文数字转阿拉伯数字
#只能转数字,传参中包含非数字会错. def t(str): zhong={'零':0,'一':1,'二':2,'三':3,'四':4,'五':5,'六':6,'七':7,'八':8,'九':9}; ...
- C#下用于同时使用OpenCvSharp和Emgu.CV两个库的相互转换库
很久以前做的一个图像处理项目,在.NET平台上使用OpenCV,但因为同时使用了C#支持的两个比较有名的库,由于封装方式不同,难免要转换两个库之间的Mat对象. 同时还封装了一些WPF下,System ...