git的ssh配置和使用

原创 2017年09月13日 23:56:14

一、秘钥生成

我是在Windows的gitbase里面操作的。
生成秘钥:
$ ssh-keygen -t rsa -f sample
t 为密码类型
f 为生成的秘钥文件名称
回车键后会让你输入密码,你可以不输,直接按回车到下一步。
ssh-keygen -t rsa -C “your_email@youremail.com”
有些为了方便识别,会以自己的邮箱做标记。
这个是命令输入去执行的结果:

$ ssh-keygen -t rsa -f sample
Generating public/private rsa key pair.
Enter passphrase (empty for no passphrase):
Enter same passphrase again:
Your identification has been saved in sample.
Your public key has been saved in sample.pub.
The key fingerprint is:
SHA256:d1TDf+SYS8BADB4MvGO3yXvdIy6IJsMgncOBSsO4BqE admin@DESKTOP
The key's randomart image is:
+---[RSA 2048]----+
|     ..oo+oo .o  |
|.     ..... o....|
|+o     ..   .. * |
|E+.   + .  .  + +|
|++.o . +So. .. ..|
|+.*     +. .  .  |
|.. +   . o . .   |
|    + o o o o o  |
|     +   . o.. . |
+----[SHA256]-----+

在电脑C:\Users\yourname.ssh会生成对应的私钥和公钥。外来的私钥也可以放这里。
如果你没加名称会生成默认名字:id_rsa和id_rsa.pub。id_rsa为私钥,id_rsa.pub为公钥。打开它,里面是一段字符。
在本例里会生成sample_rsa和sample.pub
$ cd ~/.ssh
进入文件夹可以查看

私钥保存在您的电脑上,公钥交添加到服务器上。
用户必须拥有与服务器公钥所配对的私钥,才能访问服务器上的代码库。
下面罗列的是ssh-keygen的各个参数的作用

usage: ssh-keygen [options]
Options:
  -A          Generate non-existent host keys for all key types.
  -a number   Number of KDF rounds for new key format or moduli primality tests.
  -B          Show bubblebabble digest of key file.
  -b bits     Number of bits in the key to create.
  -C comment  Provide new comment.
  -c          Change comment in private and public key files.
  -D pkcs11   Download public key from pkcs11 token.
  -e          Export OpenSSH to foreign format key file.
  -F hostname Find hostname in known hosts file.
  -f filename Filename of the key file.
  -G file     Generate candidates for DH-GEX moduli.
  -g          Use generic DNS resource record format.
  -H          Hash names in known_hosts file.
  -h          Generate host certificate instead of a user certificate.
  -I key_id   Key identifier to include in certificate.
  -i          Import foreign format to OpenSSH key file.
  -J number   Screen this number of moduli lines.
  -j number   Start screening moduli at specified line.
  -K checkpt  Write checkpoints to this file.
  -k          Generate a KRL file.
  -L          Print the contents of a certificate.
  -l          Show fingerprint of key file.
  -M memory   Amount of memory (MB) to use for generating DH-GEX moduli.
  -m key_fmt  Conversion format for -e/-i (PEM|PKCS8|RFC4716).
  -N phrase   Provide new passphrase.
  -n name,... User/host principal names to include in certificate
  -O option   Specify a certificate option.
  -o          Enforce new private key format.
  -P phrase   Provide old passphrase.
  -p          Change passphrase of private key file.
  -Q          Test whether key(s) are revoked in KRL.
  -q          Quiet.
  -R hostname Remove host from known_hosts file.
  -r hostname Print DNS resource record.
  -S start    Start point (hex) for generating DH-GEX moduli.
  -s ca_key   Certify keys with CA key.
  -T file     Screen candidates for DH-GEX moduli.
  -t type     Specify type of key to create.
  -u          Update KRL rather than creating a new one.
  -V from:to  Specify certificate validity interval.
  -v          Verbose.
  -W gen      Generator to use for generating DH-GEX moduli.
  -y          Read private key file and print public key.
  -Z cipher   Specify a cipher for new private key format.
  -z serial   Specify a serial number.

二、放秘钥到服务器上

1.GitHub服务器

路径:settings——SSH and GPS keys里面new一个ssh key
把对应的公钥(sample.pub)放上去(把文件里的字符复制进去)。
GitHub_ssh
这时,你已经可以用ssh获取别人的项目代码了
获取源码:
$ git clone git@github.com:username/gitproj.git

2.配置git服务器

其实就是放了一个远程仓在服务器上。
ubuntu上安装git

 sudo apt-get install git

centos上安装git

yum install -y git

创建用户git

adduser git

我这里用的是centos
进入git用户

su git

创建秘钥

 ssh-keygen -t rsa -f ~/.ssh/aliyun

私钥自行保存。

创建authorized_keys文件保存公钥

mkdir .ssh
chmod 700 ~/.ssh
touch ~/.ssh/authorized_keys
chmod 600 ~/.ssh/authorized_keys
cat ~/.ssh/aliyun.pub >> ~/.ssh/authorized_keys 

出于安全考虑,创建的git用户不允许登录shell,这可以通过编辑/etc/passwd文件完成。找到类似下面的一行:

git:x:1000:1000::/home/git:/bin/bash

改为

git:x:1000:1000::/home/git:/usr/bin/git-shell

测试

 mkdir ~/gitrepo
 cd ~/gitrepo
 git init --bare sample.git
 ##把仓库所属用户改为git
 chown -R git:git sample.git

pc端上
配置pc端的私钥,放在~/.ssh文件夹下面,如有需要可以再配置一个config文件同样放在~/.ssh文件夹下面,config文件配置见下文。

客户端验证

  git clone git@aliyun-git:gitrepo/sample.git
  cd sample
  touch a.txt
  git add a.txt
  git commit -m "init commit" 
  git push origin master

这里aliyun-get是域名,更多详细请看下面的config配置。执行到这一步基本ok了。

3.多服务器ssh

如果有多台服务器上怎么分别对应不同秘钥呢?你需要配置一个config文件在~/.ssh里面
里面写有各个服务器的配置清单。
~/.ssh/config

Host github.com
  HostName        github.com
  User            git
  IdentityFile    ~/.ssh/id_rsa_github

host aliyun-git
  port 22
  compression yes
  hostname 192.168.1.120
  user git
  identityfile ~/.ssh/aliyun
版权声明:本文为博主原创文章,未经博主允许不得转载。 举报

相关文章推荐

git-ssh 配置和使用

1、设置Git的user name和email:(如果是第一次的话) $ git config --global user.name "humingx" $ git config -...

Git配置和使用(SSH配置)

第一步:生成SSH  Key Git是分布式的代码管理工具,远程的代码管理是基于SSH的,所以要使用远程的Git则需要SSH的配置。 github的SSH配置如下: 一 、 ...

精选:深入理解 Docker 内部原理及网络配置

网络绝对是任何系统的核心,对于容器而言也是如此。Docker 作为目前最火的轻量级容器技术,有很多令人称道的功能,如 Docker 的镜像管理。然而,Docker的网络一直以来都比较薄弱,所以我们有必要深入了解Docker的网络知识,以满足更高的网络需求。

Rhel7下NFS的配置以及使用

一、NFS概述1.NFS概述NFS 是Network File System的缩写,即网络文件系统。 一种使用于分散式文件系统的协定,由Sun公司开发,于1984年向外公布。 功能是通过网络让不同...

java web项目中加入log4j

java web项目中加入log4j
  • whh743
  • whh743
  • 2016-12-12 16:44
  • 2502

Git ssh 配置及使用

闲聊这篇教程是在电脑上已经安装好git的前提之上的,要进行以下配置,请先确保你的电脑已经安装好git。以下配置步骤是在git bash里面进行配置的,可以通过 右键》 git bash here 打开...

Git SSH Key 生成步骤

Git SSH Key 生成步骤(转) it是分布式的代码管理工具,远程的代码管理是基于ssh的,所以要使用远程的git则需要ssh的配置。 github的ssh配置如下: 一 ...

git下SSH配置问题

只需要向网站提交SSH产生的公钥即可。在提交后就可以用SSH协议来下载代码。 但不论是否输入SSH的公钥,在用HTTP方式下载代码时,都需要输入对应托管平台的账号和密码。 可以多次生成公私...

GIT的使用和配置

1、什么是GIT我们在写项目的过程中,特别是多人开发的时候,写完之后要组合到一起,这样的话,我们需要把每一次组合前的代码都要备份一下,在进行组合,这样会出现非常多的文件,不太利于我们的开发,这样一个问...

Git 的使用和配置

Git 常用命令git init here – 创建本地仓库(repository),将会在文件夹下创建一个 .git 文件夹,.git 文件夹里存储了所有的版本信息、标记等内容...

Git的安装和使用

1, 首先要了解什么是Git。 简而言之,Git是一个分布式的代码版本管理工具。类似的常用工具还有SVN,CVS。 概念了解参见;http://baike.baidu.com/subvie...
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)