• Git使用手册:HTTPS和SSH方式的区别和使用


    在管理Git项目上,很多时候都是直接使用https url克隆到本地,当然也有有些人使用SSH url克隆到本地。这两种方式的主要区别在于:使用https url克隆对初学者来说会比较方便,复制https url然后到git Bash里面直接用clone命令克隆到本地就好了,但是每次fetch和push代码都需要输入账号和密码,这也是https方式的麻烦之处。而使用SSH url克隆却需要在克隆之前先配置和添加好SSH key,因此,如果你想要使用SSH url克隆的话,你必须是这个项目的拥有者。否则你是无法添加SSH key的,另外ssh默认是每次fetch和push代码都不需要输入账号和密码,如果你想要每次都输入账号密码才能进行fetch和push也可以另外进行设置。前面的几篇介绍Git的博客里面采用的都是https的方式作为案例,今天主要是记录如何配置使用ssh方式来提交和克隆代码。

    步骤1:检查你的电脑上是否已经生成了SSH Key
      在git bash下执行如下命令

    cd ~/.ssh ls
    这两个命令就是检查是否已经存在id_rsa.pub或id_dsa.pub文件,如果文件已经存在,那么你可以跳过步骤2,直接进入步骤3。

    步骤2:创建一个SSH Key
      在git bash下执行如下命令

    ssh-keygen -t rsa -C "你的email地址"
    代码参数含义:
    -t指定密钥类型,默认是rsa,可以省略。
    -C设置注释文字,比如邮箱。
    -f指定密钥文件存储文件名。
    以上命令省略了-f参数,因此,运行上面那条命令后会让你输入一个文件名,用于保存刚才生成的SSH key代码,如:
    Generating public/private rsa key pair.
    Enter file in which to save the key (/c/Users/you/.ssh/id_rsa): [Press enter]
    当然,你也可以不输入文件名,使用默认文件名(推荐),那么就会生成id_rsa和id_rsa.pub两个秘钥文件。
    接着又会提示你输入两次密码(该密码是你push文件的时候要输入的密码,而不是github管理者的密码),当然,你也可以不输入密码,直接按回车。那么push的时候就不需要输入密码,直接提交到Git服务器上了,如:
    Enter passphrase (empty for no passphrase):
    Enter same passphrase again:
    接下来,就会显示如下一些提示,如:
    Your identification has been saved in /c/Users/you/.ssh/id_rsa.
    Your public key has been saved in /c/Users/you/.ssh/id_rsa.pub.
    The key fingerprint is:
    01:0f:f4:3b:ca:85:d6:17:a1:7d:f0:68:9d:f0:a2:db 你的email地址
    当你在Git Bash上看到这段显示的时候,那就说明,你的SSH key已经创建成功,你只需要添加到Git服务器上的SSH key上就可以了。

    步骤3:添加SSH Key到Git服务器
      这个由于不同的Git服务器,在界面添加的区域不一样,所以不做详述,具体参照不同Git服务器自己的操作。
      经历了以上的三个步骤之后,你就可以愉快的使用SSH URL的方式来提交和克隆项目的代码了,并且不需要再频繁的输入账号密码,如果你之前已经一直使用https方式进行开发,当前想要切换成为ssh方式进行开发,只需要执行如下几步的操作即可:

    git remote rm origin git remote add origin "Git仓库的ssh格式地址" git push origin

    Git密钥生成步骤SSH Key

     

    Git是分布式的代码管理工具,远程的代码管理是基于SSH的,所以要使用远程的Git则需要SSH的配置。

    github的SSH配置如下:

    一 、设置Git的user name和email:

    $ git config --global user.name "xuhaiyan"
    $ git config --global user.email "haiyan.xu.vip@gmail.com"

    二、生成SSH密钥过程:
    1.查看是否已经有了ssh密钥:cd ~/.ssh
    如果没有密钥则不会有此文件夹,有则备份删除
    2.生存密钥:

    复制代码
    $ ssh-keygen -t rsa -C “haiyan.xu.vip@gmail.com”
    按3个回车,密码为空。
    
    
    Your identification has been saved in /home/tekkub/.ssh/id_rsa.
    Your public key has been saved in /home/tekkub/.ssh/id_rsa.pub.
    The key fingerprint is:
    ………………
    复制代码

    最后得到了两个文件:id_rsa和id_rsa.pub


    3.添加密钥到ssh:ssh-add 文件名
    需要之前输入密码。
    4.在github上添加ssh密钥,这要添加的是“id_rsa.pub”里面的公钥。

    打开https://github.com/ ,登陆xuhaiyan825,然后添加ssh。


    5.测试:ssh git@github.com

    The authenticity of host ‘github.com (207.97.227.239)’ can’t be established.
    RSA key fingerprint is 16:27:ac:a5:76:28:2d:36:63:1b:56:4d:eb:df:a6:48.
    Are you sure you want to continue connecting (yes/no)? yes
    Warning: Permanently added ‘github.com,207.97.227.239′ (RSA) to the list of known hosts.
    ERROR: Hi tekkub! You’ve successfully authenticated, but GitHub does not provide shell access
    Connection to github.com closed.

    三、 开始使用github
    1.获取源码:

    $ git clone git@github.com:billyanyteen/github-services.git

    2.这样你的机器上就有一个repo了。
    3.git于svn所不同的是git是分布式的,没有服务器概念。所有的人的机器上都有一个repo,每次提交都是给自己机器的repo
    仓库初始化:

    git init

    生成快照并存入项目索引:

    git add

    文件,还有git rm,git mv等等…
    项目索引提交:

    git commit

    4.协作编程:
    将本地repo于远程的origin的repo合并,
    推送本地更新到远程:

    git push origin master

    更新远程更新到本地:

    git pull origin master

    补充:
    添加远端repo:

    $ git remote add upstream git://github.com/pjhyett/github-services.git

    重命名远端repo:

    $ git://github.com/pjhyett/github-services.git为“upstream”
  • 相关阅读:
    [OI学习笔记]排列组合&二项式定理
    [OI学习笔记]拓补排序
    [OI学习笔记]DAG最短路的四种算法整理-floyd,Dijkstra,Bellman-Ford,SPFA
    [OI学习笔记]从蒟蒻的角度理解动态规划(DP)——从暴力搜索到动态规划
    [OI学习笔记]最小生成树之Kruskal算法
    [OI学习笔记]最小生成树之Prim算法
    [OI学习笔记]图的存储与遍历-邻接矩阵&邻接表
    将数组中第n个元素,放到第m个元素后面
    Unity3D中播放序列帧动画
    UVA1589 Xiangqi
  • 原文地址:https://www.cnblogs.com/jiliunyongjin/p/8483545.html
Copyright © 2020-2023  润新知