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 [email protected]: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:帮助

#表示注释

相关推荐
盖世英雄酱5813614 分钟前
🚀不改SQL,也能让SQL的执行效率提升100倍
java·数据库·后端
陈随易23 分钟前
Bun v1.2.16发布,内存优化,兼容提升,体验增强
前端·后端·程序员
GetcharZp24 分钟前
「Golang黑科技」RobotGo自动化神器,鼠标键盘控制、屏幕截图、全局监听全解析!
后端·go
程序员岳焱26 分钟前
Java 与 MySQL 性能优化:Linux服务器上MySQL性能指标解读与监控方法
linux·后端·mysql
坚持学习永不言弃27 分钟前
【底层】Volatile的理解
后端
高级bug工程师28 分钟前
💡 从业务中抽象通用能力:我如何封装了一个实用的 Spring Boot Starter 框架
后端
武子康30 分钟前
大数据-12-Hive 基本介绍 下载安装配置 MariaDB安装 3台云服务Hadoop集群 架构图 对比SQL HQL
后端
chenquan30 分钟前
ArkFlow 流处理引擎 0.4.0-rc1 发布
人工智能·后端·github
易安说AI42 分钟前
教你在cursor中无限使用Claude3.7模型,手慢无!
后端