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

Git 使用SSH登陆

一、SSH介绍

         SSH连接相比于HTTP连接会简单一点,因为SSH连接通过了私钥与公钥进行身份认证,这样就不需要像HTTP一样,每次clone或者操作仓库都需要输入密码

        其中私钥和密钥是需要在自己电脑上生成的,通过命令即可生成一个私钥和一个密钥,这两个是成对出现的,一般会生成在你电脑C盘的用户目录下,有一个.ssh文件夹,如果看不到这个文件夹,打开文件管理器的显示隐藏文件功能,一般里边会有两个文件,一个是公钥,一个是私钥,后缀带.pub的是公钥

        公钥需要放到远端服务器的,私钥一般就保存在电脑上即可,不要泄露给别人。

        如果你要操作的仓库没有公钥,你是不能对这个仓库进行操作的,必须把你生成的公钥添加进去,下面会讲如何操作。

二、本地创建SSH密钥

        1、先在本地打开git bash,然后输入如下命令按三次回车,命令里的邮箱就写你远端仓库的邮箱即可

ssh-keygen -t rsa -C "远端仓库邮箱"

        2、 按完三次回车后,即可进入C盘用户目录,找到.ssh文件夹,打开里边后缀为.pub的文件,复制里边内容

        3、打开远端仓库,这里以gitee为例,登陆后点击右上角,找到账号设置,进入设置后找到SSH公钥,把刚才复制的粘贴进去,点击确定,就完成了公钥添加。

        注意:远端仓库分为仓库密钥和个人密钥,仓库密钥只能克隆和拉取仓库,不能推送仓库,也就是不能对仓库进行修改,而个人密钥是可以对仓库进行推送的。

        如果设置的是仓库密钥,在推送的时候会提示权限不够。

        4、测试SSH登陆,打开Git bash,输入如下命令测试,中间会让输入一次yes,如果SSH密钥设置成功,即可看到会输出You've successfully authenticated字样。

ssh -T git@gitee.com

三、通过SSH克隆仓库

3.1 本地没有仓库

        1、找到一个工作空间,最好在一个空文件夹下,然后打开Git bash,输入如下命令即可克隆仓库,后面接的地址一定是SSH地址

git clone 远端SSH地址

        2、切换到需要操作的分支,一般clone下来的仓库都是有很多个分支的,使用下面命令查看所有分支,如果是新clone的仓库分支是一样的。

# 查看远端仓库所有分支
git branch -r
# 查看远本地仓库所有分支
git branch -a

        使用下面命令切换对应分支:

 git checkout 需要操作的分支名字

        如果只有一个master分支,想再创建一个新分支,使用如下命令,再哪个分支上使用checkout命令,就是基于哪个分支创建的新分支。

git checkout -b 新分支名字

        如果想删除某个分支,使用下面命令

        注意必须处于别的分支才能删除这个分支,不能再本分支删除本分支

git branch -d 要删除的分支名字

        如果想删除远端分支,可以直接再远端界面操作,也可以使用下面命令

git push origin --delete 远端要删除分支名字

3.2 本地有仓库

        1、添加远端仓库        

        如果本地有一个仓库,使用如下命令添加远端仓库

git remote add origin 远端仓库SSH地址

        2、拉取远端仓库

        使用下面命令拉取远端仓库,会把远端仓库的所有分支全部拉取下来

git pull

        如果只是想拉取远端仓库的某一个分支,使用如下命令 

git pull origin 要拉取的远端仓库分支名

        如果本地仓库是一个空仓库,使用上面命令会把拉取下来的东西放到master分支,如果想跟远端仓库名字一样。需要使用如下命令,这里本

git push origin bee本地分支名字:远端仓库分支名字

地分支名字也写成远端分支名字,为后面上传减少麻烦

git pull origin 远端分支名字:本地分支名字

        注意:如果你本地是一个空仓库,拉取某一个仓库后,你的分支名就是master,而不是你远端仓库的分支名,这个后面推送的时候可能推送不上去,后面会讲

        空仓库的master分支实际是不存在的,也不能上来直接使用 git branch命令创建新分支,但是可以使用git checkout -b 命令直接创建新分支,其实页没有创建新分支,只是把默认的master改为了你写的分支名字

        但是如果你本地已经有分支了,就不会出现这种情况,只需要拉取完仓库后,切换到对应的分支即可,然后再操作,或者在对应分支的基础上再创建新的分支

        3、推送仓库

        使用如下命令即可把本地仓库推动到远端仓库

        如果当前分支是新创建的分支,就会在云端上传一个新的分支

git push origin 远端仓库分支名字

        注意:如果前面说的,你本地分支名字跟远端仓库分支名字不同,就需要使用如下命令

git push origin 本地分支名字:远端仓库分支名字

        4、合并分支

        首先需要切换到你要合并的分支,然后使用如下命令合并

git merge 要合并到当前分支的分支名字

相关文章:

  • 工厂方法模式和抽象工厂模式详解
  • 【从零开始学习计算机科学与技术】计算机网络(六)传输层
  • 调整iptables规则,解决无法ssh连接服务器的问题
  • Linux中安装Git
  • Javascript 日期相关计算
  • halcon几何测量(二)计算距离和角度的函数
  • Linux主机持久化技术
  • 日常学习开发记录-input组件
  • 数据库设计实验(3)—— 分离与附加、还原与备份
  • 【Java面试场景题搜集总结】
  • Redis和MongoDB的区别
  • 【数学建模】熵权法
  • maven插件不能正确解析
  • 八、JavaScript函数
  • NAT技术-初级总结
  • MySQL :参数修改
  • springboot请求响应
  • 设计一个高性能的分布式限流系统
  • Redis的消息队列是怎么实现的
  • HarmonyOS开发,深拷贝、浅拷贝的封装和调用
  • 特朗普指控FBI前局长“暗示刺杀总统”,“8647”藏着什么玄机?
  • 大外交丨3天拿下数万亿美元投资,特朗普在中东做经济“加法”和政治“减法”
  • 坚决打好产业生态培育攻坚战!陈吉宁调研奉贤区
  • 外交部部长助理兼礼宾司司长洪磊接受美国新任驻华大使递交国书副本
  • 烤肉店从泔水桶内捞出肉串再烤?西安未央区市监局:停业整顿
  • 刘国中将出席第78届世界卫生大会并顺访瑞士、访问白俄罗斯