Windows下git和github的使用

news2024/11/23 16:45:27

介绍windows下的git和GitHub使用。

一、注册gihub账号

github官网:https://github.com 自行创建即可。
登录,create repository新建仓库一个测试库readme,创建完成。
在这里插入图片描述

二、git的安装

git官方网站:https://git-scm.com/
选择Windows版本下载安装即可。
在这里插入图片描述
在这里插入图片描述
下载安装直接默认全部下一步即可
安装完成后,在任务栏可以看到已经存在这几个软件
在这里插入图片描述

三、生成 ssh key连接GitHub

3.1 生成密钥

打开git bash生成ssh key 密钥,加密方式为rsa。

 ssh-keygen -t rsa

在这里插入图片描述
可以看到生成的密钥在C盘的用户,用户名下的.ssh名录。
在这里插入图片描述

3.2 复制公共密钥到git hub

公钥为id_rsa.pub的内容,以txt文本模式打开复制里面的内容。

登录github,在选项setting >> SSH and GPG key >> add new ssh添加刚才的公钥地址即可。title随便填写即可。

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

3.3 验证是否连接成功

输入以下命令,第一次需要确认输入yes即可。

ssh -T git@github.com

在这里插入图片描述
如图所示,出现 You’ve successfully authenticated, but GitHub does not provide shell access.则成功连接。

四、git命令上传文件至GitHub仓库

4.1 配置git参数的username,email

这是因为Git是分布式版本控制系统,所以,每个机器都必须自报家门:你的名字和Email地址。

git config --global user.email "xxx@example.com"
git config --global user.name "Your Name"

自己设置自己的用户名和邮箱地址。不设置这一步,后面commit会报错如下:

Author identity unknown
 
*** Please tell me who you are.
 
Run
 
  git config --global user.email "you@example.com"
  git config --global user.name "Your Name"
 
to set your account's default identity.
Omit --global to set the identity only in this repository

4.2 选择一个盘,创建自己的仓库目录

这里我以C盘为例,创建一个demo文件夹作为项目目录。
在这里插入图片描述
注:在我们进行任何的git操作之前,我们都得先切换到 Git 的仓库目录。

4.3 打开Git Bash,命令进入仓库目录

cd  C:/git/demo

在这里插入图片描述

4.4 git init初始化仓库目录

进入任何一个新的仓库目录,第一步就是要初始化这个仓库目录。

git init

在这里插入图片描述
初始化后,默认进入仓库主分支,即master。
命令 git status 可查看仓库状态,初始化后在查看这时已经有了一个空仓库.
在这里插入图片描述
在文件夹中,这时也出现一个隐藏的文件夹.git,这个是一个仓库。
在这里插入图片描述

4.5 git add添加文件到本地仓库

在demo文件夹创建一个文件123.txt,作为测试文件。
然后在Git Bash 添加文件到本地仓库。
在这里插入图片描述

git add 123.txt

在这里插入图片描述

4.6 git commit提交文件到本地仓库

提交到本地库并备注为123 commit,此时变更仍在本地。

git commit -m "123 commit"

在这里插入图片描述

4.7 git remote add增加一个远程服务器的别名

为了后续的方便管理,可设置一个别名。
格式为git remote add 别名 git@github.com:GitHub用户名/GitHub仓库名.git

git remote add 123 git@github.com:theonlyu/test.git 

theonlyu 改成自己的GitHub用户名
test 改成自己的GitHub仓库名
在这里插入图片描述

4.8 git push推送到github仓库

后面接刚才设置的别名就可以了。

git push 123 master

在这里插入图片描述
在GitHub的test仓库查看,也已经存在文件了。
在这里插入图片描述
推送完成,命令参考:

git add README.md #添加文件到本地仓库
git rm README.md #本地倒库内删除
git commit -m "first commit" #提交到本地库并备注,此时变更仍在本地。
git commit -a  ##自动更新变化的文件,a可以理解为auto
git remote add xxx git@github.com:xxx/xxx.git  #增加一个远程服务器的别名。
git remote rm xxx   ##删除远程版本库的别名
git push -u remotename master #将本地文件提交到Github的remoname版本库中。此时才更新了本地变更到github服务

五、从GitHub仓库下载至本地

下载比较简单,在GitHub右边的code下可看到好几种下载方式,可以直接下载zip压缩文件,也可命令下载,一般选择ssh方式,可读写。
在这里插入图片描述

5.1 同样你需要进入一个目录

如直接下载到C盘的test文件夹,则先进入C盘test文件夹

cd /c/git/demo/test

在这里插入图片描述

5.2 git clone下载至本地

git clone git@github.com:xxxxxx/test.git

在这里插入图片描述

下载方式差别参考:

git clone git://github.com:xxxx/test.git ##以gitreadonly方式克隆到本地,只可以读
git clone git@github.com:xxx/test.git  ##以SSH方式克隆到本地,可以读写
git clone https://github.com/xxx/test.git ##以https方式克隆到本地,可以读写
git fetch git@github.com:xxx/xxx.git  ##获取到本地但不合并
git pull git@github.com:xxx/xxx.git ##获取并合并内容到本地

六、Git的分支管理

6.1 创建分支

例子:在本地demo目录创建一个branch.txt以分支提交。

git branch #显示当前分支是master
git branch new_bra  #创建分支命名为new_bra
git checkout new_bra  #切换到新分支
git add branch.txt
git commit -m "added branch.txt"
git push 123 new_bra  ##把分支提交到远程服务器,只是把分支结构和内容提交到远程,并没有发生和主干的合并行为。

在这里插入图片描述
在github左上角可看到,new_bra分支已经上传成功,文件也存在了。主master却还没有新文件,因为没合并。
在这里插入图片描述

6.2 合并分支

如果new_bra分支成熟了,就是代码确认下来了,觉得有必要合并进master

git checkout master  #切换到新主干
git merge new_bra  ##把分支合并到主干
git branch #显示当前分支是master
git push 123 master #此时主干中也合并了new_bra的代码,123为别名

在这里插入图片描述
在github中成功合并,切换至master,新文件 branch.txt 也存在了。
在这里插入图片描述

6.3 其他命令

#更新远程分支列表
git remote update 别名 --prune
 
#查看所有分支
git branch -a
 
#删除远程分支
git push 别名 --delete 分支名
 
#删除本地分支
git branch -d 分支名

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C#中如何使用ObjectPool来提高StringBuilder的性能

在C#中我们知道使用StringBuilder能提高大量字符串拼接的效率,其实StringBuilder的效率也可以提升,那就是使用ObjectPool。以下介绍怎么使用ObjectPool提高StringBuilder的性能。一、简介 C# ObjectPool类是一个内置的类库,用于实现对象…

Elasticsearch:如何使用自定义的证书安装 Elastic Stack 8.x

在我之前的文章 “如何在 Linux,MacOS 及 Windows 上进行安装 Elasticsearch”,我详细描述了如何在各个平台中安装 Elastic Stack 8.x。在其中的文章中,我们大多采用默认的证书来安装 Elasticsearch。在今天的文章中,我们用自己创…

异常检测经典作:基于teacher-students的无监督异常检测

来源:投稿 作者:Mr.Eraser 编辑:学姐 论文链接:https://arxiv.org/pdf/1911.02357.pdf 贡献 提出了一种基于师生学习的无监督异常检测新框架:来自预训练教师网络的局部描述符用作学生集合的代理标签。模型能够在大型…

<<和>>操作符、取地址重载、const关键字

文章目录 自定义类型<<和>>重载const关键字取地址重载&#xff08;类的默认构造函数&#xff09; 自定义类型<<和>>重载 在内置类型中&#xff0c;<<和>>可以自动识别 在自定义类型冲&#xff0c;运算符重载&#xff0c;<<和>&…

maven从入门到精通 第六章 在Maven中项目导入、生命周期、插件、目标、仓库

这里写自定义目录标题 一 工程与模块导入1 工程导入的方法1.1 版本控制系统1.2 来自工程目录1.2.1 直接导入工程文件1.2.2直接解压 2 模块导入 二 生命周期的基本概念1 生命周期存在的意义 三 插件和目标四 仓库 一 工程与模块导入 1 工程导入的方法 1.1 版本控制系统 通常使…

有赞一面:亿级用户DAU日活统计,有几种方案?

说在前面 在40岁老架构师 尼恩的读者社区(50)中&#xff0c;最近有小伙伴拿到了一线互联网企业如极兔、有赞、希音、百度、网易、滴滴的面试资格&#xff0c;遇到一几个很重要的面试题&#xff1a; (1) 亿级用户场景&#xff0c;如何高性能统计日活&#xff1f; (2) 如何实现亿…

九、Ribbon负载均衡

目录 一、Ribbon负载均衡策略&#xff08;常用7种&#xff09;&#xff1a; 详细介绍&#xff1a; 1、轮询策略&#xff1a; RoundRibbonRule&#xff08;Ribbon默认策略&#xff09; 2、重试策略&#xff1a;RetryRule 3、加权响应时间策略&#xff1a;WeightedResponseT…

【模拟电子技术】常用半导体器件——本征半导体

&#x1f347;&#x1f347;只有强大的意志&#xff0c;才能成就最艰难的选择。 ——CSDN厉昱辰 目录 &#x1f34d;&#x1f34d;一、半导体 &#x1f34d;&#x1f34d;二、本征半导体的晶体结构 &#x1f34d;&#x1f34d; 三、本征半导体中的两种载流子 &#x1f34d…

数字图像处理基础知识(自救指南)

概念 本部分多来自课件&#xff0c;见水印 数字图像处理的目的 提高图像的视感质量&#xff0c;以达到赏心悦目的目的。提取图像中所包含的某些特征或特殊信息&#xff0c;主要用于计算机分析&#xff0c;经常用作模式识别、计算机视觉的预处理。对图像数据进行变换、编码和压…

炫云为什么要采用让人看不懂的GHZ计费?

很多人看到炫云GHZ计费都表示看不懂&#xff0c;觉得麻烦&#xff0c;没有按核数、按线程或者按分钟计费简单易懂&#xff0c;甚至还被某些同行经常拿来攻击。哪为什么炫云还坚持用GHZ计费呢&#xff1f;哪是因为使用GHZ计费更加公平、透明&#xff0c;且具有硬件无关性。今天就…

10个适合Web开发的最佳CSS生成器工具

在写CSS的时候&#xff0c;我们可以手写CSS&#xff0c;也可以直接使用一些CSS生成器来完成&#xff0c;今天我就跟大家分享10个好用的CSS生成器工具&#xff0c;帮助你提升工作效率。 1.纯CSS条纹生成器 网址&#xff1a;https://stripesgenerator.com 没有 Flash&#xff0…

QT多线程基础

文章目录 前言一、多线程概念介绍二、创建一个线程三、start和terminate函数四、如何不使用terminate函数终止线程总结 前言 本篇文章来讲解一下QT中的多线程使用方法。 其实线程这个概念对于我们来说并不陌生&#xff0c;main函数在多线程中一般就被称为主线程。 在QT中&am…

《计算机网络—自顶向下方法》 第四章Wireshark实验:TCP 协议分析

在因特网协议族&#xff08;Internet Protocol Suite&#xff09;中&#xff0c;TCP 层是位于 IP 层之上&#xff0c;应用层之下的中间层。不同主机的应用层之间经常需要可靠的、像管道一样的连接&#xff0c;但是 IP 层不提供这样的流机制&#xff0c;而是提供不可靠的包交换。…

Ordinal 是什么? BTC NFT 解释

Ordinal NFT 于 2023 年 1 月 20 日由开发者 Casey Rodarmor 在 BTC 主网上推出&#xff0c;它是在 BTC上 创建 NFT 的最新方式。虽然 BTC 上的 NFT 并不是一个新概念&#xff0c;BTC 之上的第 2 层网络&#xff08;例如 Counterparty 和 Stacks&#xff09;已经支持基于 BTC 的…

第七届中华梦乡·福清石竹山梦文化节举办

第七届中华梦乡福清石竹山梦文化节现场 5月9日至12日&#xff0c;第七届中华梦乡福清石竹山梦文化节暨海峡两岸&#xff08;福清&#xff09;道教论坛在福州福清举办。本届梦文化节以“福佑中华 梦圆石竹”为主题&#xff0c;旨在发挥海峡两岸道教界同根同源、联系密切的独特优…

【Java零基础入门篇】第 ⑤ 期 - 抽象类和接口(二)

博主&#xff1a;命运之光 专栏&#xff1a;Java零基础入门 学习目标 1.了解什么是抽象类&#xff0c;什么是接口&#xff1b; 2.掌握抽象类和接口的定义方法&#xff1b; 3.理解接口和抽象类的使用场景&#xff1b; 4.掌握多态的含义和用法&#xff1b; 5.掌握内部类的定义方法…

【HBase】介绍

文章目录 什么时候用Hbase&#xff1f;常见应用场景逻辑结构物理结构数据模型Name Space TableRowColumnTime StampCell 存储设计HLogHFileHfile生成方式 Apache HBase™ 是以 hdfs 为数据存储的&#xff0c;一种分布式、可扩展的 NoSQL 数据库。 Bigtable 是一个稀疏的、分布式…

5项目五:W1R3S-1(思路为主!)

特别注明&#xff1a;本文章只用于学习交流&#xff0c;不可用来从事违法犯罪活动&#xff0c;如使用者用来从事违法犯罪行为&#xff0c;一切与作者无关。 目录 前言 一、信息收集 二、网页信息的收集 三、提权 总结 前言 思路清晰&#xff1a; 1.信息收集&#xff0c;…

《程序员面试金典(第6版)》面试题 16.19. 水域大小(深度优先搜索,类似棋盘类问题,八皇后的简化版本,C++)

题目描述 你有一个用于表示一片土地的整数矩阵land&#xff0c;该矩阵中每个点的值代表对应地点的海拔高度。若值为0则表示水域。由垂直、水平或对角连接的水域为池塘。池塘的大小是指相连接的水域的个数。编写一个方法来计算矩阵中所有池塘的大小&#xff0c;返回值需要从小到…

【数据结构与算法】图的遍历与拓扑排序

文章目录 一、用数组模拟邻接表二、图的深度优先遍历&#xff08;dfs&#xff09;2.1 概念2.2 例题&#xff1a;树的重心 三、图的广度优先遍历&#xff08;bfs&#xff09;3.1 概念3.2 例题&#xff1a;图中点的层次 四、拓扑排序4.1 概念4.2 例题&#xff1a;有向图的拓扑序列…