本篇博客是整理git相关知识的第一篇,因为之前一直是用SourceTree对Git的命令行操作用的不是特别熟,于是乎过了一遍ProGit(链接:https://git-scm.com/book/zh/v1)。本篇博客以及后边的将要发的几篇博客是对之前看ProGit时的笔记的整理。当然在整理时,根据具体示例来梳理了一下知识点,和ProGit上的讲解顺序有些区别。本篇博客聊了Git基础操作的一部分,主要是基于Github上Fork的Masonry仓库来做的,首先Clone相关仓库,然后根据git status命令的提示引出了一系列的命令操作。

Git的原理就不做过多赘述了,ProGit上聊得挺好。不过还是要聊一下集中版本控制系统和分布式版本控制的区别。在版本管理中主要包含集中化的版本控制系统 (Centralized Version Control Systems,简称 CVCS) 例如 CVS、Subversion 以及 Perforce 等 ,和分布式版本控制系统(Distributed Version Control System,简称 DVCS), 例如Git、Mercurial、Bazaar 以及 Darcs  。DVCS的特点为每一次的克隆操作,实际上都是一次对代码仓库的完整备份。 其中文件的状态主要包括已提交(committed)、已修改(modified)和已暂存(staged) 的。这些东西就不细说了,先看一下git的命令的一些操作。

备注:接下来的几篇博客的终端操作都是在 Mac 上使用的 ITerm完成的,终端上装的是oh-my-zsh (https://github.com/robbyrussell/oh-my-zsh)。

一、获取远程仓库

为了方便做一些git相关的基础操作,就是使用在github上Fork的Masonry的仓库做实验吧,然后基于此Fork的仓库来展开接下来的相关内容。

  

第一步要做的就是将远程仓库中的代码克隆到本地,git clone 命令做的就是这件事情。其后边跟的参数就是上述截图中的地址,其具体操作如下所示:

  

在第一部分我们就先简单的看一下 git clone 的演示操作。首先使用了git clone 命令将远端的代码以及相关分支信息clone到本地,然后在本地进行了一次提交(git commit), 最后将提交push到远端。在接下来的几篇博客中会陆陆续续的介绍到,在此就先不多说了。

  

二. 由 git status 命令引起的其他命令

我们可以使用 git status 命令来查看相关文件的状态,在下方的操作中首先我们对README.md文件使用vim编译器进行修改并保存, 然后创建了一个名为NewCreateFile的文件。并使用git status命令来查看其相关的状态。

从下方输出的结果中不难看出README.md的文件状态为 modified, 也就是被修改了,更详细的提示为 “Changes not stagged for commit”, 也就是说文件被修改了,但是还没有在提交(commit)前进行存储(staged)。并且给了相关的提示,可以使用 git add <文件名>命令进行存储,或者使用 git checkout -- <文件名> 命令放弃在工作目录中的修改。

而我们刚创建的 NewCreateFile 文件处于Untracked (未被跟踪的状态),并且可以使用git add <文件名>来将该创建的NewCreateFile添加到可以被提交(commit)的内容当中去。并且还给出了一条建议,可以对 NewCreateFile 文件使用 git commit -a 来直接进行提交。

如果你对git的各种状态比较熟悉了,也可以使用 git status -s 来查看简写的状态,这种简写的状态和SVN上的差不多 M - 被修改,A - 被添加,D - 被删除,R - 重命名,?? - 未被跟踪 等等,下方遇到其他的状态符号时在一一解释。

  

根据上面git status命令的提示内容,我们至少可以得到三种命令的使用方式:

  • 暂存文件的命令:git add <文件名>

  • 放弃未暂存文件的修改命令:git checkout -- <文件名>

  • 将被修改的文件暂存并提交的命令:git commit -a 

接下来我们可以看一下git add的命令,下方分别将上述两个文件进行了add, 也就是将文件进行暂存。暂存后,使用了git status命令查看状态,提示这些修改可以被提交了,并且还可以使用 git reset HEAD <文件名>来取消相关文件的暂存。使用 git status -s 命令来查看 状态标记由原来的红色改成了绿色,并且NewCreateFile的状态标记由??变成了 A  (新添加文件)。

  

接下来我们根据提示,看一下 git reset HEAD <文件名> 命令的操作,下方分别对已经暂存的两个文件执行了 git reset HEAD <文件名>操作,如下所示。从操作后的结果可以看出,两个文件的状态是一夜回到了解放前,又回到了之前暂存的状态。

  

接下来我们在看一下对未暂存的修改文件进行回滚的操作命令: git checkout -- <文件名>,根据上面的提示我们可以知道该操作可以放弃对某个为暂存的文件的修改。接下来我们就来看一下这个命令的操作。不过有一点需要注意,该操作如果生效了,再想找回被丢弃的内容就找不回了。也就是说git checkout -- <文件名>是不可逆的,因为其回滚的内容并没有在git中进行暂存和记录。从下方的操作我们可以看出被修改的README.md回到了未被修改的状态之前。

  

接下来我们来看一下上面提到的命令git commit -a 的操作,首先我们再次对README.md进行修改,然后查看一下状态。接着使用 git commit -a -m "提交说明" 来进行添加和提交。从该命令执行后的状态中我们可以看到,git commit -a 只对 状态为M的文件有用,而对新增而为添加的问题是不起作用的,因为我们新添加的文件NewCreateFile仍然处于 Untracked 状态中。

  

我们可以使用 git add 命令对 NewCreateFile 文件进行暂存,使用 git commit 命令对暂存的内容进行提交。提交后,我们查看状态时看到一个提示, 大概是说你的分支已经领先远端的主分支2个提交,可以使用 git push 操作来发布你本地的提交。

  

下方是git push操作的相关内容,我本地是配了github的ssh-key的,不过之前clone的时候使用的是https的方式,需要在第一次PUSH的时候都要求输入用户名和密码。每次都输入用户名和密码挺麻烦的稍后我们将使用git的其他命令将其解决掉。

  

push完毕后,我们可以动github上相应的仓库中可以看到其相关的修改内容了,具体如下:

  

由上面的内容,不难发现,从一开始的git status命令,根据相关提示,引出了其他相关命令。下方是对其相关命令的总结:

  • git status : 查看当前仓库中文件的状态。

  • git status -s : 文件状态的简写(M - 修改, A - 添加, D - 删除, R - 重命名,?? - 未追踪)。

  • git add <文件名> :将后方紧跟的文件进行暂存,以便commit使用。

  • git reset HEAD <文件名> : 将已经暂存的文件进行撤销,回到未暂存的状态。

  • git checkout -- <文件名> :撤销对尚未暂存文件的修改,该操作不可逆,慎用。

  • git commit -a : 对那些被修改的文件单尚未暂存和提交的文件进行暂存和提交。注意:对未暂存的新增文件无效。

  • git commit : 对暂存区的文件进行提交到本地仓库。

  • git push : 将本地仓库已经提交的内容发布到远端。

三、查看和修改远端地址

1、添加远端仓库地址

根据上面的操作可以看到,上面的远端链接是https的。因为我本地是赔了github的ssh-key的,所以也是支持ssh的链接的。下方我们将根据 git remote 远程仓库操作来添加上ssh的仓库地址。下方是一系列的操作:

  • 首先通过 git remote -v 命令来查看当前仓库的远端地址,从下方看到是 https格式的。

  • 然后在通过 git remote add 远端仓库地址别名 <url> 来添加一个新的仓库地址,下方添加的是一个ssh的仓库链接。

  • 接着我们再次对远端仓库的链接查看时,就会看到相应的新添加的仓库地址。

  • 然后我们队README文件做了点修改,并push远端。在 push 时我们选择了后来添加的新的远端仓库,可以看出使用的是别名。

  

下方是push后从github上对应的仓库看到的相关内容,也是可以看到的修改的相关内容的。

  

2、远端仓库地址删除和重命名

从上面的内容不难看出,两个仓库地址其实是重复的。现在我们没必要都将其进行存储了。我们要删掉那个https的仓库,下方是具体的操作步骤。

  • 首先通过 git remote -v 来查看目前现有的远端仓库。

  • 然后通过 git remote rm origin 命令来删除别名为 origin 的远端地址,删除后,再次查看时,origin的仓库地址就木有了。

  • 紧接着使用 git remote rename origin_ssh origin 命令,将origin_ssh重命名为origin即可。

  • 最后我们还可以使用 git remote show origin 命令来查看push到远端的那个分支上,具体操作步骤如下所示。

  

今天博客就先到这儿,下篇博客会继续聊git命令的其他基础操作。

Git知识总览(一) 从 git clone 和 git status 谈起的更多相关文章

  1. Git知识总览(二) git常用命令概览

    上篇博客我们从 git clone 和 git status 两个命令开始,引出了一系列的git操作命令, 请参见:<Git知识总览(一) 从 git clone 和 git status 谈起 ...

  2. Git知识总览(三) 分支的创建、删除、切换、合并以及冲突解决

    前两篇博客集中的聊了git的一些常用命令,具体请参见<Git知识总览(一) 从 git clone 和 git status 谈起>.<Git知识总览(二) git常用命令概览> ...

  3. Git知识总览(四) git分支管理之rebase 以及 cherry-pick相关操作

    上篇博客聊了<Git知识总览(三) 分支的创建.删除.切换.合并以及冲突解决>,本篇博客我们主要来看一下 rebase 变基相关的操作.rebase 操作和 merge 操作最终都可以达到 ...

  4. Git知识总览(五) Git中的merge、rebase、cherry-pick以及交互式rebase

    上篇博客聊了<git分支管理之rebase 以及 cherry-pick相关操作>本篇博客我们就以Learning Git中的关卡进行展开.下方列举了LearningGit中的 merge ...

  5. Git知识总览(六) Git分支中的远程操作实践

    前几篇博客陆陆续续的讲了好多关于Git操作的内容,本篇博客仍然也不例外,不过本篇博客的主题是关于git的远程操作的.依照之前博客的风格,我们依然依托于LearningGitBranch中的相关内容来探 ...

  6. Git 系列(二):初步了解 Git

    在这个系列的介绍篇中,我们学习到了谁应该使用 Git,以及 Git 是用来做什么的.今天,我们将学习如何克隆公共 Git 仓库,以及如何提取出独立的文件而不用克隆整个仓库. 由于 Git 如此流行,因 ...

  7. 最近学到的Git知识,大厂的Git机制还是很方便的

    本文首发于微信公众号:程序员乔戈里 转载请注明:https://blog.csdn.net/WantFlyDaCheng/article/details/102538508 一.两次的 git com ...

  8. Git知识总结

    Git知识总结 Git安装 windows 在git官网中下载安装程序,然后按默认选项安装即可 安装完成后,在开始菜单里找到"Git"->"Git Bash&quo ...

  9. 【android Studio】零git知识、零脚本命令,即刻体验git版本管理魅力!

    git的优点就不去多说了.阻碍咱新手体验它的唯一问题就是门槛太高,脚本看着像天书, 本文主要阐述的,就是如何在android studio上,也能像tfs那样,非常简单的操作,就能使用git进行版本管 ...

随机推荐

  1. apache mysql无法启动解决办法

    最近在调试几个代码,需要不停的启动关闭服务器和mysql.在连续的几次开关后,无法启动了,每次启动后就直接关闭. 刚开始是怀疑是不是端口被占用了,查看端口后,并没有端口被占用的情况.查看mysql错误 ...

  2. 非一屏页面,出现遮罩层页面位置不动,并且遮罩层一屏显示。(pc,移动端都适用的方法)

    首先展示页面效果: 遮罩没出现的页面张酱紫:页面在楼层二这个位置. 遮罩显示:后面页面页面任停留在当前浏览位置,滚动条并未回顶部 下面来说说写法: css: 页面具体布局样式......(此处省略无数 ...

  3. Failed to load the JNI shared lib...

    启动eclipse报错:Failed to load the JNI shared lib... 解决办法如下:保证JDK与eclipse相匹配 在同一台计算机中,如果JDK是32位的,那么eclip ...

  4. HDU 1394 逆序数 线段树单点跟新 | 暴力

    Minimum Inversion Number Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java ...

  5. Filebeat轻量级日志采集工具

    Beats 平台集合了多种单一用途数据采集器.这些采集器安装后可用作轻量型代理,从成百上千或成千上万台机器向 Logstash 或 Elasticsearch 发送数据. 一.架构图 此次试验基于前几 ...

  6. System.Security.Cryptography.RSA.FromXmlString 系统找不到指定的文件和X509读取证书文件系统找不到指定的文件异常

    前言: 最近公司增加服务器,在新增加的服务器中发现一些问题. 1.应用程序在读取证书文件中出现"系统找不到指定的文件."异常,但是已经确认证书文件存在.本地测试也可以读取,就在新增 ...

  7. WeChat 隐私政策

    隐私政策 本应用尊重并保护所有使用服务用户的个人隐私权.为了给您提供更准确.更有个性化的服务,本应用会按照本隐私权政策的规定使用和披露您的个人信息.但本应用将以高度的勤勉.审慎义务对待这些信息.除本隐 ...

  8. centos7 忘记mysql root密码办法

    1.首先确认服务器出于安全的状态,也就是没有人能够任意地连接MySQL数据库. 因为在重新设置MySQL的root密码的期间,MySQL数据库完全出于没有密码保护的状态下,其他的用户也可以任意地登录和 ...

  9. 【NOIP2014提高组】解方程

    https://www.luogu.org/problem/show?pid=2312 对于30%的数据,n<=2,暴力带入试解.对于50%的数据,ai很大,结合高精乘法和霍纳算法暴力代入试解. ...

  10. Usaco 2006Nov Round Numbers

    题意:定义Round Number为二进制表示下0的个数大于等于1的个数的数.求[l,r]中有多少圆环数 我们把二进制位用一颗01二叉树表示,如下: 我们依据二进制位来遍历这颗线段树,如果当前高度对应 ...