Git 基本操作【本地仓库与远程仓库的推送、克隆和拉取】
文章目录
- 一、Git简介
- 二、Git的下载安装
- 三、Git常规命令
- 四、新建本地仓库
- 五、本地分支操作
- 六、Git远程仓库
- 七、远程仓库克隆、抓取和拉取
- 八、总结
- 九、学习交流
一、Git简介
Git是分布式版本控制系统(Distributed Version Control System,简称 DVCS),分为两种类型的仓库:
本地仓库和远程仓库
工作流程如下
1.从远程仓库中克隆或拉取代码到本地仓库(clone/pull)
2.从本地进行代码修改
3.在提交前先将代码提交到暂存区
4.提交到本地仓库。本地仓库中保存修改的各个历史版本
5.修改完成后,需要和团队成员共享代码时,将代码push到远程仓库
二、Git的下载安装
官网下载地址:https://git-scm.com/download
-
- 选择开发环境,这里我以Windows为例
- 选择开发环境,这里我以Windows为例
-
- 选择对应的系统位下载
- 选择对应的系统位下载
-
- 安装时全部选择默认即可,安装完后进入某一个文件夹,出现如下情况即为安装成功!
- 安装时全部选择默认即可,安装完后进入某一个文件夹,出现如下情况即为安装成功!
三、Git常规命令
- 初始化本地仓库
git init
- 查看文件状态
git status
- 将文件从工作区移至暂存区
例如:git add test.txt,表示将文件test.txt放入到暂存区中
git add 文件名
- 将暂存区的文件提交到本地仓库
例如git commit -m “add test.txt”,表示将暂存区的文件都提交到本地仓库,并备注“add test.txt”
git commit -m “备注”
- 查看提交版本记录
git log
- 查看历史操作记录
git reflog
- 版本回退,commitID为回退的ID号,ID号可用git log指令查看
git reset --hard commitID
- 起别名。在本机用户(例如我的:C/用户/18100)的目录下创建文件“
.bashrc
”,在该文件里输入指令起别名。例如:
alias git-log='git log --pretty=oneline --all --graph --abbrev-commit'
即将git log --pretty=oneline --all --graph --abbrev-commit
起别名为git-log
,该语句意为git log的优化使用。
-
左键双击可选中字符表示复制,按下鼠标滚轮表示粘贴。
-
若不想让某些文件纳入git管理,则在工作目录中创建
.gitignore
文件,里面输入需要忽略的文件名。例如:忽略所有.a
后缀的文件,则在.gitignore
中编辑“*.a
”
四、新建本地仓库
-
- 新建一个文件夹作为测试使用
-
- 进入该文件夹,右键选择Git bash
-
- 在命令行中输入“
git init
”,初始化本地仓库
- 在命令行中输入“
-
- 在命令行中输入“
touch test.txt
”,在仓库中创建一个文件,此时该文件处于工作区状态(一个文件想存储到本地仓库需要经过2个变换:工作区–>暂存区、暂存区–>本地仓库)
- 在命令行中输入“
-
- 将文件放入暂存区中。输入命令“
git add test.txt
”,该命令表示将文件test.txt放入到暂存区中。
- 将文件放入暂存区中。输入命令“
-
- 提交到本地仓库。输入指令“
git commit -m "add test.txt"
”,该命令表示将暂存区的文件都提交到本地仓库,并备注“add test.txt”
- 提交到本地仓库。输入指令“
五、本地分支操作
-
- 查看本地分支
git branch
-
- 创建本地分支
git branch 分支名
-
- 切换分支
git checkout 分支名
-
- 直接切换到一个不存在的分支(创建并切换)
git checkout -b 分支名
-
- 合并分支,将“分支名”合并到当前的分支上
git merge 分支名
-
- 删除分支,需要做各种检查(推荐使用)
git branch -d 分支名
-
- 强制删除分支,无需任何检查
git branch -D 分支名
六、Git远程仓库
这里我以Gitee为例,建立远程仓库,Github、Gitlab等同理。
-
- 注册登录Gitee账号
-
- 在Gitee上创建仓库
- 在Gitee上创建仓库
-
- 回到本地仓库Git bash上,输入命令“
ssh-keygen -t rsa
”,然后一直回车即可
- 回到本地仓库Git bash上,输入命令“
-
- 获取公钥,继续输入命令“
cat ~/.ssh/id_rsa.pub
”,复制如下公钥
- 获取公钥,继续输入命令“
-
- 回到Gitee,打开设置,进入SSH公钥,在公钥编辑框内输入粘贴到的公钥
- 回到Gitee,打开设置,进入SSH公钥,在公钥编辑框内输入粘贴到的公钥
-
- 验证公钥是否配置成功。回到Git bash,输入“
ssh -T git@gitee.com
”
- 验证公钥是否配置成功。回到Git bash,输入“
-
- 到Gitee中复制仓库的SSH地址
- 到Gitee中复制仓库的SSH地址
-
- 添加远程仓库,地址为上面复制的SSH地址,起别名为“
origin
”到git bash中输入“git remote add origin SSH地址
”
- 添加远程仓库,地址为上面复制的SSH地址,起别名为“
-
- 验证是否添加成功,查看远程仓库,输入指令“
git remote
”
- 验证是否添加成功,查看远程仓库,输入指令“
-
- 将本地仓库推送到远程仓库,输入指令“
git push 远端名称 本地分支名:远端分支名
”,例如git push origin master:master
- 将本地仓库推送到远程仓库,输入指令“
以上推送到远程仓库的步骤可用改用“git push --set-upstream origin master
”,意为当前分支与远端的master分支关联起来,并同时完成推送,即在以后的推送中可以直接使用“git push
”完成推送。
Tips:git branch -vv
:可查看分支的关联关系。
七、远程仓库克隆、抓取和拉取
- 1. 克隆
在计算机某文件夹中打开git bash,输入“git clone 仓库SSH地址 本地目录
”,意为对远程仓库进行复制,存放到“文件夹”中,其中“本地目录”可省略,系统会自动生成一个目录。 - 2. 抓取
抓取命令“git fetch 远端名 远端分支
”,即将远端仓库里的某个分支的更新都抓取到本地,不会合并,如果不指定远端名和分支名,则抓取所有分支。 - 3. 拉取
拉取命令“git pull 远端名 远端分支
”,即将远端仓库的修改拉取到本地并会自动进行合并,等同于fetch+merge,如果不指定远端名和分支名,则拉取所有分支。
Tips:“git merge origin/master
”为将远程仓库的master分支合并到本地分支
八、总结
本地仓库:是在开发人员自己电脑上的Git仓库,存放我们的代码(.git 隐藏文件夹就是我们的本地仓库)
远程仓库:是在远程服务器上的Git仓库,存放代码(可以是github.com或者gitee.com 上的仓库,或者自己该公司的服务器)
工作区: 我们自己写代码(文档)的地方
暂存区: 在 本地仓库中的一个特殊的文件(index) 叫做暂存区,临时存储我们即将要提交的文件
Clone:克隆,就是将远程仓库复制到本地仓库
Push:推送,就是将本地仓库代码上传到远程仓库
Pull:拉取,就是将远程仓库代码下载到本地仓库,并将代码 克隆到本地工作区
九、学习交流
学习交流 联系下方wx即可👇👇👇
相关文章:
Git 基本操作【本地仓库与远程仓库的推送、克隆和拉取】
文章目录 一、Git简介二、Git的下载安装三、Git常规命令四、新建本地仓库五、本地分支操作六、Git远程仓库七、远程仓库克隆、抓取和拉取八、总结九、学习交流 一、Git简介 Git是分布式版本控制系统(Distributed Version Control System,简称 DVCS&…...
FPGA开发
https://www.enclustra.com.cn/?bd_vid11435475462206745180 https://www.monolithicpower.cn/design-tools/design-tools/llc-design-tool.html https://www.elecfans.com/article/88/143/2012/20120718280641_2.html...
js手撕代码
1、实现instanceof运算符 instanceof运算符用于检测构造函数的prototype属性是否出现在某个实例对象的原型链上,运算符左侧是实例对象,右侧是构造函数。 const isInstanceof function(left,right){let proto Object.getPrototypeOf(left);while(true…...
typecho反序列化
typecho反序列化 环境的搭建 漏洞复现前提 <?php class Typecho_Feed {const RSS1 RSS 1.0;const RSS2 RSS 2.0;const ATOM1 ATOM 1.0;const DATE_RFC822 r;const DATE_W3CDTF c;const EOL "\n";private $_type;private $_items;public function __const…...
php程序设计的基本原则
单一职责原则(SRP):一个类应该只有一个原因引起变化,即一个类应该只负责一项职责。 class User {private $name;private $email;public function __construct($name, $email) {$this->name $name;$this->email $email;}p…...
python execute() 使用%s 拼接sql 避免sql注入攻击 好于.format
1 execute(参数一:sql 语句) # 锁定当前查询结果行 cursor.execute("SELECT high, low, vol FROM table_name WHERE symbol %s FOR UPDATE;"% (symbol,)) 2 .format() cursor.execute("SELECT high, low, vol FROM table_name WHERE symbol {} FOR UPDATE;…...
RPC项目解析(1)
分布式通信框架:让远程方法调用和调用进程内方法一样简单 RPC通信原理 rpc:远程过程调用(远程能够调用其他模块的方法) 在rpc中需要发送时候,对发送的信息进行序列化,在服务端对接收到的信息进行反序列化…...
点云从入门到精通技术详解100篇-基于 RGB 图像与点云融合的三维点云分割算法及成像系统
目录 前言 相机和激光雷达标定研究现状 点云分割算法研究现状...
JDK8新特性
Lembda表达式 lembda表达式是一个简洁、可传递的匿名函数,实现了把代码块赋值给一个变量的功能 是我认为jdk1.8中最让人眼前一亮的特性(我没用过其他函数式的语言) 在了解表达式之前,我们先看两个概念 函数式接口 含有且仅含有一个抽象方法&…...
X86_64函数调用汇编程序分(2)
X86_64函数调用汇编程序分(2) 1 X86_64寄存器使用标准2 leaveq和retq指令2.1 leaveq2.2 retq 3 执行leaveq和retq之后栈的结构3.1 执行leaveq之后栈的结构3.1.1 test_fun_b函数执行leaveq之前的栈结构示意图3.1.2 test_fun_b函数执行leaveq之后的栈结构示…...
组件传值之ref(解决父传子动态绑定问题)
在父组件往子组件传值,子组件中要显示父组件的信息,首先是在网上搜的watch 来监听组组件的props,但是父组件只传一次,后续再更改就没了,所以我用的$refs props:{params:{type:Object;defult():{return {} } } }watch:{params: {/…...
vscode-server
1know_host清除 2 删除服务器里的home/user/.vscode-server(不是根root下的vscode-server),删除时用户名保持一致。 3 ssh配置文件 /etc/ssh/sshd_config[想改变,使用root,修改文件权限] 4 删除修改后,重启Windows下…...
ubuntu 20.04安装开发环境总结_安装python
Ubuntu 20.04 是一款主要面向开发人员的操作系统之一,与此同时,它还支持多种开发环境和工具的使用。但是因为对市面上各种软件的支持没有window那样友好,所以对ubuntu系统安装配置各种环境的问题做了个总结 安装 PyCharm: 可以从…...
尚硅谷_宋红康_IntelliJ IDEA 常用快捷键一览表
1-IDEA的日常快捷键 第1组:通用型 说明快捷键复制代码-copyctrl c粘贴-pastectrl v剪切-cutctrl x撤销-undoctrl z反撤销-redoctrl shift z保存-save allctrl s全选-select allctrl a 第2组:提高编写速度(上) 说明快捷…...
Java设计模式之建造者模式详解(Builder Pattern)
在日常的开发工作中,我们常常需要创建一些复杂的对象。这些对象可能包含许多不同的属性,并且这些属性的初始化过程可能相当复杂。在这种情况下,建造者模式是一种非常有用的设计模式,因为它允许我们分步骤地创建复杂的对象。 概念和…...
TCP的滑动窗口与拥塞控制
客户端每发送的一个包,服务器端都应该有个回复,如果服务器端超过一定的时间没有回复,客户端就会重新发送这个包,直到有回复。 为了保证顺序性,每一个包都有一个 ID。在建立连接的时候,会商定起始的 ID 是什…...
MySQL更新语句执行过程
执行流程 update t set name XXX where id 1; 加载id1的记录所在的整页数据到缓存池;旧值写入undolog便于回滚;更新内存数据;写redo log到RedoBuff;redo log顺序写入磁盘,准备提交事务(prepare阶段&…...
Matlab图像处理-彩色图像基础
彩色的物理认识 人类能够感知的物体的颜色是由物体反射的光的性质决定的。如图8-2所示,可见光是由电磁波谱中较窄的波段组成。 如果物体反射的光在所有可见光波长范围内都是平衡的,那么从观察者的角度来看,它是白色的; 如果物体…...
MATLAB算法实战应用案例精讲-【数模应用】数据中台
目录 前言 几个高频面试题目 数据中台、数仓、大数据平台的区别 1)数据中台VS数据仓库...
el-form动态检验无法生效问题(已解决)
要对el-form里面的字段动态生成校验规则,测试了一系列的骚操作也无法生效,要么是require视图生效了,校验规则还是不生效;看了csdn里面好多方案,都是废话,废话,直接上硬货,最终总结如下ÿ…...
【python】代码学习过程问题总结
目录 1. 使用 conda 创建并进入虚拟环境 2. pycharm 选择 interpreter 的时候,在虚拟环境中找不到 python.exe 3.(py & python)ModuleNotFoundError: No module named XXX 4. AttributeError: module ‘tensorflow‘ has no attribu…...
Qt应用开发(基础篇)——菜单 QMenu
一、前言 QMenu类继承于QWidget,它提供了一个菜单样式的小部件,用于菜单栏、上下文菜单和一些弹出式菜单。 QMenu菜单的选项是可选的,它可以是一个下拉的菜单,也可以是独立的上下文菜单。下拉菜单通常作用于当用户单击相应的项目或…...
MySQL-DDL语句
MySQL-DDL语句 数据库操作语句增删数据库查看数据库列表创建数据库进入(使用)数据库/查看当前所在的数据库查看数据库的建库语句查看数据库的编码集和校验集删除数据库修改数据库的编码集查看数据库支持的编码集和校验集 数据库备份备份单个数据库恢复数…...
总结987
考研倒计时102天 时间记录: 6:20起床 7:00~7:40早读,13年tex2 7:50~8:20实验室 8:30~8:34列日计划 8:40~11:18进步本回顾,记录 11:20~12:20计算机网络网课 2:10~3:05计网20道选择题 3:07~4:42政治1000题25道选择题纠错 …...
【服务器 | 测试】如何在centos 7上面安装jmeter
安装之前需要几个环境,以下是列出的几个环境 CentOS 7.7 64位JDK 1.8JMeter 5.2 1. 下载jmeter安装包 JMeter是开源的工具,安装 JMeter 要先安装好 JDK 的环境,安装JDK在前面的文章已经讲到 JMeter最新版下载地址:Apache JMeter…...
20.04部署cartographer
部署cartographer sudo apt-get update sudo apt-get install -y python3-wstool python3-rosdep ninja-build stow下载cartographer新建了一个ws mkdir carto_ws cd carto_ws wstool init src wstool merge -t src https://raw.githubusercontent.com/cartographer-project/…...
djangoMTV初探
1.restful请求方式 一个视图对应多个操作(增删改查) 老的方式 views.py from django.shortcuts import render from django.http import HttpResponse,request,QueryDict, JsonResponse from myapp.models import User from django.views.generi…...
Minecraft--基于云服务器搭建自己的服务器--简易搭建
阿丹: 上一个项目结束了。但是看着自己的服务器想着能不能做点啥子吧。想到了之前和兄弟们玩的麦块。好久没和兄弟们一起玩耍了。怀念之前一起连一个wifi玩我的世界的时候是真快乐。于是尝试自己动手搭建一个我的世界服务器,邀请兄弟们重温一下快乐。 提…...
【数据结构与算法】十大经典排序算法
文章目录 前言一、常见十大排序算法总结1、名词解释2、时间复杂度 二、排序算法与C语言实现1、冒泡排序2、选择排序3、插入排序4、希尔排序5、归并排序6、快速排序7、堆排序8、计数排序9、桶排序10、基数排序 总结 前言 排序算法是《数据结构与算法》中最基本的算法之一。 排序…...
Android 12.0 SystemUI下拉状态栏定制化之隐藏下拉通知栏布局功能实现(一)
1.前言 在12.0的系统定制化开发中,由于从12.0开始SystemUI下拉状态栏和11.0的变化比较大,所以可以说需要从新分析相关的SystemUI的 布局,然后做分析来实现不同的功能,今天就开始实现关于隐藏SystemUI下拉状态栏中的通知栏布局系列一 如图: 2.SystemUI下拉状态栏定制化之…...
网站建设详细方案/大一html网页制作作业简单
上网查了一下,官方貌似没有提供flash builder 4.5的下载,但是既然是基于eclipse的,那么应该能被安装在linux下。 首先,安装eclipse sudo apt-get install eclipse 然后,下载eclipse的flash builder 插件 最后就是安装了…...
公司做免费网站建设/搜索引擎广告案例
0x00 前言 随着微软越来越开放,C#也变得越来越吸引人们的眼球。而在游戏行业中,C#也开始慢慢地获得了关注。这不, 网易绝代双娇手游团队已经全面使用.Net Core支持前后端统一C#开发,跨平台部署了。 所以,我们就来总结一…...
动态网站建设试题/百度推广代理商名单
lua 函数 函数 语法格式 function_scope function function_name( argument1, argument2, argument3, ...)function_bodyreturn result_params_comma_separated end 相关说明 function_scope:函数作用域,全局或者local,不设置默认为全局 fu…...
域名注册了 如何做网站/2023年8月新冠又来了
title转载于:https://www.cnblogs.com/wangjixianyun/p/9036220.html...
做网站fjfzwl/网站自己推广
1、安装编译环境 1.基础环境 yum update yum groupinstall "Development Tools" 2.gettext更新 gettext 版本大于0.18可以跳过 gettext -V 编译安装: wget https://ftp.gnu.org/pub/gnu/gettext/gettext-0.21.tar.gz --no-check-certificate &…...
成都最好的网站建设/广州营销seo
前段时间做了一个开发,涉及到网络编程,开发过程比较顺利,但任务完成后始终觉得有一些疑惑。主要是因为对网络协议不太熟悉,对一些概念也没弄清楚。后来我花了一些时间去了解这些网络协议,现在对TCP/IP网络协议有了初步…...