Git实用笔记

198次阅读
没有评论

共计 2438 个字符,预计需要花费 7 分钟才能阅读完成。

Git 的作用是版本控制,即管理文件夹。

下载安装 Git

官网下载:https://git-scm.com/downloads

官方文档:https://git-scm.com/book/zh/v2

使用 Git 之前的最小配置:

# 配置个人信息:用户名、邮箱
git config --global user.name '李小龙'
git config --global user.email '1@qq.com'

global 对当前用户所有仓库有效,local 只对某个仓库有效,system 对系统所有登录的用户有效。

创建仓库

建 Git 仓库,有两种场景:

  1. 把已有项目代码纳入 Git 管理
    1. cd 项目代码所在文件夹
    2. git init,进行本地初始化
  2. 新建项目直接用 Git 管理
    1. cd 某个文件夹
    2. git init your_project,会在当前路径下创建和项目名称同名的文件夹
    3. cd your_project
# 1 查看当前文件状态(新增和修改过的文件都是红色)git status

# 2 添加一个或多个文件到暂存区
git add [file1] [file2]
# 添加指定目录到暂存区
git add [dir]
# 添加当前目录下的所有文件到暂存区
git add .

# 将文件移出暂存区
git rm --cached [file1]

# 3 生成版本
git commit -m "描述信息"

# 查看版本记录
git log
# 版本记录图形展示(h 是哈希值,s 是提交记录)git log --graph --pretty=format:"%h %s"

# 4 创建分支,使用 -M 强制重命名
git branch -M main

# 文件重命名
git mv 旧文件名 新文件名

Git 实用笔记

回滚

# 回滚至之前版本
git reset --hard 版本号

# 查看所有历史版本信息
git reflog
# 回滚至之后版本
git reset --hard 版本号

四步曲(添,提,拉,推)

实际工作开发四步曲:添,提,拉,推,其作用分别是:

  • 添:将修改内容添加到本地暂存区 git add
  • 提:将本地暂存区内容提交到本地代码库 git commit -m ‘description’
  • 拉:同步,拉取远程代码库内容 git pull。在多人协同开发中十分重要,因为假如事先没有同步更新到最新版本有可能会覆盖别人修改的东西,假如拉取后有冲突,解决冲突即可
  • 推:将本地代码库内容推送到远程代码仓库 git push

分支

git branch # 查看分支
git branch 分支名称 # 创建分支,如 dev、bug 分支
git checkout 分支名称 # 切换分支
git merge 要合并的分支 # 分支合并
git branch -d 分支名称 # 删除分支

分支合并可能会产生冲突,需要手动解决冲突。快速解决冲突可以使用软件,如 Beyond Compare,比较方便直观。

变基

作用是合并提交记录,使代码变得简洁,建议合并记录时不要合并那些已 push 到远程仓库的记录。

把最近 3 条提交记录合并成 1 条:git rebase -i HEAD~3

合并分支:git rebase 分支 ,在 git rebase 过程中可能会产生冲突,需要手动解决冲突。解决完冲突后,执行命令:git rebase --continue 继续变基。

GitHub

# 给远程仓库起别名(git@github.com:abc/learn-go.git)git remote add origin 远程仓库地址
# 向远程仓库推送代码。- u 选项即 --set-upstream 用来设置上游分支,在本地分支和远程分支之间建立一个关联
# 执行一次带 - u 选项的 git push 后,以后只需使用 git push 就可将本地分支推送到对应的远程分支,不需要每次都指定远程仓库和分支
# 加 -f 强制推送
git push -u origin 分支

# 克隆远程仓库代码(内部已实现 git remote add origin 远程仓库地址)git clone 远程仓库地址
# 指定分支,- b 选项指定特定分支,比如 dev 分支或标签 v1
git clone -b dev 远程仓库地址

# 切换分支(git branch 查看分支可能看不到,但可以切换分支,如果有分支的话)git checkout 分支名称
# 分支合并(如在 dev 上开发,需要把 master 合并到 dev,确保 dev 代码最新:git merge master)git merge 要合并的分支

# 拉取远程仓库代码
git pull origin 分支
# 等价于
git fetch origin 分支 # 远程仓库到版本库
git merge origin/ 分支 # 版本库到工作区

Git 标签

tag 通常用于标记项目的特定版本,例如版本 1.0 或 2.0。

创建带有注释的 tag:git tag -a v1 -m "第一版"

查看标签详细信息:git show [tagname]

推送所有 tag:git push --tags,这将推送所有尚未在远程仓库上的本地标签。

配置

# 项目配置文件:项目 /.git/config
git config --local user.name '李小龙'
git config --local user.email '1@qq.com'

# 全局配置文件:~/gitconfig
git config --global user.name '李小龙'
git config --global user.email '1@qq.com'

# 系统配置文件:/etc/.gitconfig
git config --system user.name '李小龙'
git config --system user.email '1@qq.com'

免密登录

URL 中体现

原来的地址: https://github.com/abc/hello.git

修改后地址: https:// 用户名: 密码 @github.com/abc/hello.git

SSH 实现

  1. 生成公钥和私钥,默认放在~/.ssh 目录下,id_rsa.pub 公钥、id_rsa 私钥:ssh-keygen
  2. 拷贝公钥内容,并设置到 GitHub 中
  3. 在 Git 本地中配置 ssh 地址:git remote add origin git@github.com/abc/hello.git
  4. 以后使用:git push origin master

正文完
 0
阿伯手记
版权声明:本站原创文章,由 阿伯手记 于2023-08-02发表,共计2438字。
转载说明:本站原创内容,除特殊说明外,均基于 CC BY-NC-SA 4.0 协议发布,转载须注明出处与链接。
评论(没有评论)
验证码

阿伯手记

阿伯手记
阿伯手记
喜欢编程,头发渐稀;成长路上,宝藏满地
文章数
766
评论数
204
阅读量
436959
今日一言
-「
热门文章
职场救急!AI请假话术生成器:1秒定制高通过率理由

职场救急!AI请假话术生成器:1秒定制高通过率理由

超级借口 不好开口?借口交给我!智能生成工作请假、上学请假、饭局爽约、约会拒绝、邀约推辞、万能借口等各种借口理...
夸克网盘快传助手提高非VIP下载速度

夸克网盘快传助手提高非VIP下载速度

夸克网盘限速这个大家都知道,不开会员差不多限速在几百 K。那有没有办法在合法合规途径加速下载夸克网盘呢?这里推...
国内已部署DeepSeek模型第三方列表 免费满血版联网搜索

国内已部署DeepSeek模型第三方列表 免费满血版联网搜索

本文收集了目前国内已部署 DeepSeek 模型的第三方列表,个个都是免费不限次数的满血版 DeepSeek,...
巴别英语:用美剧和TED演讲轻松提升英语听力与口语

巴别英语:用美剧和TED演讲轻松提升英语听力与口语

还在为枯燥的英语学习而烦恼吗?巴别英语通过创新的美剧学习模式,让英语学习变得生动有趣。平台提供海量美剧和 TE...
TVAPP:开源电视盒子资源库,一键打造家庭影院

TVAPP:开源电视盒子资源库,一键打造家庭影院

导语 TVAPP 是一个专为 Android TV 电视盒子用户打造的开源影音资源库,集成了影视、直播、游戏等...
Chinese Name Generator 在线中文姓名生成器

Chinese Name Generator 在线中文姓名生成器

Chinese Name Generator 是一款在线中文姓名生成器,可在几秒内生成符合个人需求的中文名字。...
2025年12月 每日精选

2025年12月 每日精选

关于每日精选栏目 发现一些不错的资源,点击 这里 快速投稿。 12 月 26 日 .ax 顶级域 目前全球唯一...
最新评论
15220202929 15220202929 怎么用
八对 八对 麻烦大佬更新下【堆新】的友链站名:八对星星描述:极目星视穹苍无界•足履行者大地有疆链接:https://8dui.com图标:https://cf.8dui.com/logo.webp横标:https://cf.8dui.com/logo-w.webp订阅:https://8dui.com/rss.xml
三毛笔记 三毛笔记 已添加
DUINEW DUINEW 已添加贵站,期待贵站友链~博客名称:堆新博客地址:https://duinew.com/博客描述:堆新堆新,引力向新!——堆新(DUINEW)博客头像:https://d.duinew.com/logo.webp横版头像:https://d.duinew.com/logo-w.webp博客订阅:https://duinew.com/rss.xml
hedp hedp 没看懂
bingo bingo 直接生成就可以啦,也可以添加一些选项
满心 满心 申请更新下友联信息,原名:满心记,现名:周天记原域名:qq.mba,现域名:zhoutian.com描述:我在人间混日子
开业吉日 开业吉日 没看明白这个怎么用
开业吉日 开业吉日 beddystories 这个网站太赞了,收藏
热评文章
夸克网盘快传助手提高非VIP下载速度

夸克网盘快传助手提高非VIP下载速度

夸克网盘限速这个大家都知道,不开会员差不多限速在几百 K。那有没有办法在合法合规途径加速下载夸克网盘呢?这里推...
国内已部署DeepSeek模型第三方列表 免费满血版联网搜索

国内已部署DeepSeek模型第三方列表 免费满血版联网搜索

本文收集了目前国内已部署 DeepSeek 模型的第三方列表,个个都是免费不限次数的满血版 DeepSeek,...
清华大学官方免费DeepSeek教程

清华大学官方免费DeepSeek教程

AI 领域近期最引人注目的焦点当属 DeepSeek,这款由中国创新企业深度求索研发的人工智能工具,正以开放源...
Short-Link 免费开源短网址程序,基于Fastify、Vercel和Supabase构建

Short-Link 免费开源短网址程序,基于Fastify、Vercel和Supabase构建

Short-Link 是一款基于 Fastify、Vercel 和 Supabase 构建的 URL 缩短服务...
Chinese Name Generator 在线中文姓名生成器

Chinese Name Generator 在线中文姓名生成器

Chinese Name Generator 是一款在线中文姓名生成器,可在几秒内生成符合个人需求的中文名字。...
BeddyStories 完全免费儿童睡前故事库,让孩子随时随地入睡更轻松

BeddyStories 完全免费儿童睡前故事库,让孩子随时随地入睡更轻松

BeddyStories 是一个致力于为儿童提供优质睡前故事的在线平台,用户可以在这里找到来自世界各地的经典故...
DrawLink:一键生成链接视觉卡片,提升分享点击率

DrawLink:一键生成链接视觉卡片,提升分享点击率

小贴士 :此站或已变迁,但探索不止步。我们已为您备好「类似网站」精选合集,相信其中的发现同样能为您带来惊喜。