Git操作命令总结

背景

这两天学习了git相关操作,记录下常见的操作命令。

基本理论

git本地有三个工作区:工作目录(Working Directory)、暂存区(stage\index)、资源区(Repository)或Git Directory

操作流程

目录结构

版本库:/.git隐藏文件夹

工作区:/.git所在的目录

暂存区:/.git/index 保存临时修改文件的地方

用户配置文件 :gitconfig

文件地址:.gitconfig

常见命令

通用指令

查看配置:查看配置git config -l

查看当前用户配置git config --global --list

修改用户配置

查看文件状态:git status [filename]

查看操作日志: git log

提示的文字在commit时书写

切换指定版本: git reset

git reset--hard 995e0688f2554e1e557d86f82de3e5c92db817c8 ,可以切换到指定版本的文件

分类

本地仓库操作

设置本地git仓库:git init

添加到暂存区: git add

可以看到add后文件的颜色由红变绿

取消暂存: git reset

add的逆操作,取消存入暂存区

提交:git commit

-m 以及后面的文字为此次更新的注释说明

本地流程总结

新建文件(红色)->add 文件(绿色)-> commit 文件(白色)

远程仓库操作

设置远程仓库:git clone

设置远程git仓库: git clone git@gitee.com:gitee-enterprise_2_0/hellogit.git

查看远程仓库:git remote -v

添加远程仓库:git remote add

可观察添加前后远程仓库数量(0->2)

推送到远程仓库:git pull origin master

推送到远程流程:新建文件->添加到缓存区(add)->提交(commit,可写备注)->推送远程仓库(pull)

合并冲突:pull后加上参数 --allow-unrelated-histories

分支相关操作

查看分支: git branch

参数说明:

不写,本地分支

-r远程分支

-a 所有分支(远程+本地)

创建分支: git branch [name]

切换分支:git checkout [name]

推送分支至远程仓库:git push [shortName] [name]

注意与上文的区别:git pull origin master

推送谁,最后一个参数就写谁,上文默认是主线master,这是分支b1

合并分支: git merge [name]

合并前切换到主线,在主线master合并分支b1

分支合并冲突处理 : commit后加 -i

注意与上文区别:--allow-unrelated-histories

上文是在一条分支内处理,横向的

这是处理两条分支冲突,纵向的

标签相关操作

显示标签:git tag

创建标签: git tag [name]

将标签推送至远程仓库:git push [shortName][name]

检出标签:git checkout -b [branch][name]

标签相关操作与分支基本相同

分支可看作日常协调工作,时不时会改

标签是较为稳定的一个版本,类似 v1.0,v2.0 作为一个发布版本

补充:基本的Linux的命令

pwd:显示当前所在的目录路径

ls(ll):都是列出当前目录的所有文件,之不多ll列出的内容更加详细

touch:创建一个文件,如touch index.js 就会在当前文件下创建一个文件

rm:删除一个文件

mkdir:新建一个目录,就是新建一个文件夹

rm-r:删除一个文件夹,rm -r src删除src目录

mv:移动文件 mv index.html src,index为要移动的文件,src为目标文件夹

reset:重新初始化屏幕

clear:清屏

history:查看历史命令

help:帮助

#表示注释

相关推荐
IT_陈寒3 分钟前
React 性能优化:5个实战技巧让首屏加载提升50%,开发者亲测有效!
前端·人工智能·后端
大厂码农老A33 分钟前
你打的日志,正在拖垮你的系统:从P4小白到P7专家都是怎么打日志的?
java·前端·后端
摇滚侠35 分钟前
Spring Boot 3零基础教程,深度理解 Spring Boot 自动配置原理,笔记11
spring boot·笔记·后端
间彧1 小时前
Spring Boot默认支持Logback的原因分析
后端
ezl1fe1 小时前
第零篇:把 Agent 跑起来的最小闭环
人工智能·后端·agent
文心快码BaiduComate1 小时前
文心快码Comate3.5S更新,用多智能体协同做个健康管理应用
前端·人工智能·后端
我是天龙_绍1 小时前
mybatis-plus 设置 数据库的字段自动填充
后端
Rust菜鸡1 小时前
在你的Rust类型里生成TypeScript的bindings!
后端
间彧1 小时前
Logback、Log4j与SLF4J的区别与选型指南
后端
间彧1 小时前
Logback详解与Spring Boot项目实战指南
后端