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,他会把两个分支的最新快照以及两者 ...
随机推荐
- python SQLAchemy常用语法
SQLAlchemy是Python编程语言下的一款ORM框架,该框架建立在数据库API之上,使用关系对象映射进行数据库操作,简言之便是:将对象转换成SQL,然后使用数据API执行SQL并获取执行结果. ...
- *p++、*++p、(*p)++区别
关于数组指针的谜题 假设 p 是指向数组 arr 中第 n 个元素的指针,那么 *p++.*++p.(*p)++ 分别是什么意思呢? *p++ 等价于 *(p++),表示先取得第 n 个元素的值,再将 ...
- mysql 修改数据库密码
MYSQL5.7以下版本的数据库密码使用的是 mysql这个数据库里的user表的password这个字段, 修改密码只需: 1.update MySQL.user set password=pass ...
- 排查在 Azure 中创建、重启 Linux VM 或调整其大小时发生的分配故障
创建 VM.重启已停止(解除分配)的 VM 和重设 VM 大小时,Azure 会为订阅分配计算资源. 执行这些操作时,即使尚未达到 Azure 订阅限制,也可能偶尔收到错误. 本文说明一些常见分配故障 ...
- SQL Server ->>监控和管理Tempdb
Tempdb作为一个公共数据库,存储着一些临时的数据.有些是用户自己创建的,有些是SQL Server自己创建的.Tempdb空间被使用的一些常见场景有 用户自定义:临时表和表变量.游标. SQL S ...
- 关于Excel文件导入到Sqlserver2008中出现截断错误的解决办法
出现错误的可能原因: 1.数据库字段Varchar长度不够: 2.不能用Text类型: 3.数据中可能存在换行符: 4.数据项文本过长,超过4000: 5.前8行的最大长度不够大,后面有超过的. 解决 ...
- Hyper-V迁移---委派
在Hyper-V管理器中-实时迁移,选择“使用kerberos",如图1所示 在AD中,找到Hyper-V宿主,分别设置委派,如图2所示 图1 图2
- 无缓冲和带缓冲channel的区别
常规定义的channel都是默认不带缓冲的,如下代码所示 package main import ( "fmt" ) func main() { c := make(chan in ...
- php简单的数组递归
参照 http://www.oschina.net/code/snippet_105637_11401 的例子 $arr = array('aa' => array('bb' => ...
- xcode9 unity3d 新坑
1.metal调试会报错,要在edit scheme里关掉