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

    1. 选择开发环境,这里我以Windows为例
      在这里插入图片描述
    1. 选择对应的系统位下载
      在这里插入图片描述
    1. 安装时全部选择默认即可,安装完后进入某一个文件夹,出现如下情况即为安装成功!
      在这里插入图片描述

三、Git常规命令

  1. 初始化本地仓库
git init
  1. 查看文件状态
git status
  1. 将文件从工作区移至暂存区
    例如:git add test.txt,表示将文件test.txt放入到暂存区中
git add 文件名
  1. 将暂存区的文件提交到本地仓库
    例如git commit -m “add test.txt”,表示将暂存区的文件都提交到本地仓库,并备注“add test.txt”
git commit -m “备注”
  1. 查看提交版本记录
git log
  1. 查看历史操作记录
git reflog
  1. 版本回退,commitID为回退的ID号,ID号可用git log指令查看
git reset --hard commitID
  1. 起别名。在本机用户(例如我的: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的优化使用。

  1. 左键双击可选中字符表示复制,按下鼠标滚轮表示粘贴。

  2. 若不想让某些文件纳入git管理,则在工作目录中创建.gitignore文件,里面输入需要忽略的文件名。例如:忽略所有.a后缀的文件,则在.gitignore中编辑“*.a

四、新建本地仓库

    1. 新建一个文件夹作为测试使用
    1. 进入该文件夹,右键选择Git bash
    1. 在命令行中输入“git init”,初始化本地仓库
    1. 在命令行中输入“touch test.txt”,在仓库中创建一个文件,此时该文件处于工作区状态(一个文件想存储到本地仓库需要经过2个变换:工作区–>暂存区、暂存区–>本地仓库)
    1. 将文件放入暂存区中。输入命令“git add test.txt”,该命令表示将文件test.txt放入到暂存区中。
    1. 提交到本地仓库。输入指令“git commit -m "add test.txt"”,该命令表示将暂存区的文件都提交到本地仓库,并备注“add test.txt”

五、本地分支操作

    1. 查看本地分支
git branch
    1. 创建本地分支
git branch 分支名
    1. 切换分支
git checkout 分支名
    1. 直接切换到一个不存在的分支(创建并切换)
git checkout -b 分支名
    1. 合并分支,将“分支名”合并到当前的分支上
git merge 分支名
    1. 删除分支,需要做各种检查(推荐使用)
git branch -d 分支名
    1. 强制删除分支,无需任何检查
git branch -D 分支名

六、Git远程仓库

这里我以Gitee为例,建立远程仓库,Github、Gitlab等同理。

    1. 注册登录Gitee账号
    1. 在Gitee上创建仓库
      在这里插入图片描述
    1. 回到本地仓库Git bash上,输入命令“ssh-keygen -t rsa”,然后一直回车即可
    1. 获取公钥,继续输入命令“cat ~/.ssh/id_rsa.pub”,复制如下公钥
      在这里插入图片描述
    1. 回到Gitee,打开设置,进入SSH公钥,在公钥编辑框内输入粘贴到的公钥
      在这里插入图片描述
    1. 验证公钥是否配置成功。回到Git bash,输入“ssh -T git@gitee.com
    1. 到Gitee中复制仓库的SSH地址
      在这里插入图片描述
    1. 添加远程仓库,地址为上面复制的SSH地址,起别名为“origin”到git bash中输入“git remote add origin SSH地址
    1. 验证是否添加成功,查看远程仓库,输入指令“git remote
    1. 将本地仓库推送到远程仓库,输入指令“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即可👇👇👇
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/112394.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

智能AI写作系统+ChatGPT程序源码搭建部署教程+支持GPT4.0/AI绘画

一、SparkAI智能创作系统 SparkAi创作系统是基于国外很火的ChatGPT进行开发的Ai智能问答系统。本期针对源码系统整体测试下来非常完美,可以说SparkAi是目前国内一款的ChatGPT对接OpenAI软件系统。那么如何搭建部署AI创作ChatGPT?小编这里写一个详细图文…

驱动开发,udev机制创建设备节点的过程分析

1.创建设备文件的机制种类 mknod命令:手动创建设备节点的命令 devfs:可以用于创建设备节点,创建设备节点的逻辑在内核空间(内核2.4版本之前使用) udev:自动创建设备节点的机制,创建设备节点的逻辑在用户空间&#xf…

基于Java+SpringBoot+Vue的旧物置换网站设计和实现

基于JavaSpringBootVue的旧物置换网站设计和实现 源码传送入口前言主要技术系统设计功能截图数据库设计代码论文目录订阅经典源码专栏Java项目精品实战案例《500套》 源码获取 源码传送入口 前言 摘 要 随着时代在一步一步在进步,旧物也成人们的烦恼,…

一键畅享云端ERP:使用Cpolar内网穿透将用友U8 Cloud部署至外网

文章目录 前言1. 用户需求2. Cpolar内网穿透的安装和注册2.1 Cpolar云端设置2.2 Cpolar Web UI本地设置 3. 公网访问测试 前言 用友U8 Cloud是用友公司推出的一款云端ERP解决方案。它以云计算技术为基础,为企业提供全面的企业资源管理解决方案,涵盖了财…

github 上传和拉取 support for passward authentication was removed...

参考下面这篇文章 remote: Support for password authentication was removed on August 13, 2021_IT博客技术分享的博客-CSDN博客 但是记得把repositories和 permissions的选项都点上,不然又会报下面的错误。

使用亚马逊云科技人工智能内容审核服务,打造安全的图像生成和扩散模型

生成式人工智能技术发展日新月异,现在已经能够根据文本输入生成文本和图像。Stable Diffusion 是一种文本转图像模型,可让您创建栩栩如生的图像应用。您可以通过 Amazon SageMaker JumpStart,使用 Stable Diffusion 模型轻松地从文本生成图像…

多线程详解(上)

文章目录 一、线程的概念1)线程是什么2)为甚要有线程(1)“并发编程”成为“刚需”(2)在并发编程中, 线程比进程更轻量. 3)线程和进程的区别 二、Thread的使用1)线程的创建继承Thread…

(图论) 827. 最大人工岛 ——【Leetcode每日一题】

❓ 827. 最大人工岛 难度:困难 给你一个大小为 n x n 二进制矩阵 grid 。最多 只能将一格 0 变成 1 。 返回执行此操作后,grid 中最大的岛屿面积是多少? 岛屿 由一组上、下、左、右四个方向相连的 1 形成。 示例 1: 输入: grid [[1, 0]…

Maven 安装配置

Maven 安装配置 文章目录 Maven 安装配置一、下载 Maven二、解压Maven核心程序三、指定本地仓库四、配置阿里云镜像仓库4.1 将原有的例子配置注释掉4.2 加入新的配置 五、配置 Maven 工程的基础 JDK 版本六、配置环境变量6.1 检查 JAVAHOME 配置是否正确6.2 配置 MAVENHOME6.3 …

vue柱状图+折线图组合

<template><div id"main" style"width: 100%;height: 500px; padding-top: .6rem"></div> </template>data() {return {weekData: ["1周","2周","3周","4周","5周","6周&…

Java + Selenium + Appium自动化测试

一、启动测试机或者Android模拟器&#xff08;Genymotion俗称世界上最快的模拟器&#xff0c;可自行百度安装&#xff09; 二、启动Appium&#xff08;Appium环境安装可自行百度&#xff09; 三、安装应用到Genymotion上&#xff0c;如下图我安装一个计算机的小应用&#xff0c…

Python+Django前后端分离

程序示例精选 PythonDjango前后端分离 如需安装运行环境或远程调试&#xff0c;见文章底部个人QQ名片&#xff0c;由专业技术人员远程协助&#xff01; 前言 这篇博客针对《PythonDjango前后端分离》编写代码&#xff0c;代码整洁&#xff0c;规则&#xff0c;易读。 学习与应…