从零开始一个git操作实例,图文并茂
wptr33 2024-11-10 13:15 39 浏览
徒弟不懂git怎么用,
于是写了篇文章,
把本地git操作从头写了一遍,
自己去看吧!
0、基本概念
?Git是一个免费、开源的、分布式版本控制系统
?它使用一个特殊的叫做仓库的数据库来记录文件的变化
?仓库中的每个文件都有一个完整的版本历史记录
1)安装
sudo apt-update
sudo apt-get install git
git --version
2)工作流转
Git 管理项目时,文件流转的三个工作区域:Git 的工作目录,暂存区域,以及本地仓库。
你的本地仓库由 git 维护的三棵"树"组成。
- 工作目录:它持有实际文件;
- 暂存区(Index):它像个缓存区域,临时保存你的改动;
- 本地仓库(Respository):可以把本地仓库理解成一个目录,这个目录中所有的文件都可以被Git管理起来每个文件的删除、修改、新增操作都可以被Git跟踪到以便任何时候,都可以追踪历史或者还原到之前的某一个版本HEAD,它指向你最后一次提交的结果。
3)文件3种状态
对于任何一个文件,在 Git 内都只有三种状态:已修改(modified),已暂存(staged)和已提交(committed)。
- 已修改表示修改了某个文件,但还没有提交保存;
- 已暂存表示把已修改的文件放在下次提交时要保存的清单中; add
- 已提交表示该文件已经被安全地保存在本地数据库中了。commit
一、创建仓库并提交第1个commit
步骤1-4流程,参考下图流程会更清晰一些
1、创建仓库
使用当前目录作为Git仓库,我们只需使它初始化。
git init
该命令执行完后会在当前目录生成一个 .git 目录。
2、新建本地文件
本地增加文件url.c、README.md
实用git status查看文件状态,红色部分,有2个未跟踪的在文件
3、提交文件到暂存区git add
你可以提出更改(把它们添加到暂存区),使用如下命令:
git add <filename>
git add . //添加所有文件
git add *.c //添加所有c文件
执行下面操作:
git add *.c
git add README.md
4、提交改动git commit
使用如下命令以实际提交改动:
git commit -m "代码提交信息"
或者
git commit
然后进入vim编辑器,添加提交信息
例如:
git commit -m '初始化项目版本'
以上命令将目录下以 .c 结尾及 README 文件提交到仓库中。
现在,刚才的改动已经提交到了 HEAD,但是还没到远端仓库。
可以使用git log查看所有的提交:
5、推送改动git push
刚才的改动现在已经在本地仓库的 HEAD 中了。
执行如下命令以将这些改动提交到远端仓库:
git push origin master
可以把 master 换成你想要推送的任何分支。
如果你还没有克隆现有仓库,并欲将你的仓库连接到某个远程服务器,你可以使用如下命令添加:
git remote add origin <server>
如此你就能够将你的改动推送到所添加的服务器上去了。
三、 分支操作
分支是用来将特性开发绝缘开来的。在你创建仓库的时候,master 是"默认的"分支。
在其他分支上进行开发,完成后再将它们合并到主分支上。
0)查看分支
列出分支基本命令:
git branch
没有参数时,git branch 会列出你在本地的分支。
此例的意思就是,我们有一个叫做 master 的分支,并且该分支是当前分支。 执行 git init 的时候,默认情况下 Git 就会为你创建 master 分支。 分支在本地完成,速度快。
1)创建分支
要创建一个新的分支,我们使用branch命令。
git branch test
由上图所示:
- 多了一个分支test
- 当前分支为主分支master,前面*表示活动分支
2)切换分支
branch命令不会将我们带入分支,只是创建一个新分支。所以我们使用checkout命令来更改分支。
git checkout test
创建一个叫做"test"的分支,并切换过去:
git checkout -b test
如上图所示:
- 分支test前面有*,所以当前活动分支为master
分支创建和切换参考下图:
3)切回master分支并合并
在分支test上,修改文件url.c,然后commit
切换回主分支并合并
git checkout master
git merge test
由上图所示,git merge test后,主分支多了一个新的commit b9217
注意:
对其他分支的更改不会反映在主分支上。如果想将更改提交到主分支,则需切换回master分支,然后使用合并。
4)删除分支
使用-d标识,把新建的分支删掉:
git branch -d test
git branch -D test
如上图,我们删除了分支test
5)上传分支push
除非你将分支推送到远端仓库,不然该分支就是 不为他人所见的:
git push origin <branch>
四、替换本地改动git checkout
假如操作失误可以使用如下命令替换掉本地改动:
git checkout -- <filename>
此命令会使用 HEAD 中的最新内容替换掉你的工作目录中的文件。
已添加到暂存区的改动以及新文件都不会受到影响。
- 步骤
修改文件url.c,增加信息
//this change will be delete by git checkout
然后再git checkout url.c
如上图所示,
执行下面命令后:
git checkout url.c
url.c修改的信息
//this change will be delete by git checkout
已经被删除了,此时工作区域文件还原到了commitb 9217状态
查看url.c:
假如你想丢弃你在本地的所有改动与提交,可以到服务器上获取最新的版本历史,并将你本地主分支指向它:
git fetch origin
git reset --hard origin/master
五、重置git reset
当我们不想要之前提交的修改时,就会用到这个命令。也许这是一个 错误的提交或者可能是引入了 bug 的提交,这时候就要执行 git reset。
git reset 能让我们不再使用当前台面上的文件,让我们可以控制 HEAD 应该指向的位置。
1)软重置
软重置会将 HEAD 移至指定的提交(或与 HEAD 相比的提交的索引),而不会移除该提交之后加入的修改!
输入 git status 后,你会看到我们仍然可以访问在之前的提交上做过的所有修改。
这意味着我们可以修复这些文件的内容,之后再重新提交它们!
2)硬重置
有时候我们并不想保留特定提交引入的修改。不同于软重置,我们应该再也无需访问它们。
Git 应该直接将整体状态直接重置到特定提交之前的状态:这甚至包括你在工作目录中和暂存文件上的修改。
我们重新add并commit,然后硬重置
可见我们所有提交的信息都已经被移除,
工作区域文件恢复到commit 7bb299状态。
打开文件,查看,添加信息已经不存在,
六、还原git revert
另一种撤销修改的方法是执行 git revert。
通过对特定的提交执行还原操作,我们会创建一个包含已还原修改的新提交。
新创建文件peng.c并提交
用git revert 撤销修改
由上图所示,执行git revert 209485之后,我们新增的文件peng.c被删除,并提交了1个新的commit 5b08d
此前添加peng.c文件的提交还在,这样就保留了该提交信息,提高了仓库的兼容性。
在撤销特定的提交时,git revert 非常有用,同时也不会修改分支的历史。
七、拣选git cherry-pick
当一个特定分支包含我们的活动分支需要的某个提交时,我们对那个提交执行 cherry-pick!
对一个提交执行 cherry-pick 时,我们会在活动分支上创建一个新的提交,其中包含由拣选出来的提交所引入的修改。
创建切换到cherry分支,
git branch cherry
git checkout cherry
在分支cherry上修改文件README.md提交几个节点
切回master分支
git checkout master
执行git cherry-pick b98fc77
由上图所示,分支cherry的commit b98fc77,被复制到分支master,并创建了1个新的提交2d995,
通过该命令我们就可以将其他分支,需要的提交,合并到主分支master。
相关推荐
- [常用工具] git基础学习笔记_git工具有哪些
-
添加推送信息,-m=messagegitcommit-m“添加注释”查看状态...
- centos7安装部署gitlab_centos7安装git服务器
-
一、Gitlab介1.1gitlab信息GitLab是利用RubyonRails一个开源的版本管理系统,实现一个自托管的Git项目仓库,可通过Web界面进行访问公开的或者私人项目。...
- 太高效了!玩了这么久的Linux,居然不知道这7个终端快捷键
-
作为Linux用户,大家肯定在Linux终端下敲过无数的命令。有的命令很短,比如:ls、cd、pwd之类,这种命令大家毫无压力。但是,有些命令就比较长了,比如:...
- 提高开发速度还能保证质量的10个小窍门
-
养成坏习惯真是分分钟的事儿,而养成好习惯却很难。我发现,把那些对我有用的习惯写下来,能让我坚持住已经花心思养成的好习惯。...
- 版本管理最好用的工具,你懂多少?
-
版本控制(Revisioncontrol)是一种在开发的过程中用于管理我们对文件、目录或工程等内容的修改历史,方便查看更改历史记录,备份以便恢复以前的版本的软件工程技术。...
- Git回退到某个版本_git回退到某个版本详细步骤
-
在开发过程,有时会遇到合并代码或者合并主分支代码导致自己分支代码冲突等问题,这时我们需要回退到某个commit_id版本1,查看所有历史版本,获取git的某个历史版本id...
- Kubernetes + Jenkins + Harbor 全景实战手册
-
Kubernetes+Jenkins+Harbor全景实战手册在现代企业级DevOps体系中,Kubernetes(K8s)、Jenkins和Harbor组成的CI/CD流水...
- git常用命令整理_git常见命令
-
一、Git仓库完整迁移完整迁移,就是指,不仅将所有代码移植到新的仓库,而且要保留所有的commit记录1.随便找个文件夹,从原地址克隆一份裸版本库...
- 第三章:Git分支管理(多人协作基础)
-
3.1分支基本概念分支是Git最强大的功能之一,它允许你在主线之外创建独立的开发线路,互不干扰。理解分支的工作原理是掌握Git的关键。核心概念:HEAD:指向当前分支的指针...
- 云效Codeup怎么创建分支并进行分支管理
-
云效Codeup怎么创建分支并进行分支管理,分支是为了将修改记录分叉备份保存,不受其他分支的影响,所以在同一个代码库里可以同时进行多个修改。创建仓库时,会自动创建Master分支作为默认分支,后续...
- git 如何删除本地和远程分支?_git怎么删除远程仓库
-
Git分支对于开发人员来说是一项强大的功能,但要维护干净的存储库,就需要知道如何删除过时的分支。本指南涵盖了您需要了解的有关本地和远程删除Git分支的所有信息。了解Git分支...
- git 实现一份代码push到两个git地址上
-
一直以来想把自己的博客代码托管到github和coding上想一次更改一次push两个地址一起更新今天有空查资料实践了下本博客的github地址coding的git地址如果是Gi...
- git操作:cherry-pick和rebase_git cherry-pick bad object
-
在编码中经常涉及到分支之间的代码同步问题,那就需要cherry-pick和rebase命令问题:如何将某个分支的多个commit合并到另一个分支,并在另一个分支只保留一个commit记录解答:假设有两...
- 模型文件硬塞进 Git,GitHub 直接打回原形:使用Git-LFS管理大文件
-
前言最近接手了一个计算机视觉项目代码是屎山就不说了,反正我也不看代码主要就是构建一下docker镜像,测试一下部署的兼容性这本来不难但是,国内服务器的网络环境实在是恶劣,需要配置各种镜像(dock...
- 防弹少年团田柾国《Euphoria》2周年 获世界实时趋势榜1位 恭喜呀
-
当天韩国时间凌晨3时左右,该曲在Twitter上以“2YearsWithEuphoria”的HashTag登上了世界趋势1位。在韩国推特实时趋势中,从上午开始到现在“Euphoria2岁”的Has...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
程序员的开源月刊《HelloGitHub》第 71 期
-
详细介绍一下Redis的Watch机制,可以利用Watch机制来做什么?
-
假如有100W个用户抢一张票,除了负载均衡办法,怎么支持高并发?
-
Java面试必考问题:什么是乐观锁与悲观锁
-
如何将AI助手接入微信(打开ai手机助手)
-
SparkSQL——DataFrame的创建与使用
-
redission YYDS spring boot redission 使用
-
一文带你了解Redis与Memcached? redis与memcached的区别
-
如何利用Redis进行事务处理呢? 如何利用redis进行事务处理呢英文
-
- 最近发表
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)