Git 学习笔记–基本操作
- Git 与 SVN 不同,是分布式的版本控制系统,不需要主服务器即可工作,实际中为了方便各个工作者间同步工作,通常还是会设置主服务器。
- Git的设置及初始化:
- 设置全局用户信息:
luojiahu@ubuntu:~/learning/learngit$ git config --global user.name "luojiahu"
luojiahu@ubuntu:~/learning/learngit$ git config --global user.email "luojiahu@yeah.net"
- 初始化目录为Repository:
luojiahu@ubuntu:~/learning/learngit$ git init
Initialized empty Git repository in /home/luojiahu/learning/learngit/.git/
- 文件的提交:
luojiahu@ubuntu:~/learning/learngit$ git add ReadMe.txt
luojiahu@ubuntu:~/learning/learngit$ git commit -m "add a readme file."
[master (root-commit) 849bbd2] add a readme file.
1 file changed, 0 insertions(+), 0 deletions(-)
create mode 100644 ReadMe.txt
- 查看当前Repository的状态信息
luojiahu@ubuntu:~/learning/learngit$ git status
On branch master
Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git checkout -- <file>..." to discard changes in working directory)modified: ReadMe.txt
no changes added to commit (use "git add" and/or "git commit -a")
- 查看详细的文件变化内容
luojiahu@ubuntu:~/learning/learngit$ git diff ReadMe.txt
diff --git a/ReadMe.txt b/ReadMe.txt
index e69de29..38b41f6 100644
--- a/ReadMe.txt
+++ b/ReadMe.txt
@@ -0,0 +1 @@
+add some content.
- 查看提交日志,可以通过—pretty=oneline 限制为显示单行
luojiahu@ubuntu:~/learning/learngit$ git log
commit f2adaa19be7976661aa65228ca20ca02a83c1999
Author: luojiahu <luojiahu@yeah.net>
Date: Tue Aug 28 08:09:00 2018 -0700add GPL
commit 356f51ac350dca07602a5b7f4d0b6fbf7d8eb27f
Author: luojiahu <luojiahu@yeah.net>
Date: Tue Aug 28 08:07:16 2018 -0700add some content.
commit 849bbd2050a94e8cec1403ebdac5f1d56ad914b8
Author: luojiahu <luojiahu@yeah.net>
Date: Tue Aug 28 07:45:18 2018 -0700add a readme file.
luojiahu@ubuntu:~/learning/learngit$ git log --pretty=oneline
f2adaa19be7976661aa65228ca20ca02a83c1999 add GPL
356f51ac350dca07602a5b7f4d0b6fbf7d8eb27f add some content.
849bbd2050a94e8cec1403ebdac5f1d56ad914b8 add a readme file.
- Git版本的回退:
在Git中,用HEAD表示当前版本,上一各版本是HEAD^,上上个为HEAD^^,以此类推… 版本号太大是可以用类似HEAD100~表示。
可以通过git reset命令实现版本的回退,不添加—hard 参数仅仅回退当前工作版本,添加—hard 修改实际文件内容。
luojiahu@ubuntu:~/learning/learngit$ git reset HEAD^
Unstaged changes after reset:
M ReadMe.txt
luojiahu@ubuntu:~/learning/learngit$ git log
commit 356f51ac350dca07602a5b7f4d0b6fbf7d8eb27f
Author: luojiahu <luojiahu@yeah.net>
Date: Tue Aug 28 08:07:16 2018 -0700add some content.
commit 849bbd2050a94e8cec1403ebdac5f1d56ad914b8
Author: luojiahu <luojiahu@yeah.net>
Date: Tue Aug 28 07:45:18 2018 -0700add a readme file.
回退后又后悔了怎么办?可以通过 git reflog 查看每一步的操作命令
luojiahu@ubuntu:~/learning/learngit$ git reflog
849bbd2 HEAD@{0}: reset: moving to HEAD^
356f51a HEAD@{1}: reset: moving to HEAD^
f2adaa1 HEAD@{2}: commit: add GPL
356f51a HEAD@{3}: commit: add some content.
849bbd2 HEAD@{4}: commit (initial): add a readme file.
然后,通过git reset –hard commit_id 恢复至对应的版本,commit_id不必写全
luojiahu@ubuntu:~/learning/learngit$ git reset –hard f2adaa1
HEAD is now at f2adaa1 add GPL
- 工作区与版本库:
Git 中当前的工作路径即为工作区(Working Directory),在Working Directory 下的 .git目录即为版本库(Repository)。其中版本库又分为暂存区(Stage),Master分支,及HEAD指针等。git add 命令将修改的文件提交到Stage区,而git commit命令将暂存区的内容提交到当前的分支。
- Git 管理 “修改” 而不是 “文件”
git commit 只会将上次 git add 命令提交到 Stage 区的修改提交到当前分支,在最近一次 gti add 命令之后对文件做的修改将不会被提交。
- 撤销修改
- 当对工作区的修改,未添加到暂存区时,可以通过:git chechout – filename 命令恢复修改
- 当对工作区的修改已经添加到暂存区,可以通过:git reset HEAD ReadMe.txt 命令恢复暂存区,然后按照1中的步骤恢复工作区。
luojiahu@ubuntu:~/learning/learngit$ git status
On branch master
Changes to be committed:
(use "git reset HEAD <file>..." to unstage)modified: ReadMe.txt
luojiahu@ubuntu:~/learning/learngit$ git reset HEAD ReadMe.txt
Unstaged changes after reset:
M ReadMe.txt
luojiahu@ubuntu:~/learning/learngit$ git status
On branch master
Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git checkout -- <file>..." to discard changes in working directory)modified: ReadMe.txt
no changes added to commit (use "git add" and/or "git commit -a"
luojiahu@ubuntu:~/learning/learngit$ git checkout -- ReadMe.txt
luojiahu@ubuntu:~/learning/learngit$ git status
On branch master
nothing to commit, working directory clean
删除文件
Git认为文件的删除也是一种修改操作,可以通过git rm命令实现文件的删除。如果发生误删,可以通过git reset HEAD filename + git checkout – filename 恢复文件。
luojiahu@ubuntu:~/learning/learngit$ git rm ReadMe.txt
rm 'ReadMe.txt'
luojiahu@ubuntu:~/learning/learngit$ git status
On branch master
Changes to be committed:
(use "git reset HEAD <file>..." to unstage)deleted: ReadMe.txt
luojiahu@ubuntu:~/learning/learngit$ git checkout -- ReadMe.txt
error: pathspec 'ReadMe.txt' did not match any file(s) known to git.
luojiahu@ubuntu:~/learning/learngit$ git status
On branch master
Changes to be committed:
(use "git reset HEAD <file>..." to unstage)deleted: ReadMe.txt
luojiahu@ubuntu:~/learning/learngit$ git reset HEAD ReadMe.txt
Unstaged changes after reset:
D ReadMe.txt
luojiahu@ubuntu:~/learning/learngit$ git status
On branch master
Changes not staged for commit:
(use "git add/rm <file>..." to update what will be committed)
(use "git checkout -- <file>..." to discard changes in working directory)deleted: ReadMe.txt
no changes added to commit (use "git add" and/or "git commit -a")
luojiahu@ubuntu:~/learning/learngit$ git checkout -- ReadMe.txt
luojiahu@ubuntu:~/learning/learngit$ ll
total 16
drwxrwxr-x 3 luojiahu luojiahu 4096 Sep 1 18:58 ./
drwxrwxr-x 3 luojiahu luojiahu 4096 Aug 28 07:42 ../
drwxrwxr-x 8 luojiahu luojiahu 4096 Sep 1 18:58 .git/
-rw-rw-r-- 1 luojiahu luojiahu 28 Sep 1 18:58 ReadMe.txt
Git 学习笔记–基本操作的更多相关文章
- Git学习笔记---协作的一般流程
一般的操作流程 1.pull 王小坤与另一个同事张大炮一起开发一个项目,张大炮昨天修改了数据库读写的api,优化了执行速度,并把read()函数改名成了Read(),下午下班之前把这些代码push到服 ...
- Git学习笔记与IntelliJ IDEA整合
Git学习笔记与IntelliJ IDEA整合 一.Git学习笔记(基于Github) 1.安装和配置Git 下载地址:http://git-scm.com/downloads Git简要使用说明:h ...
- Git学习笔记(10)——搭建Git服务器
本文主要记录了Git服务器的搭建,以及一些其他的配置,和最后的小总结. Git远程仓库服务器 其实远程仓库和本地仓库没啥不同,远程仓库只是每天24小时开机为大家服务,所以叫做服务器.我们完全可以把自己 ...
- Git学习笔记(四)
一.忽略特殊文件 在Git工作区的根目录下创建一个特殊的.gitignore文件,然后把要忽略的文件名填进去,Git就会自动忽略这些文件. 不需要从头写.gitignore文件,GitHub已经为我们 ...
- git 学习笔记6--remote & log
git 学习笔记6--remote & log 创建SSH Keys ssh-keygen -t rsa -C "1050244110@qq.com" 本地关联远程 git ...
- 【转帖】Git学习笔记 记录一下
本文内容参考了廖雪峰老师的博文,并做了适当整理,方便大家查阅. 原帖地址 https://wangfanggang.com/Git/git/ 常用命令 仓库初始化 - git init 1 git i ...
- [转]Git学习笔记与IntelliJ IDEA整合
Git学习笔记与IntelliJ IDEA整合 一.Git学习笔记(基于Github) 1.安装和配置Git 下载地址:http://git-scm.com/downloads Git简要使用说明:h ...
- GIT学习笔记(1):创建版本库
GIT学习笔记(1):创建版本库 创建版本库 1.创建合适目录并初始化为仓库 版本库即需要交由Git进行版本控制的目录,其下所有文件的修改.删除,Git都能跟踪还原. 说明:初始化后,当前目录下会多出 ...
- GIT学习笔记(5):变基
GIT学习笔记(5):变基rebase 变基 引入变基 在Git中整合来自不同分支的修改主要有两种方法:merge以及rebase. 整合分支最容易的方法是merge,他会把两个分支的最新快照以及两者 ...
随机推荐
- 利用Grahics 进行图片裁剪
这两天做了一个图片对比工具,里面要处理两张大的图片,所以要对图片先进行裁剪最开始用了 /// <summary> /// 裁剪图片 /// </summa ...
- 查看源代码HTML
HTML 提示 - 如何查看源代码 如果您想找到其中的奥秘,只需要单击右键,然后选择“查看源文件”(IE)或“查看页面源代码”(Firefox),其他浏览器的做法也是类似的.这么做会打开一个包含页面 ...
- 微信小程序开发踩坑记
前言 微信小程序自去年公测以来,我司也申请了一个帐号开发,春节前后开始开发,现在终于告一个段落了.谨以此文记录下踩过的坑. 坑1:scroll-view与onPullDownRefresh冲突 由于有 ...
- Linux下配置免密登录!
ssh-keygen 产生公钥与私钥对. ssh-copy-id 将本机的公钥复制到远程机器的authorized_keys文件中,ssh-copy-id也能让你有到远程机器的home, ~./ss ...
- XISE菜刀V13.0 官网版 XISE菜刀VIP破解版 XISE官网
诠释: 1. 破解VIP登陆限制 2.去后门 (自查) 下载地址 :https://pan.baidu.com/s/1eR2rUOM 查毒地址:http://a.virscan.org/a3983f3 ...
- 文本处理三剑客之 grep
grep简介 grep(Global search REgular expression and Print out the line)是Linux上的文本处理三剑客之一,另外两个是sed和awk. ...
- webpack之react开发前准备
今天抽出空来,翻了翻webpack之react的书籍,看到刚出的es6语法,貌似是简单了不少,但是兼容性确实不容乐观,如果实在要用那也不是不可以的,首先就跟随我来看下这个插件吧: Babel:这个插件 ...
- sso(single sign on)
sso系统使用 https://www.cnblogs.com/shuai-server/p/8987070.html 一:什么是sso(single sign on) ? sso(单点登录系统)简单 ...
- SpringMVC 如何定义类型转换器
举例说明, 将一个字符串转换成的 User 类型. 例如将字符串 1-zcd-1234-zcd@163.com-1999/12/12 转换成User 类型. 一.实体类 public class U ...
- 一对一关联关系基于主键映射的异常 IdentifierGenerationException
具体异常:org.hibernate.id.IdentifierGenerationException: attempted to assign id from null one-to-one pro ...