Git关联远程仓库

article/2025/9/28 18:29:31

前面我们介绍的所有操作都是在本地仓库完成的,本文我们主要来看看如何和远程仓库进行交互,为了方便起见,这里远程仓库我们选择GitHub。

本文是Git系列的第五篇,了解前面的文章有助于更好的理解本文:


1.Git概述
2.Git基本操作
3.Git中的各种后悔药
4.Git分支管理


配置SSH KEY

SSH KEY的配置不是必须的,不配置的话我们就只能使用HTTPS协议,这样每次提交时要输入用户名密码,略麻烦,所以还是配置一下。配置SSH KEY的原理很简单,采用非对称加密方式生成公钥和私钥,公钥告诉GitHub,私钥留在自己电脑上(私钥不可泄露),当我们向GitHub上提交数据时,GitHub会用我们留给它的公钥加密一段消息返回给我们的电脑,如果我们能够用私钥解密成功,说明是合法的用户,这样就避免我们输入用户名密码了。大致的原理就是这样,现在很多免登录的系统都采用了这种方式,比如Hadoop免登录配置也是这样。那我们就来看看这个SSH KEY要怎么生成。  

1.查看本地是否已有SSHKEY

查看当前用户目录下是否有.ssh文件,如下:

图片描述

如果查看之后有结果,则直接跳转到第四步,什么都没有就继续生成。

2.生成SSH指纹

生成SSH指纹的命令很简单,如下:

ssh-keygen -t rsa -b 4096 -C "你的邮箱地址"

注意邮箱地址要替换。

3.添加ssh到ssh-agent中

执行如下命令即可:

eval "$(ssh-agent -s)"

OK,做好这一切之后,我们当前用户目录下已经有了一个名为.ssh的隐藏文件夹了,打开这个目录,会发现有一个名为id_rsa.pub的文件,这就是我们一会要使用的公钥文件。

4.将公钥告诉GitHub

登录GitHub,点击右上角的向下的箭头,选择Settings,在新打开的页面中左边侧栏选择SSH and GPG keys,如下:

图片描述

完了之后点击最下面的Add SSH key按钮即可,如此之后,我们的SSH KEY就配置成功了。

创建远程仓库

接下来我们在GitHub上创建一个仓库,登录成功之后,直接点击右上角绿色的New repository按钮,如下:

图片描述

其实这里我们只需要填一个版本仓库的名字,我填了test,填好之后,点击Create repository就OK了。

关联远程仓库

创建成功之后,我们会看到仓库的地址,如下:git@github.com:lenve/test.git,然后我需要将我们之前的本地仓库和这个远程仓库进行关联,使用git remote add命令,如下:

$ git remote add origin git@github.com:lenve/test.git

在这条命令中,git会自动将远程仓库的名字设置为origin,方便我们的后续操作。

推送到远程仓库

推送到master分支

假设我想将本地master分支上的内容推送到远程master分支上,方式如下:

$ git push -u origin master

-u参数可以在推送的同时,将origin 仓库的master 分支设置为本地仓库当前分支的upstream(上游)。添加了这个参数,将来运行git pull命令从远程仓库获取内容时,本地仓库的这个分支就可以直接从origin 的master 分支获取内容,省去了另外添加参数的麻烦。这个参数也只用在第一次push时加上,以后直接运行git push命令即可。

推送到其他分支

如果想推送到其他分支,还是这条命令,修改一下分支的名字即可,比如我也想把我的fa分支推送到远程仓库中,执行如下命令:

$ git checkout fa
$ git push -u origin fa

先切换到fa分支,然后执行git push命令,参数含义和之前的一样,这里我们创建的远程仓库的分支名也为fa(当然我们可以取任何名字,但是为了不混淆,最好取一致的名字)。这两条命令执行成功之后,此时在网页中我们就可以看到已经有多个分支了,如下:

图片描述

从远程仓库获取

首次获取

刚刚是我们向远程仓库提交数据,有提交当然就有获取,我们可以通过git clone命令克隆一个远程仓库到本地,方式也简单,在本地创建一个空文件夹,执行如下命令:

$ git clone git@github.com:lenve/test.git

表示克隆文件到本地仓库。此时克隆的远程仓库的master分支到本地仓库,我们可以通过git branch -a来查看本地仓库和远程仓库的信息,-a参数可以同时显示本地仓库和远程仓库的信息,如下:

图片描述

我们看到远程仓库中已经有了fa分支了,如果我们想把fa分支也克隆下来,执行如下命令:

$ git checkout -b fa origin/fa

表示根据远程仓库的fa分支创建一个本地仓库的fa分支,创建完成之后进行切换,也可以通过如下命令只创建不切换:

$ git branch fa origin/fa

此时我在fa分支下修改git01.txt文件并提交,如下:

图片描述

注意由于fa分支就是从远程仓库克隆下来的,所以这里可以不添加-u参数。

从远程仓库更新

此时我们回到第一次最早的那个test本地仓库中,那个test仓库的fa分支现在和远程仓库不一致了,我们可以通过git pull命令来更新,如下:

图片描述

Ok,关联远程仓库我们先说这么多。有问题欢迎留言讨论。

参考资料:

1.《GitHub入门与实践》
2.《Pro Git》

更多JavaEE和Git资料请关注公众号:

图片描述


http://chatgpt.dhexx.cn/article/6UIZxVEr.shtml

相关文章

【git学习】本地关联远程仓库

目录 一、本地仓库关联远程仓库(新建仓库) 二、拉取远程分支到本地(已有远程仓库) 一、本地仓库关联远程仓库(新建仓库) 本地新建工程,然后关联远程git仓库并向远程仓库提交代码。 1、本地新建…

笔录Flutter (六) 布局系列: Stack、Positioned、Align

Flutter练习demo 常用属性 关于alignment的使用 使用这些属性 直接使用Alignment(x, y) x、y两个值的范围在 -1 到 1 之间。如图: 坐标的圆点表示center,如上图所示: 使用 效果图: import package:flutter/material.dart;c…

flutter 布局 Stack Positioned的混合操作 两个组件Container重叠 构建背景圆角操作 类似css的relative

flutter 布局 Stack Positioned的混合操作 两个组件Container重叠 构建背景圆角操作 首先看一下需求 需要在这里加一个背景圆角,涉及到两个组件Container的重叠 我们使用Stack Positioned的混合操作 类似于css汇中的relative属性,而且我接下来使用的操作…

Flutter布局组件之层叠组件Stack和Positioned

层叠布局 Stack、Positioned 层叠布局和Web中的绝对定位、Android中的Frame布局是相似的,子组件可以根据距父容器四个角的位置来确定自身的位置。绝对定位允许子组件堆叠起来(按照代码中声明的顺序)。Flutter中使用Stack和Positioned这两个组…

Flutter开发之——多组件布局容器-Stack和IndexedStack及Positioned

一 概述 Stack组件时Flutter中用来进行绝对布局的一个容器组件(Stack组件可以将子组件叠加显示,根据子组件的顺利依次向上叠加)IndexedStack是Stack的子类,Stack是将所有的子组件叠加显示,而IndexedStack只显示指定的子组件Positioned组件通…

Flutter 层叠布局 Stack、Positioned

层叠布局和Web中的绝对定位、Android中的Frame布局是相似的,子组件可以根据距父容器四个角的位置来确定自身的位置。绝对定位允许子组件堆叠起来(按照代码中声明的顺序)。Flutter中使用Stack和Positioned这两个组件来配合实现绝对定位。Stack…

Flutter 多子 Widget 布之Stack、Positioned

文章目录 层叠 Widget 布局Stackalignmentfitoverflow Positioned 上文 Flutter 多子 Widget 布局之Flex、Expanded、Wrap、Flow,介绍了弹性布局 Flex、Expanded和流式布局Wrap、Flow再上文 Flutter 多子 Widget 布局之线性布局 Row、Column,介绍了线性布…

【Flutter从入门到实战】 ⑧、FlexWidget、Flex的主轴和交叉轴、Row和Column的使用、Expanded的FlexFit和flex的使用、Stack、Positioned的使用

Flutter从入门到实战 一共分为23个系列 ①(Flutter、Dart环境搭建篇) 共3个内容 已更新 ②(Dart语法1 篇) 共4个内容 已更新 ③(Dart语法2 篇) 共2个内容 已更新 ④(Flutter案例开发篇) 共4个内容 已更新 ⑤(Flutter的StatelessWidget 共3个内容 已更新 ⑥(Flutter的基础Widge…

Flutter入门学习--(16)布局定位控件Positioned

Positioned控件主要用来设置绝对布局,必须配合Stack控件来使用, Positioned控件 通过设置left和top属性可以设置控件的绝对位置 import package:flutter/material.dart;void main() > runApp(MyApp());class MyApp extends StatelessWidget {overrid…

Flutter 中 Positioned、Align、Center 的使用详解 _ Flutter Widgets

), Positioned( 《Android学习笔记总结+最新移动架构视频+大厂安卓面试真题+项目实战源码讲义》 【docs.qq.com/doc/DSkNLaERkbnFoS0ZF】 完整内容开源分享 top: 10, child: getItem(‘top 10’), ), Positioned( bottom: 10, child: getItem(‘bottom 10’), ), Positioned( h…

12、 Flutter Widgets 之 Stack,Positioned叠加组件

Stack/Positioned是用来做页面布局定位的组件,需要结合使用 Stack children:一个数组,里面可放多个Widgetalignment:Alignment.topCenter//对齐方式,会对所有的子组件统一设置对齐,不灵活,一般不用 Positioned child:一…

Flutter层叠布局 Stack、Positioned

Flutter中使用Stack和Positioned这两个组件来配合实现绝对定位。Stack允许子组件堆叠,而Positioned用于根据Stack的四个角来确定子组件的位置。 Stack alignment: 此参数决定如何去对齐没有定位(没有使用Positioned)或部分定位…

Flutter之层叠布局Stack、Positioned

Flutter中使用Stack和Positioned这两个组件来配合实现绝对定位。Stack允许子组件堆叠,而Positioned用于根据Stack的四个角来确定子组件的位置。 一.属性列表 Stack Stack({this.alignment AlignmentDirectional.topStart, this.textDirection,this.fit StackFi…

Flutter组件--重叠布局/相对布局(Stack,Positioned组件)

1.Flutter Stack组件 Stack表示堆的意思,我们可以用Stack或者Stack结合Align或者Stack结合 Positiond来实现页面的定位布局 属性 说明 alignment 配置所有子元素的显示位置 children 子组件 只使用Stack组件的情况下,所有的组件都是重叠在一起的,具体见下: …

Flutter——最详细(Positioned)使用教程

Positioned简介 创建一个小组件,用于控制 [Stack] 的子项的位置。 使用场景: 可以通过坐标的形式来摆放控件的位置,堆叠布局时可以使用; 属性作用width宽度height高度top顶bottom底left左right右 注意事项: 1.如果设置…

【Flutter组件】层叠布局 Stack、Positioned

层叠布局(Stack)和 Web 中的绝对定位、Android 中的 FrameLayout 布局是相似的,子组件可以根据距父容器四个角的位置来确定自身的位置。层叠布局允许子组件按照代码中声明的顺序堆叠起来。Flutter中使用Stack和Positioned这两个组件来配合实现绝对定位。Stack允许子…

【Flutter】Flutter 布局组件 ( FractionallySizedBox 组件 | Stack 布局组件 | Positioned 组件 )

文章目录 一、FractionallySizedBox 组件二、Stack 布局组件三、Positioned 组件四、 完整代码示例五、 相关资源 一、FractionallySizedBox 组件 FractionallySizedBox 组件 : 可控制组件在水平/垂直方向上填充满父容器 ; class FractionallySizedBox extends SingleChildRen…

Flutter实战Stack与Positioned使用详解

目录 Stack Positioned 小案例 Stack Stack({Key key,this.alignment AlignmentDirectional.topStart,//未指定区域的排布方式this.textDirection,this.fit StackFit.loose,//没有定位的子组件如何去适应Stack的大小this.overflow Overflow.clip,this.clipBehavior Clip…

Flutter基础学习 13-19 Stack的Positioned属性

前边已经介绍了Stack组件,并且进行了两个组件的层叠布局,但是如果是超过两个组件的层叠该如何进行定位那?这就是我们加今天要学的主角Positioned组件了,这个组件也叫做层叠定位组件。 知识点: Positioned组件的属性&#xff1a…

《Flutter 控件大全》第六十八个:Positioned

如果你对Flutter还有疑问或者技术方面的疑惑,欢迎加入Flutter交流群(微信:laomengit)。同时也欢迎关注我的Flutter公众号【老孟程序员】,公众号首发Flutter的相关内容。Flutter地址:http://laomengit.com 里面包含160多个组件的详细用法。Positioned用于定位Stack子组件,…