当前位置: 首页 > news >正文

git常用命令(git github ssh)

目录

  • 1、语法说明
  • 2、本地仓库相关操作
    • 建立一个git文件(git init)
    • 把工作区的文件添加到暂存区(git add)
    • 把暂存区的文件添加到本地仓库(git commit)
    • 查看暂存区和本地仓库中的文件(git ls-files)
    • 查看文件夹下所有文件的状态(git status)
    • 查看版本库中的提交记录(git log)
    • 恢复的文件(git checkout)
    • 版本退回(git reset)
    • 查看本地仓库文件和暂存区文件中的内容(git show)
    • 文件差异对比(git diff)
    • 忽略文件(.gitignore)
  • 3、SSH简介(密钥,GitHub)
    • 在本地生成公钥和私钥
    • 在GitHub中添加公钥
  • 4、远程仓库(GitHub)相关操作
    • 下载GitHub上的代码(git clone)
    • 下载被更新代码(git pull)
    • 上传修改的代码(git push)

1、语法说明

被”< >“和"[ ]“包含起来的内容表示用户自己选定的参数。但”< >“是要求用户必须输入的,而”[ ]"表示用户可以根据自己的需要选择输入。
比如git reset的语法是这样的:

git reset commit <commitid> --[option]

其中commitid指的是commit id,可以理解为每一提交到本地仓库之后该仓库状态的ID,利用这个ID我们可以快速定位到某个状态。
那么以下两个种方式都是合理的:

git reset commit 7b0dcac
git reset commit 7b0dcac --soft

2、本地仓库相关操作

建立一个git文件(git init)

用git Bash进入一个新的文件夹,输入以下命令可以建立一个git文件。

git init

查看一下是否有.git文件
在这里插入图片描述

把工作区的文件添加到暂存区(git add)

git add <object_file>

把暂存区的文件添加到本地仓库(git commit)

方法一:提交之后再进入vim编辑器写入这次提交的备注

git commit

方法一:提交的同时写入备注

git commit -m <"any information you wanna write.">

查看暂存区和本地仓库中的文件(git ls-files)

git ls-files

查看文件夹下所有文件的状态(git status)

git status

查看版本库中的提交记录(git log)

版本库即本地仓库。
方法一:直接查看提交记录的完整信息

git log

在这里插入图片描述
箭头所指的是每次提交更新之后本地仓库状态的哈希值,也可以理解该时间点本地仓库状态对应的ID,用的时候经常拿一部分来用即可。
方法二:查看部分重要信息

git log --oneline

在这里插入图片描述
红框内是哈希值的前N位,一般用这个来对应每一个的提交信息即可。

恢复的文件(git checkout)

  1. 在工作区中的文件被修改之后,却想要恢复到修改前的状态,但还未提交到暂存区和本地仓库。
 git checkout <object_file>

注:git checkout默认只是恢复到上一次的状态,如果想要恢复到更久以前的状态,请继续往下看。再者,这一小节的修改,不仅指修改了文件,还可以指文件被删除了。

  1. 在工作区中的文件被修改之后,却想要恢复到修改前的状态,但已经提交到暂存区和本地仓库。
  2. 在工作区中的文件被修改之后,却想要恢复到以前的某个状态,但已经提交到暂存区和本地仓库。
git checkout commit <commitid> <object_file>

注:这里的ID即是第N次提交记录的哈希值。该指令可以把object_file文件恢复到第N次提交时候的状态。

版本退回(git reset)

版本退回有三种方式,分别是soft, hard, mixed。其中的mixed也是默认(default)的方式。
默认的方式下,本地仓库的记录会退回到之前的某个时间点。但工作区和暂存区保持不变。

git reset <commitid>

soft的方式下,本地仓库和暂存区的状态会退回到之前的某个时间点。但工作区保持不变。

git reset <commitid> --soft

soft的方式下,本地仓库、暂存区和工作区的状态都会退回到之前的某个时间点。

git reset <commitid> --hard

用git reset --hard,打个比方。比如你在早上8:00向本地仓库提交了一次更新,版本库记录这次更新后的状态ID为123456。接着你继续工作到中午12:00,但此时你发现你早上的工作方向全错了,想要恢复早上8:00时的文件状态,就可以使用git reset 123456 --hard。

查看本地仓库文件和暂存区文件中的内容(git show)

查看暂存区中文件的内容。

git show :<object_file>

查看本地仓库里某次状态下的文件内容。

git show <commitid>:<object_file>

文件差异对比(git diff)

1、对比工作区和暂存区文件的差异

git diff [object_file]

可以看到这里的object_file是被”[ ]“包含起来的,说明这个参数可写也可不写,不写的话表示对比所有文件的差异,写则表示只对比某个文件的差异。
2、对比工作区和本地仓库文件内容之间的差异

git diff <commitid> [oject_file]

3、对比本地仓库中两个版本的差异

git diff <commitid> <commitid> [object_file] 

4、对比两个文件之间的差异

git diff <object_file_1> <object_file_2>

忽略文件(.gitignore)

在一个项目中,经常会生成一些中间文件,比如C++在Windows编译之后有一个.exe文件,而这些文件我们并不希望它被上传到本地仓库中。那么,我们就可以利用.gitignore文件去隐藏那些我们不希望上传的文件。
第一步:创建一个.gitignore文件

vim .gitignore

第二步:在.gitignore文件里写入我们希望被忽略的文件名。(比如所有的.exe文件)

echo *.exe -> .gitignore

3、SSH简介(密钥,GitHub)

在传统的网络通信当中,访问一个网站存在被第三方截取数据的风险,更甚至当你以自己的用户名和密码登录该网站的时候,这些信息也有可能被窃取。于是为了规避这种风险,人们提出了ssh。
SSH(Secure Shell): 一种网络安全协议,让信息以加密的形式进行传输。具体体现为ssh通信依赖公钥和私钥这两把钥匙来加密和解析数据。
无论是公钥还是私钥都由本地计算机生成,然后本地计算机会把公钥发给目标服务器。目标服务器所发送的信息都会用公钥进行加密,当收到信息之后,本地计算机再用私钥进行数据解析。由于公钥加密的信息只能用私钥进行解析,而私钥一直存在于本地PC之中,所以不可能被第三方通过网络窃取。通过这种设置,即便第三方通信数据,也因为只有一把钥匙而无法解析。
以上只是一些关于SSH的粗略理解,事实上公钥私钥只用于SSH握手过程的相互确认身份,具体的信息传递还是其他一些加密方法。

在本地生成公钥和私钥

进入git bash
第一步,切换到根目录且进入.ssh文件夹。

cd ~
cd .ssh

第二步,生成密钥。

sshtest-keygen -t rsa -b 4096

第三步,输入密钥的名称(例如test)。
第四步,输入密码。
在这里插入图片描述
通过这个这两部操作,会生成test和test.pub两个文件,前者是私钥文件,后者是公钥文件。
第五步,创建config文件,指定使用该密钥文件来认证GitHub。

tial -5 config

最后一步,进入test.pub文件,复制公钥添加在GitHub中。

在GitHub中添加公钥

通过上一个步骤,我们获取了本地计算机生成的公钥。接下来进入GitHub添加公钥。
如图,先进入GitHub页面,点击自己的头像,再点击Settings…
在这里插入图片描述
在这里插入图片描述
通过以上的操作,接下来我们用本地计算机访问GitHub的时候,GitHub便知道是哪台计算机访问它了,以便接下来我们将GitHub的远程仓库和本地仓库连接起来。

4、远程仓库(GitHub)相关操作

下载GitHub上的代码(git clone)

下载GitHub上的代码可以通过命令行的方式,也可以通过网页点击的方式。网页点击则相对简单,如图,直接点击Download ZIP即可以下载相应的压缩包。
在这里插入图片描述
命令行的方式则有三种,HTTPS, SSH, GitHub CLI。这三种方式只是复制对应的链接,然后在git bash输入命令行即可。

git clone <link>

在我们克隆(clone)别人的仓库之后,也可以用git log去查看作者的修改记录。

下载被更新代码(git pull)

如果我们想获取代码作者在GitHub上作的修改,最笨的方法当然是重新下载一遍,但也可以用git pull命令更新所修改的内容。但需要注意的是,使用git pull命令必须先进入相应的文件夹。

git pull

上传修改的代码(git push)

我们在本地修改代码并添加到本地仓库之后可以用git push命令来将代码上传到GitHub上。但这不意味着你可以随随便便的将自己的代码push到别人的仓库中,一般而言需要得到作者的许可。而对于自己的仓库,GitHub会通过用户名或ssh的密钥来自动匹配你的权限。

git push

相关文章:

git常用命令(git github ssh)

目录 1、语法说明2、本地仓库相关操作建立一个git文件(git init)把工作区的文件添加到暂存区(git add)把暂存区的文件添加到本地仓库(git commit)查看暂存区和本地仓库中的文件(git ls-files)查看文件夹下所有文件的状态(git status)查看版本库中的提交记录(git log)恢复的文件…...

完美解决:Nginx访问PHP出现File not found.

目录 解决方法一&#xff1a; 解决方法二&#xff1a; 遇到 File not found. 出现的问题解决&#xff1a; 解决方法一&#xff1a; 修改nginx的主配置文件。 vi /etc/nginx/nginx.conf location ~ \.php$ { root html; fastcgi_pass …...

音视频5、libavformat-2

4、封装 Muxers (封装器)以 AVPacket 的形式获取编码数据并将其写入到指定容器格式的文件或输出字节流中。 muxing过程中最重要的API函数有: avformat_write_header() 用于写入文件header; av_write_frame() / av_interleaved_write_frame() 用于写…...

python opencv -模板匹配

python opencv -模板匹配 模板匹配就是&#xff0c;我们现有一个模板和一个图片&#xff0c;然后&#xff0c;在这个图片中寻找和模板近似的部分。 在opencv 中主要通过cv2.matchTemplate这个函数去实现。 下面我们先看一下&#xff0c;模板图片和需要匹配的图片&#xff1a…...

大数据技能大赛(高职组)答案

任务C&#xff1a;数据挖掘&#xff08;10分&#xff09; 所有模块都有&#xff0c;不是白嫖&#xff01;&#xff01;有需要可以联系我 环境说明&#xff1a; 服务端登录地址详见各任务服务端说明。 补充说明&#xff1a;各节点可通过Asbru工具或SSH客户端进行SSH访问&#xf…...

C++动态规划算法:最多可以参加的会议数目

本周推荐阅读 C二分算法&#xff1a;得到子序列的最少操作次数 本题的其它解法 C二分算法&#xff1a;最多可以参加的会议数目 II 本文涉及的基础知识点 二分查找算法合集 题目 给你一个 events 数组&#xff0c;其中 events[i] [startDayi, endDayi, valuei] &#xf…...

Windows 下安装MySQL8.0 Zip

1、将下载的mysql 压缩包解压。 2、已管理员身份证 打开 cmd窗口&#xff0c;进入到解压目录的&#xff0c;本文以解压到 D:\soft\mysql-8.0.29-winx64 为例来介绍。 3、在解压目录下 新建一个 my.ini 文件。 my.ini 文件内容如下&#xff1a; [mysqld] # 设置3306端口 por…...

8.2 Windows驱动开发:内核解锁与强删文件

在某些时候我们的系统中会出现一些无法被正常删除的文件&#xff0c;如果想要强制删除则需要在驱动层面对其进行解锁后才可删掉&#xff0c;而所谓的解锁其实就是释放掉文件描述符&#xff08;句柄表&#xff09;占用&#xff0c;文件解锁的核心原理是通过调用ObSetHandleAttri…...

【Spark源码分析】事件总线机制分析

Spark事件总线机制 采用Spark2.11源码&#xff0c;以下类或方法被DeveloperApi注解额部分&#xff0c;可能出现不同版本不同实现的情况。 Spark中的事件总线用于接受事件并提交到对应的监听器中。事件总线在Spark应用启动时&#xff0c;会在SparkContext中激活spark运行的事件总…...

c语言第七弹--扫雷小游戏!

今天做一个有趣的扫雷小游戏 现在正式开始设计。 思路&#xff1a;想要根本上实现必须拥有 实现函数的主体.c文件 头文件.h 及头文件实现.c。 头文件.h #pragma once #include <stdio.h> #include <stdlib.h> #include <time.h> #define EASY_COUNT 10 #d…...

浏览器是什么

浏览器是什么 本文简要介绍浏览器的功能和组成。 浏览器&#xff08;Web Browser&#xff09;是一种用于访问和浏览互联网上的网页和资源的软件应用程序。它是用户与互联网交互的主要工具之一。 浏览器通过使用网络协议&#xff08;如HTTP、HTTPS等&#xff09;与远程服务器通…...

一文彻底看懂Python切片,Python切片理解与操作

1.什么是切片 切片是Python中一种用于操作序列类型(如列表、字符串和元组)的方法。它通过指定起始索引和结束索引来截取出序列的一部分,形成一个新的序列。切片是访问特定范围内的元素,就是一个Area。 说个笑话:切片不是切片,而是切片,但是又是切片。大家理解下呢(末…...

聊聊tomcat的connection-timeout

序 本文主要研究一下tomcat的connection-timeout ServerProperties.Tomcat org/springframework/boot/autoconfigure/web/ServerProperties.java public static class Tomcat {/*** Access log configuration.*/private final Accesslog accesslog new Accesslog();/*** Th…...

HCIA-RS基础:动态路由协议基础

摘要&#xff1a;本文介绍动态路由协议的基本概念&#xff0c;为后续动态路由协议原理课程提供基础和引入。主要讲解常见的动态路由协议、动态路由协议的分类&#xff0c;以及路由协议的功能和自治系统的概念。文章旨在优化标题吸引力&#xff0c;并通过详细的内容夯实读者对动…...

jQuery 第十一章(表单验证插件推荐)

文章目录 前言jValidateZebra FormjQuery.validValValidityValidForm BuilderForm ValidatorProgressionformvalidationjQuery Validation PluginjQuery Validation EnginejQuery ValidateValidarium后言 前言 hello world欢迎来到前端的新世界 &#x1f61c;当前文章系列专栏&…...

SSL握手失败的解决方案

一、SSL握手失败的原因&#xff1a; 1&#xff0c;证书过期&#xff1a;SSL证书有一个有效期限&#xff0c;如果证书过期&#xff0c;就会导致SSL握手失败。 2&#xff0c;证书不被信任&#xff1a;如果网站的SSL证书不被浏览器或操作系统信任&#xff0c;也会导致SSL握手失败…...

K8S客户端一 Rancher的安装

一 安装方式一 通过官网方式安装&#xff1a;官网 sudo docker run --privileged -d --restartunless-stopped -p 80:80 -p 443:443 rancher/rancher:stable访问服务器地址即可&#xff1a;http://192.168.52.128 修改语言 第一次安装会生成密码&#xff0c;查看密码步骤如下…...

websocket与node.js实现

什么是 websocket&#xff1f; websoket 是一种网络通信协议&#xff0c;基于 tcp 连接的全双工通信协议&#xff08;客户端和服务器可以同时收发信息&#xff09;&#xff0c;值得注意的是他不基于 http 协议&#xff0c;websocket 只有在建立连接的时候使用到 http 协议进行…...

postpresql 查询某张表的字段名和字段类型

postpresql 查询某张表的字段名和字段类型 工作中第一次接触postpresql&#xff0c;接触到这么个需求&#xff0c;只是对sql有点了解&#xff0c;于是就网上查阅资料。得知通过系统表可以查询&#xff0c;设计到几张系统表&#xff1a;pg_class、pg_attrubute、information_sc…...

jetson NX部署Yolov8

一,事情起因,由于需要对无人机机载识别算法进行更新,所以需要对yolov8算法进行部署到边缘端。 二,环境安装 安装虚拟环境管理工具,这个根据个人喜好。 我们需要选择能够在ARM架构上运行的conda,这里我们选择conda-forge 下载地址 安装即可 剩下的就是和conda 创建虚拟…...

RestClient

什么是RestClient RestClient 是 Elasticsearch 官方提供的 Java 低级 REST 客户端&#xff0c;它允许HTTP与Elasticsearch 集群通信&#xff0c;而无需处理 JSON 序列化/反序列化等底层细节。它是 Elasticsearch Java API 客户端的基础。 RestClient 主要特点 轻量级&#xff…...

测试微信模版消息推送

进入“开发接口管理”--“公众平台测试账号”&#xff0c;无需申请公众账号、可在测试账号中体验并测试微信公众平台所有高级接口。 获取access_token: 自定义模版消息&#xff1a; 关注测试号&#xff1a;扫二维码关注测试号。 发送模版消息&#xff1a; import requests da…...

业务系统对接大模型的基础方案:架构设计与关键步骤

业务系统对接大模型&#xff1a;架构设计与关键步骤 在当今数字化转型的浪潮中&#xff0c;大语言模型&#xff08;LLM&#xff09;已成为企业提升业务效率和创新能力的关键技术之一。将大模型集成到业务系统中&#xff0c;不仅可以优化用户体验&#xff0c;还能为业务决策提供…...

循环冗余码校验CRC码 算法步骤+详细实例计算

通信过程&#xff1a;&#xff08;白话解释&#xff09; 我们将原始待发送的消息称为 M M M&#xff0c;依据发送接收消息双方约定的生成多项式 G ( x ) G(x) G(x)&#xff08;意思就是 G &#xff08; x ) G&#xff08;x) G&#xff08;x) 是已知的&#xff09;&#xff0…...

【HarmonyOS 5.0】DevEco Testing:鸿蒙应用质量保障的终极武器

——全方位测试解决方案与代码实战 一、工具定位与核心能力 DevEco Testing是HarmonyOS官方推出的​​一体化测试平台​​&#xff0c;覆盖应用全生命周期测试需求&#xff0c;主要提供五大核心能力&#xff1a; ​​测试类型​​​​检测目标​​​​关键指标​​功能体验基…...

【Redis技术进阶之路】「原理分析系列开篇」分析客户端和服务端网络诵信交互实现(服务端执行命令请求的过程 - 初始化服务器)

服务端执行命令请求的过程 【专栏简介】【技术大纲】【专栏目标】【目标人群】1. Redis爱好者与社区成员2. 后端开发和系统架构师3. 计算机专业的本科生及研究生 初始化服务器1. 初始化服务器状态结构初始化RedisServer变量 2. 加载相关系统配置和用户配置参数定制化配置参数案…...

将对透视变换后的图像使用Otsu进行阈值化,来分离黑色和白色像素。这句话中的Otsu是什么意思?

Otsu 是一种自动阈值化方法&#xff0c;用于将图像分割为前景和背景。它通过最小化图像的类内方差或等价地最大化类间方差来选择最佳阈值。这种方法特别适用于图像的二值化处理&#xff0c;能够自动确定一个阈值&#xff0c;将图像中的像素分为黑色和白色两类。 Otsu 方法的原…...

如何为服务器生成TLS证书

TLS&#xff08;Transport Layer Security&#xff09;证书是确保网络通信安全的重要手段&#xff0c;它通过加密技术保护传输的数据不被窃听和篡改。在服务器上配置TLS证书&#xff0c;可以使用户通过HTTPS协议安全地访问您的网站。本文将详细介绍如何在服务器上生成一个TLS证…...

Android15默认授权浮窗权限

我们经常有那种需求&#xff0c;客户需要定制的apk集成在ROM中&#xff0c;并且默认授予其【显示在其他应用的上层】权限&#xff0c;也就是我们常说的浮窗权限&#xff0c;那么我们就可以通过以下方法在wms、ams等系统服务的systemReady()方法中调用即可实现预置应用默认授权浮…...

Reasoning over Uncertain Text by Generative Large Language Models

https://ojs.aaai.org/index.php/AAAI/article/view/34674/36829https://ojs.aaai.org/index.php/AAAI/article/view/34674/36829 1. 概述 文本中的不确定性在许多语境中传达,从日常对话到特定领域的文档(例如医学文档)(Heritage 2013;Landmark、Gulbrandsen 和 Svenevei…...