【Linux学习笔记】git三板斧

【Linux学习笔记】git三板斧

 🌟个人主页:努力学习的小汤  

🌈专栏系列:linux

目录

❄️前言:

☀️版本控制器git

☀️git简史

☀️git三板斧

⭐gitee创建仓库并克隆到本地

⭐1. git add

⭐2. git commit

⭐3. git push

⭐4. 首次使用git

☀️git其他操作

⭐git status

⭐git log

⭐git pull

☀️本章小结:

🌻共勉:


❄️前言:

 上一篇博客我们学习了make和makefile自动化构建工具,今天我们来学习一下git的三板斧。

☀️版本控制器git

为了我们方便管理不同版本的文件,就有了版本控制器;

所谓的版本控制器,就是能够了解到一个文件的历史记录(修改记录);简单来说就是记录每一次的改动和版本迭代的一个管理系统,同时也方了多人进行协作。

当前应用最广泛的版本控制器就是gitgit可以控制电脑上所有格式的文件。

之前我们在windows下使用git来管理自己的本地文件,并上传至gitee

☀️git简史

​ 同生活中的许多伟大事物一样,Git 诞生于一个极富纷争大举创新的年代。Linux 内核开源项目有着为数众多的参与者。绝大多数的Linux 内核维护工作都花在了提交补丁和保存归档的繁琐事务上(1991-2002年间)。到2002年,整个项目组开始启用一个专有的分布式版本控制系统 BitKeeper 来管理和维护代码。

到了 2005 年,开发 BitKeeper 的商业公司同 Linux 内核开源社区的合作关系结束,他们收回了 Linux内核社区免费使用 BitKeeper 的权力。这就迫使 Linux 开源社区(特别是 Linux 的缔造者 LinusTorvalds)基于使用 BitKeeper 时的经验教训,开发出自己的版本系统。他们对新的系统制订了若干目标:

速度。简单的设计。对非线性开发模式的强力支持(允许成千上万个并行开发的分支)。完全分布式。有能力高效管理类似 Linux 内核一样的超大规模项目(速度和数据量)。

自诞生于 2005 年以来,Git 日臻成熟完善,在高度易用的同时,仍然保留着初期设定的目标。 它的速度飞快,极其适合管理大项目,有着令人难以置信的非线性分支管理系统。

那我们在linux下该如何使用git来管理文件呢?

☀️git三板斧

在使用之前,当然要先进行安装git

yum install git 

在进行管理之前,我们要登录gitee官网注册属于自己的账号https://gitee.com

gitee创建仓库并克隆到本地

在注册完成账号之后,我们的账号下是没有任何仓库的;我们要先进行创建仓库,并且将仓库克隆到自己的本地来管理自己的文件。

创建仓库:

在注册完成账号后,来到个人主页,点击右上角头像旁边的+,点击创建仓库,进入创建仓库的界面。

进入到以下界面

这里填写一下仓库信息

仓库名称:为自己的仓库起个名字

仓库介绍:简单介绍自己的仓库

初始化仓库:初始化语言,模版(gitignore),开源许可证

设置模版:选择readme文件(可以编辑该文件,帮助读者快速了解自己的仓库内容。

分支模型:这里选择单分支模型(根据自己需求选择)。

创建完成就进入了以下界面;(可以看到readme文件,我们克隆到本地后可以进行修改)。

创建完成之后,我们将这个仓库,克隆到本地

  1. 点击上图中的克隆/下载,获取当前仓库地址

点击之后,有上述提示,我们只需要在本地执行即可。

git clone https://gitee.com/lxb0720/test_linux.git 

如上图所示,就成功将仓库克隆到本地了,我们现在就可以看到仓库里的内容了

⭐1. git add

git add,我们在windows下,直接点击,选择要添加的文件即可;

但是在linux下,我们不能像windows那样选择要添加的文件,所以我们要告知我们要上传的文件就行上传。

⭐2. git commit

当我们git add之后,文件只是上传到了暂存区,并没有被管理起来;

我们要执行git commit将暂存区的文件上传到本地仓库,让文件被管理起来。
git commit -m "描述信息" 

这里推荐加上-m选项,并且加上描述信息,就像写日志那样。

⭐3. git push

通过git commit,我们已经将文件在本地仓库管理起来;但是,这些文件还并没有同步到远端;我们在gitee上还是无法看到这些文件。

git push就是件本地仓库内容同步到远端。

在执行git push之后,需要我们输入gitee的用户名和密码才能上传成功。

⭐4. 首次使用git

如果第一次使用git上传文件,需要我们配置运行用户名和邮箱;在我们点击克隆/下载时,就有提示

直接指向下面指令即可。

git config --global user.name '用户名' git config --global user.email '邮箱' 

☀️git其他操作

git status

对于git status,这个操作的作用就是查看当前的状态;

说简单一点就是看现在进行了哪一步操作。

这里再看git commit后的状态

这里执行git push后,再次来查看

git log

我们使用git来管理我们的文件,那如果我们想要查看我们提交上传的记录,就要用到git log

这里就可以看到我们的提交用户和日期以及提交的日志信息

git pull

在了解这个指令之前,我们先来看git是如何管理并同步到远端的。

看到这里可能有疑惑,本地文件夹和本地仓库不一样吗?

肯定是不一样的,在我们将远端仓库克隆到本地文件夹时,我们该目录下是存在一个.git隐藏文件的

我们看到还存在一个gitigonre文件,那这个文件是干什么的呢?

这里就直接说了

.gitignore文件是在我们上传文件时,需要忽视的文件名后缀。

什么意思呢?

这里.gitinore文件中存在多种文件名的后缀,这里就看.o

我们在编译时可能会产生临时文件.o,但是我们不希望将这个临时文件上传,这时gitignore文件中有.o,在上传的时候就会忽略.o,不会将其上传。

到这里git简单操作就结束了,后期深入学习git之后再来详细探讨git。

☀️本章小结:

模块核心知识点具体操作 / 指令补充说明
Git 基础定义与优势Git:分布式版本控制器,可管理任意格式文件2005 年由 Linus 开发,适配 Linux 内核级超大规模项目核心优势:速度快、设计简单、支持多分支并行开发、完全分布式
安装(Centos/RedHat)yum install gitUbuntu 系统可使用apt install git
Gitee 仓库操作仓库创建1. 登录 Gitee(https://gitee.com)2. 个人主页右上角「+」→「创建仓库」3. 填写仓库名称、描述等信息,完成创建仓库是存放项目文件的容器,支持公有 / 私有权限设置
克隆仓库到本地git clone 仓库地址例:git clone https://gitee.com/lxb0720/test_linux.git克隆后本地生成仓库目录,包含远端仓库所有文件及.git 隐藏目录(本地仓库核心)
Git 核心三板斧暂存文件(add)git add 文件名:暂存指定文件git add .:暂存当前目录所有修改文件将本地修改的文件提交到「暂存区」,是提交前的必要步骤
提交到本地仓库(commit)git commit -m "描述信息"1. -m 必须加,描述信息需清晰(如「新增 test.c 文件」)2. 将暂存区文件提交到「本地仓库」,生成版本记录
推送到远端仓库(push)git push1. 执行后需输入 Gitee 用户名 + 密码验证2. 将本地仓库提交记录同步到 Gitee 远端仓库3. 首次推送前需配置用户信息(见下方)
Git 基础配置首次使用配置git config --global user.name '用户名'git config --global user.email '邮箱'--global 表示全局配置,所有仓库共用该信息用户名 / 邮箱需与 Gitee 注册信息一致
Git 辅助操作查看状态(status)git status显示文件的修改状态:未跟踪 / 已修改 / 已暂存 / 已提交可快速判断哪些文件需要 add/commit/push
查看提交日志(log)git log显示所有提交记录,包含提交人、时间、描述信息、版本号便于追溯版本修改历史
拉取远端更新(pull)git pull将 Gitee 远端仓库的最新内容同步到本地仓库多人协作时,推送前建议先 pull 避免冲突
.gitignore 文件作用配置需要忽略的文件 / 后缀避免上传临时文件(如.o、.out、.i 等编译产物)、敏感文件等
配置示例在.gitignore 中写入:.o.out*.log配置后,git add/push 会自动忽略匹配的文件,不会纳入版本控制

🌻共勉:

以上就是本篇博客的所有内容啦,我们下期见,加油!


Read more

嫌 OpenClaw 太重?ZeroClaw 重磅开源!

大家好,我是玄姐。 摘要:当 OpenClaw 的 Node.js 内存占用让你抓狂,当 Agent 的响应速度无法满足实时需求,是时候看看 Rust 带来的新选择了。ZeroClaw,一个 100% Rust 编写、极致轻量、高度模块化的 AI Agent 框架,正式开源。 过去的一个月里,OpenClaw(及其前身 Moltbot/Clawdbot)以其强大的生态和易用性,几乎成为了开源 AI Agent 的代名词。然而,随着大家在生产环境中通过 Node.js 运行越来越复杂的 Agent 工作流,一些问题也逐渐浮出水面: 资源消耗大:Node.js 运行时的内存占用在多 Agent 场景下显得捉襟见肘。

By Ne0inhk

ALVR终极配置指南:3步解决VR串流卡顿问题

ALVR终极配置指南:3步解决VR串流卡顿问题 【免费下载链接】ALVRALVR is an open source remote VR display for Gear VR and Oculus Go. With it, you can play SteamVR games in your standalone headset. 项目地址: https://gitcode.com/gh_mirrors/alv/ALVR ALVR作为开源VR远程显示解决方案,能够将PC端的SteamVR游戏流畅传输到Gear VR、Oculus Go/Quest等独立头显设备。本指南将带你从基础安装到高级优化,彻底解决VR串流中的卡顿和延迟问题。 入门指南:从零开始搭建ALVR环境 硬件要求检查清单 在开始配置之前,请确保你的设备满足以下基本要求: 设备类型最低配置推荐配置PC显卡NVIDIA

By Ne0inhk
1.5k stars!阿里开源 PageAgent:让 AI 直接“住进“你的网页,用自然语言操控一切!

1.5k stars!阿里开源 PageAgent:让 AI 直接“住进“你的网页,用自然语言操控一切!

阿里开源 PageAgent:让 AI 直接"住进"你的网页,用自然语言操控一切 不需要浏览器插件,不需要 Python,不需要截图——一行 JS,让你的网页秒变 AI 智能体。 一、先说痛点:Web 自动化为什么这么难? 如果你用过 Selenium、Playwright,或者最近流行的 browser-use,你一定遇到过这些头疼的问题: * 环境太重:得装 Python、headless 浏览器、各种依赖,部署复杂,维护成本高; * 依赖截图 + OCR:很多方案靠多模态模型"看图操作",慢、贵、还不准; * 权限门槛高:要控制浏览器,往往需要特殊权限甚至操作系统级别的访问; * 对现有产品改造成本大:

By Ne0inhk
AI Agent开发第86课-讲透知识图谱Neo4j在构建Agent时到底怎么用(一)

AI Agent开发第86课-讲透知识图谱Neo4j在构建Agent时到底怎么用(一)

前言 知识图谱常被误解为一堆实体和关系的静态集合,实则不然。它的本质是一种结构化的语义网络,用“实体-关系-实体”的三元组形式,刻画现实世界中对象之间的复杂关联。这种建模方式天然贴近人类认知逻辑——我们理解“苹果”不仅因其属性(红色、甜),更因它与“水果”“乔布斯”“iPhone”等概念存在上下位、创始人、品牌等不同语义关系。传统关系型数据库以表结构存储数据,在表达这类多跳、异构、动态的关系时显得力不从心,JOIN 操作成本随关联深度指数级增长。图数据库的出现正是为了解决这一根本矛盾。 Neo4j 作为主流图数据库代表,将数据直接建模为节点与关系,查询时沿着连接路径遍历,时间复杂度与路径长度相关,而非全表扫描。这使得在智能 Agent 构建中,当需要基于多层因果、上下文或隐含关联进行推理决策时,Neo4j 能提供毫秒级响应。笔者认为,Agent 的“智能”不仅体现在大模型的语言生成能力,更在于其能否基于可靠、可追溯的知识结构进行逻辑推演。知识图谱配合 Neo4j,

By Ne0inhk