解决 nginx 代理 1Panel 后远程无法 ssh

解决 nginx 代理 1Panel 后远程无法 ssh

同步发布在个人笔记解决 nginx 代理 1Panel 后远程无法 ssh

问题描述

管理面板 1Panel 有 ssh 连接服务器终端的功能,在服务器本地设置好这一功能,之后我们通过 nginx 的端口转发代理 1Panel 的服务。此时我们发现通过 nginx 代理的 1Panel 日志里显示 ssh 成功了,但是终端界面一直提示 disconnected

解决方法

官方文档里对这个问题有解决方案:使用自建 Nginx 反向代理 1Panel,导致主机和容器终端均不能正常使用

在这里记录一下。

只需在代理 1Panel 的 nginx 配置文件里增加下面的配置:

bash 复制代码
location / {
    proxy_http_version 1.1;
    proxy_set_header Upgrade $http_upgrade;
    proxy_set_header Connection "upgrade";
}

即可解决。

方法解析

由于添加的是上面这三句,我怀疑 1Panel 的 ssh 功能是走的 websocket 协议, nginx 反向代理 websocket 协议时,就需要添加这三句。

那么为什么是这三句呢?每一句又分别作用于什么?

第一句proxy_http_version 1.1;是声明协议,使得下面的配置可用。

下面两句都是为了设置两个请求头 ,分别是UpgradeConnection。设置好这两个,后端的 1Panel 程序才知道要建立 websocket 连接来传输数据了。

  • Upgrade
    标识传输协议要升级/转换 ,如果是要转换为 websocket协议的话,此处的值就应该是 websocket。这个请求头代表客户端希望建立 websocket 协议进行通信, 后端的程序取到头信息后会返回101状态码(协议转换),然后就会建立 websocket 通信了。
  • Connection
    此处 Connection 头信息取值upgrade,这表明这次客户端请求是要求进行协议升级/转换 的请求。升级成什么协议呢?配合上一个配置句,是升级成websocket协议,这样请求就完全了。

最后一个疑问:为什么一旦用 nginx 代理了,就需要设置这些了呢?不代理的时候不是好好的么?

答:这是因为这些请求头都是逐跳标头 。意思就是这些标头都只能传递一层,不能透传,是逐级传递的。

当客户端直接于 1Panel 通信时,请求头能被后端接收到,所以一切正常;但是使用了 nginx 代理后,请求头就只能到 nginx 这一层,传递不到后端,我们就需要让 nginx 把请求头传递下去,形成逐层跳传,这样后端才能成功收到客户端的请求,实现协议的升级/转换。

参考Nginx反向代理websocket

相关推荐
新加坡内哥谈技术2 分钟前
Meta计划借助AI实现广告创作全自动化
运维·人工智能·自动化
zyjyyds1139 分钟前
win11系统 Docker Desktop 突然提示Docker Engine stopped解决情况之一
运维·docker·容器
Altairr9 分钟前
Docker基础(一)
运维·docker·容器·eureka
文牧之28 分钟前
PostgreSQL 的扩展pageinspect
运维·数据库·postgresql
小兔子酱#1 小时前
【Docker 01】Docker 简介
运维·docker·容器
jugt2 小时前
CentOS 7.9安装Nginx1.24.0时报 checking for LuaJIT 2.x ... not found
linux·运维·centos
hunter1273 小时前
Nginx 事件驱动理解
nginx
21号 14 小时前
9.进程间通信
linux·运维·服务器
搬码临时工9 小时前
电脑同时连接内网和外网的方法,附外网连接局域网的操作设置
运维·服务器·网络
藥瓿亭9 小时前
K8S认证|CKS题库+答案| 3. 默认网络策略
运维·ubuntu·docker·云原生·容器·kubernetes·cks