Git 的基本使用

Git 的介绍

Git 是一种分布式的版本管理系统。简单来说,它就是一个版本控制软件,而且也是现在世界上最流行最先进的。

Git 的一个具体作用就是对文件进行版本管理。由于每次项目上线,可能会产生一些无法预料的bug,这时就需要选择上一个正常的版本进行回滚操作。而 Git 的存在,就是为了开发人员能够方便地在不同版本之间进行切换。

Github、码云Gitee,在某种程度上来说,就是代码的网盘。也有开源的开发商作为代码发布、存放、征集bug的地方。

除了版本管理这个功能,Git 在团队协作开发上也有很大的优势。由于每个模块的代码都是独立的,并不会影响到其他人员的模块代码。开发完成后,项目负责人会通过git命令,去把每个模块的分支合并到一个叫master主分支上面,项目正式上线的时候,就会把master主分支进行上线部署。

SVN,也是一个版本管理系统,但是它必须要在指定的网络环境上才能进行开发和管理。所以一旦网络崩溃或者说服务器宕机了,那么SVN的版本控制功能也就崩溃了。Git —— 分布式,可以让每个开发人员都能将整个代码完整地下载到本地,包括这个项目的分支、版本更新记录。如果线上环境崩溃,完全可以通过本地选择上一个正常的呆板,然后进行回滚,再将代码覆盖至线上就能进行恢复了。

1.1 Git 工作原理

1.1.1 工作区

Git 在本地初始化一个仓库后,会存在一个 .git 文件夹。它还存在三个工作区域:工作目录(工作区)、暂存区、资源库。如果从远端仓库拉去的项目,那就会多一个工作区域,就是远程git仓库。

  • 工作区(workspace):平时开发代码、写代码的地方;
  • 暂存区(Stage / Index):用于临时保存代码的改动;
  • 本地仓库(Repository):用于存放所有版本的数据;
  • 远程仓库(Remote):保存代码的地方,Github、码云;

2. Git 命令

2.1 Git 基础操作命令

2.1.1 Git 四步走

添加当前工作区文件到暂存区

git add .

将暂存区的代码提交到本地仓库

git commit -m "备注信息"

将远程仓库代码拉取到本地

git pull

将本地仓库的代码,推送到远端仓库

git push
2.1.2 克隆远程仓库代码

如果你本地没有这些代码的情况下,使用这个命令将远程仓库的代码克隆至本地

git clone https://gitee.com/lyan-test/git-demo.git

2.2 Git 配置命令

2.2.1 查看配置命令

# 查看所有配置
git config -l

# 查看系统配置
git config --system -l

# 查看全局配置
git config --global -l

2.2.2 配置全局

git config --global user.name "lyan_test"
git config --global user.email "1055869654@qq.com"

2.3 进阶操作

恢复某个阶段的代码

# 恢复到上一次版本
git reset --hard HEAD^

# 恢复到前3次提交时的版本
git reset --hard HEAD~3

# 恢复到指定的hash版本
git reset --hard 哈希码

3. 忽略文件

在项目根目录下创建一个名为 .gitignore 文件,文件里面写上需要排除的文件名即可。

如果说忽略文件之前就已经提交过这个文件,那就需要在工作目录先执行一次删除文件操作,再把这次操作提交到我们的本地仓库中进行同步。那下次推送时,远程仓库需要被忽略的文件就会被删除了。

3.1 匹配规则

如果想要忽略所有以某个后缀名为后缀的文件

*.md

如果想要排除某个文件不被忽略,可以通过英文感叹号 !

!readme.md

想排除根目录下的某个文件夹,可以通过 / + 文件夹来忽略

/test               # 这里代表根目录下的test文件夹将会被忽略提交,而 /js/test 的则不会。

如果想排除所有文件夹下的test文件夹

*/test
test/

4. 分支

每一个实际项目中,都会存在多个分支。每个分支都对应着一个模块,或者说需要修复的bug。

查看本地所有分支
git branch
查看远程所有分支
git branch -r
新建分支
git branch 分支名
切换开发分支
git checkout 分支名
新建并切换分支
git checkout -b 分支名

在切换分支时,一定要提交已修改的代码。否则另一条分支的代码将会覆盖工作区的代码文件,当然,git 是不允许这样操作的。

合并分支
git merge 分支B           # 假设当前开发的分支为分支A

代码意思是,分支B的内容将会合并到分支A内,但分支B的代码不会受到影响。

如果出现了有代码冲突的地方,那就需要去和开发人员商讨如何保留。

删除分支
git branch -d 分支名

删除分支时,首先要保证当前开发的分支不是被删除的那条分支,否则会删除失败。

如果被删除分支中存在差异性代码,那么也会导致删除失败。因为Git认为该操作会导致代码丢失的情况出现,所以确保没问题之后,可以通过强制删除命令删除分支。或者去将要删除的分支中,进行一次代码提交。

git branch -D 分支名           # 强制删除分支
删除远程分支
git branch -dr [remote/branch]      # 这个方法只是将本地的远程信息删除,并不会实际影响到远程仓库的分支
git push origin --delete branch         # 能够直接将远程仓库的分支进行删除

杂项命令

查看当前文件的状态
git status
  • Untracked:未跟踪,文件在工作区内,但是并没有经过 Git 的管理,要通过 git add 将文件加到暂存区,然后状态变为 Staged
  • Unmodify:文件已经进入 Git 版本库,此时 Git 会将版本库中的文件与工作区内的文件进行对比,如果内容完全一致,则代表文件未修改,也就是现在文件的状态。可以通过 git rm 将文件移出版本库,变为 Untracked 状态的文件;
  • Modified:文件已进入 Git 版本库,并且经对照后发现文件已经发生修改,但没有添加到暂存区。此时文件可以通过 git add 进入暂存区,或者通过 git checkout 命令,用版本库中的文件覆盖掉工作区的文件,此时文件状态会变为 Unmodify;
  • Staged:文件处于暂存区,通过 git commit 命令提交到本地仓库中。可以使用 git reset HEAD filename 取消暂存,文件状态将变为 Modified。

可能存在的问题

push 代码时,出现 403 错误

如果当前电脑之前登陆过码云,这时用的是另外一个码云账号,一般push时会出现403错误。

  • Windows用户:控制面板 —— 用户帐户 —— 凭据管理器 —— Windows凭据,找到gitee凭据删除即可。

  • Mac:钥匙串访问 —— 搜索git,会出现 gitee.com 的一个钥匙串,右键删除即可。

git push -f 导致远程仓库历史记录丢失

当本地仓库没有包含远程仓库所有的历史记录时,强制推送会导致远程仓库的历史记录丢失,产生不可逆的影响。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,921评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,635评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,393评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,836评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,833评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,685评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,043评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,694评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,671评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,670评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,779评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,424评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,027评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,984评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,214评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,108评论 2 351
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,517评论 2 343

推荐阅读更多精彩内容

  • 一、前言: 关于git的学习最早是来源于廖雪峰帅哥的官网,通俗易懂,场景众多。不过最近在掘金上看了一个帅哥的文章,...
    前端小学生_f675阅读 266评论 0 0
  • git使用 Git学习推荐廖雪峰老师的Git教程安装之后设置 设置用户名和邮箱 创建一个版本库(仓库reposit...
    冰花水焰阅读 318评论 0 0
  • 一、本地建立Git 创建一个版本库非常简单,首先,选择一个合适的地方,创建一个空目录: $ mkdir learn...
    alex日记阅读 518评论 0 0
  • git 的使用 代码协同管理工具 防止代码丢失,做代码备份 做代码的版本管理,创建多个版本或者节点,在多版本之间切...
    探索1者阅读 342评论 0 1
  • git和svn都是版本管理控制器,git是有本地仓库的,git有工作区和暂存区,工作区是指我们在本地电脑上的目录,...
    雪萌萌萌阅读 432评论 0 2