ssh跳转设置
SSH工具的非常规使用
说明:本文所有的命令是基于OpenSSH客户端7.4p1版本。如果出现命令不正确,请检测是否为此OpenSSH版本。
设置动态代理
工作中经常会遇到使用ssh远程帮客户调试安装,但是在调试安装过程中,有时需要浏览器去访问HTTP服务,这时可以用ssh -D方式在本地启用一个socks5的代理:
#加上-Nf参数可以将此连接放到后台
ssh -D 2080 root@1.1.1.1 -N -f
连接成功后,再配置浏览器使用socks5://127.0.0.1:2080的代理,即可访问远程内网的HTTP服务。
SSH隧道连接
将远程服务器端口映射到本地内网
ssh隧道可以实现将远程服务器的某个端口,映射到本地PC上。
比如这样一个场景:公网服务器上有个MySQL数据库服务,它只监听127.0.0.1:3306。我有远程服务器C的ssh访问权限,而同事B没有该服务器的ssh权限,但是同事此时需要连接此数据库,我就可以用下面命令将远程的3306端口映射到我本地PC的19999端口。
内网同事B: 192.168.0.6 ---> 内网的我A: 192.168.0.5 ---> 公网服务器C: 1.1.1.1
#在内网A机器上执行下面命令
ssh -L 0.0.0.0:19999:127.0.0.1:3389 root@1.1.1.1 -N -f
这样同事只需要用mysql命令连接192.168.0.5:19999即可。
将本地内网端口映射到远程服务器
ssh隧道除了上面的将远程服务器端口映射到本地,还可以将本地内网的端口映射到远程服务器上。
常用场景:公司内网有个演示产品应用,需要给客户(B)访问此服务器(A)的80端口。但是此服务器没有公网IP,也没有做端口映射,此服务器只有访问公网的权限,我们只有一个生产的服务器(C)在公网。
客户内网B: 192.168.0.6 ---> 公网生产服务器C: 1.1.1.1 ---> 内网服务器C: 192.168.3.100
#在内网服务器C上执行下面命令
ssh -f -N -R 19999:localhost:80 root@1.1.1.1
客户直接访问http://1.1.1.1:19999即可
注意:上面公网服务器
1.1.1.1需要开启sshd_config配置内的一个参数,GatewayPorts yes。如果不开启此参数,默认创建的监听地址是127.0.0.1,开启此参数后监听地址为0.0.0.0。
使用ssh-agent
ssh-agent可以将本地的私钥文件保存到ssh会话里面,这样远程连到服务器B上,就可以将个人的私钥文件也带入过去。
常用场景:一个git仓库添加了我个人的公钥证书,我有权限用git的ssh协议去pull和push。但是我临时需要部署服务器B,而又不想在git仓库添加此服务器的公钥。这时即可通过使用ssh-agent转发本地的私钥到远端服务器上。
#启动ssh-agent
eval $(ssh-agent -s)
#添加本地私钥文件(若不加私钥路径,则使用默认私钥路径)
ssh-add ~/.ssh/id_rsa
#验证是否正确添加key,正确情况会列出你的公钥信息
ssh-add -L
上面是启用ssh-agent,下面还需要修改ssh_config配置文件,开启ForwardAgent yes。
#此处是全局启用ForwardAgent参数
Host *
User root
ForwardAgent yes
开启后,ssh root@1.1.1.1远程连接到远程服务器,然后用ssh-add -L在远程服务器上也可以看的你的公钥信息,这样再使用ssh协议的git clone就可以正常使用了。当然也可以再用自己的私钥,通过ssh访问其他有权限登录的服务器。
设置跳板机
生产环境中,有许多服务器没有开启公网的SSH访问,只能通过一个跳板机登录到生产内网,然后再访问生产服务器。这时候在使用scp进行文件传输、以及用ssh登录等操作很不方便。
方法一、修改ssh_config配置文件
OpenSSH 7.3版本以上的可以用下面配置:
#内网服务器端,也可写死为单个ip
Host 192.168.0.*
User root
#跳板机用户为:test,IP地址为:1.1.1.1,端口为:22022
ProxyJump test@1.1.1.1:22022
OpenSSH 7.3版本以下的用下面配置:
#内网服务器端,也可写死为单个ip
Host 192.168.0.*
User root
#跳板机用户为:test,IP地址为:1.1.1.1,端口为:22022
ProxyCommand ssh -p 22022 test@1.1.1.1 -W %h:%p
方法二、直接用命令
除了修改配置文件,还可以直接用命令实现,下面先说下7.3版本以上,支持ProxyJump的版本:
#跳板机用户为:test,IP地址为:1.1.1.1,端口为:22022,内网服务器为192.168.0.100
ssh -J test@1.1.1.1:22022 root@192.168.0.100
7.3以下版本
#跳板机用户为:test,IP地址为:1.1.1.1,端口为:22022,内网服务器为192.168.0.100
ssh -o ProxyCommand="ssh -p 22022 test@1.1.1.1 -W %h:%p" root@192.168.0.100
提示:以上跳板机配置也同样适用于基于ssh协议的工具,比如
ansible和git。
ssh跳转设置的更多相关文章
- 【原创】大叔问题定位分享(28)openssh升级到7.4之后ssh跳转异常
服务器集群之间忽然ssh跳转不通 # ssh 192.168.0.1The authenticity of host '192.168.0.1 (192.168.0.1)' can't be esta ...
- ssh无密码登录设置方法以及出现问题 ECDSA host key 和IP地址对应的key不同的解决
最近在做hadoop,因为要求各主机之间的用户必须相同,且为方便远程登录,需配置无密码登录 先附上ssh无密码登录设置方法: 先生成密钥并配置无ssh无密码登录本机,输入命令: ssh-keygen ...
- SSH远程连接时间设置
SSH远程连接时间设置步骤: 1.回到根目录:cd // 2.进入ssh目录:cd etc/ssh 3.编辑sshd_config文件:vi sshd_config 4.按 i 进入编辑状态 5.找到 ...
- iOS APP跳转设置界面以及设置中的其他界面
1.跳转设置总页面(iOS10+以及之前的都可以用:ios10+ 是跳转到了应用到设置界面) [[UIApplication sharedApplication]openURL:[NSURL URLW ...
- 思科ASA5520防火墙telnet、SSH及DHCP设置
ASA5520远程登录telnet 注:最低安全级别的接口不支持telnet登陆,如OutsideASA(config)# telnet 172.16.0.0 255.255.0.0 inside ...
- ios 判断用户是否开启权限---并跳转设置
ios 判断用户是否开启权限---并跳转设置 ios 判断用户是否开启权限---并跳转“系统设置” 1.判断 访问相册 或 相机 权限是否开启 2.检测是否开启定位 后面将持续更新 只有在应用请求过位 ...
- 小程序使用微信地址or小程序跳转设置页
如果你有使用过小程序需要你授权微信地址的情况,那么正常的逻辑应该是这样的: 点击获取地址后,弹窗: 此时我相信选择拒绝的人应该还是比较多的,毕竟这是敏感数据,拒绝后再看页面相关功能是否有使用地址的合适 ...
- 普通用户ssh无密码登录设置
这段时间在做Hadoop的环境配置,用root用户只需要按照一定的步骤进行操作就可以直接实现无密码登录,但如果使用新建用户,怎么尝试都不行. 本帖大部分都是其他人帖子的内容.如果按照下面的步骤还是不能 ...
- ssh无密码通信设置
■单向登陆配置:1.在本地机器中的~/.ssh/目录下执行下命令#ssh-keygen -t dsa然后全部回车,采用默认值.生成了一对密钥,id_dsa和id_dsa.pub,存放在用户目录的~/. ...
随机推荐
- C++ 友元 (全局函数做友元) (类做友元) (成员函数做友元)
1 //友元 全局函数做友元 2 /* 3 #include <iostream> 4 #include <string> 5 using namespace std; 6 7 ...
- Redisson实战-BloomFilter
1. 简介 布隆过滤器是防止缓存穿透的方案之一.布隆过滤器主要是解决大规模数据下不需要精确过滤的业务场景,如检查垃圾邮件地址,爬虫URL地址去重, 解决缓存穿透问题等. 布隆过滤器:在一个存在一定数量 ...
- Linux平台上转换文件编码
Linux系统的iconv指令是一个很好的文件编码转换工具,支持的编码范围广,使用方便,例如将一个utf-8编码的文件(名为tic)转换为gbk编码: iconv -f utf-8 -t gbk ti ...
- Vue-cli4 唤醒摄像头扫描二维码
<template> <div class="scan"> <div id="bcid"> <div id=" ...
- Python 应用爬虫下载酷狗音乐
应用爬虫下载酷狗音乐 首先我们需要进入到这个界面 想要爬取这些歌曲链接,然而这个是一个假的网站,虽然单机右键进行检查能看到这些歌曲的链接,可进行爬取时,却爬取不到这些信息. 这个时候我们就应该换一种思 ...
- 一篇文章让你搞懂如何通过Nginx来解决跨域问题
Nginx跨域实现 首先大家要搞清楚什么是跨域,为什么会有跨域情况的出现.哪些情况属于跨域? 跨域:由于浏览器的同源策略,即属于不同域的页面之间不能相互访问各自的页面内容 注:同源策略,单说来就是 ...
- SQL 练习26
查询 1990 年出生的学生名单 --方式1 SELECT * FROM Student WHERE Sage BETWEEN '1990-01-01' AND '1990-12-31' --方式2 ...
- CMD下编译运行Java程序
准备1:JDK下好了 准备2:环境变量配置好了 准备3:本次测试用的是JDK8,用JDK10的在Eclipse里面好像用不了 满足上面三个条件,那可以继续看下去了 Test_1:带包编译运行 代码: ...
- ffmpeg第2篇:简单滤镜与复杂滤镜的区别
在ffmpeg的滤镜中,有简单滤镜(simple filter)和复杂滤镜(complex filter)两种. 使用简单滤镜时,用-vf选项,使用复杂滤镜时,使用-filter_complex或-l ...
- tomcat9配置https-pfx
下载tomcat9 wget https://mirrors.bfsu.edu.cn/apache/tomcat/tomcat-9/v9.0.37/bin/apache-tomcat-9.0.37.t ...