首页 > 其他分享 >ngnix代理grpc

ngnix代理grpc

时间:2022-11-15 18:36:23浏览次数:75  
标签:http ssl Nginx grpc ngnix 代理 明文 gRPC

原文 http://www.1000zx.cn/it/13525.html

Nginx 1.13.10新增了对gRPC的原生支持。本文介绍如何配置Nginx的gRPC。

安装Nginx

Nginx版本要求:1.13.10。

gRPC必须使用HTTP/2传输数据,支持明文和TLS加密数据,支持流数据的交互。这是为了充分利用 HTTP/2 连接的多路复用和流式特性。所以在安装部署nginx时需要安装http/2。使用源码安装,编译时需要加入http_ssl和http_v2模块:

$ auto/configure --with-http_ssl_module --with-http_v2_module
Nginx以明文的方式发布gRPC服务。

nginx是使用http服务器监听gRPC的请求。

示例:

http {
server {
listen 80 http2;

access_log logs/access.log main;

location / {

The 'grpc://' prefix is optional; unencrypted gRPC is the default

grpc_pass grpc://localhost:50051;
}
}
}

指令grpc_pass用来指定代理的gRPC服务器地址,前缀协议有两种:

grpc://:与gRPC服务器端交互是以明文的方式
grpcs://:与gRPC服务器端交互式以TLS加密方式
gRPC服务器地址的前缀“grpc://”是可以忽略,默认就是明文交互方式。

此示例里nginx以明文的方式在80端口发布gRPC,其中代理的gRPC在后端也是以明文的方式交互。

注意:Nginx是不支持在明文的端口上同时支持http1和http2的。如果要支持这两种的http协议,需要设置为不同的端口。

Nginx以TLS加密方式公开gRPC服务

在生成环境建议使用Nginx是以加密的方式发布gRPC。这种情景需要在Nginx添加一个加密层。

在开发/测试环境可以使用自签名证书,关于自签名证书可以参考此简明教程。
配置示例:

server {
listen 1443 ssl http2;

ssl_certificate ssl/cert.pem;
ssl_certificate_key ssl/key.pem;

location / {
grpc_pass grpc://localhost:50051;
}
}

示例里在nginx层给gRPC服务对外添加了ssl,而内部代理到gRPC服务器仍然是使用明文的交互方式。

gRPC客户端也是需要TLS加密。如果是使用自签名证书等未经信任的证书,客户端都需要禁用证书检查。在部署到生产环境时,需要将自签名证书换成由可信任证书机构发布的证书,客户端也需要配置成信任该证书。

代理加密的gRPC

如果Nginx内部代理的gRPC也需要以加密的方式交互,这种情况就需要把明文代理协议grpc://替换为grpcs://。这首先要gRPC服务器是以加密的方式发布服务的。

nginx层修改如下:

grpc_pass grpcs://localhost:50051;
nginx路由gRPC请求

如果后端有多个gRPC服务端,其中每个服务端都是提供不同的gRPC服务。这种情况可以使用一个nginx接收客户端请求,然后根据不同的路径分发路由到指定的gRPC服务器。使用location区分:

location /helloworld.Greeter {
grpc_pass grpc://192.168.20.11:50051;
}

location /helloworld.Dispatcher {
grpc_pass grpc://192.168.20.21:50052;
}

location / {
root html;
index index.html index.htm;
}

对gRPC请求做负载均衡

在后端有多个gRPC服务器,它们都是同一个gRPC服务,这种情况可以结合nginx的upstream可以对gRPC的请求做负载均衡。

upstream grpcservers {
server 192.168.20.21:50051;
server 192.168.20.22:50052;
}

server {
listen 1443 ssl http2;

ssl_certificate ssl/certificate.pem;
ssl_certificate_key ssl/key.pem;

location /helloworld.Greeter {
grpc_pass grpc://grpcservers;
error_page 502 = /error502grpc;
}

location = /error502grpc {
internal;
default_type application/grpc;
add_header grpc-status 14;
add_header grpc-message "unavailable";
return 204;
}
}

其中upstream指定定义了统一gRPC服务的服务器组。在grpc_pass指定的gRPC服务器地址使用upstream定义的服务器组。

标签:http,ssl,Nginx,grpc,ngnix,代理,明文,gRPC
From: https://www.cnblogs.com/wang2650/p/16893445.html

相关文章

  • 根据继承接口批量注入GRPC客户端
    ///<summary>///作用域批量注入grpc数据///</summary>///<typeparamname="IGrpcDependency">根据泛型获取需要注入的grpc接口<......
  • 提取HTTP代理时提示“该参数条件下没有任何IP”
    很多人在提取HTTP代理时经常会遇到这样的提示:“该参数条件下当前没有任何HTTP代理”,这是为什么呢?我们一起来分析下。1、核实参数条件生成提取链接的时候,会设置......
  • 什么是http代理的有效时长
    人们常常被问到HTTP代理可以使用多久,还有人说HTTP代理是怎么运行的,今天我们就来分析一下,一个HTTP代理可以使用多久,有什么影响因素。1、动态HTTP代理的有效期,目前市......
  • HTTP代理API是什么
    经常上网的朋友可能听说过IP代理,但是它的实际功能很多人并不清楚。将其扩展到这里。当前大部分网络活动中,http是一种比较常见的网络协议,所以http代理也是普遍采用的代......
  • 云服务器搭建http代理有什么好处
    1、安全过滤,安全性方面,不允许用户直接访问真实服务器。任何访问请求都要先到达代理服务器,代理服务器进行验证、过滤等安全类操作,合格请求才会被转发到真正的服务器......
  • 为什么我的HTTP代理用着用着就变慢了
    在日常生活中当我们想用一个IP的时候,代理ip是很常见的。但是,很多用户在购买HTTP代理使用的过程中,发现刚开始速度很快,用着用着就变慢了,影响了工作效率,这是为什么呢?......
  • 移动HTTP代理有什么优点
    很多的网络用户都会使用换ip,那么HTTP代理在这当中有什么优点?IP我们都不陌生,一台电脑只有一个IP来确定电脑的位置。想换IP也是可以的,就是用换IP的软件,那就是ip代理......
  • JDK 动态代理
    Factoryclass文件publicclassProxyFactory{ privateObjecttarget; publicProxyFactory(Objecttarget){ super(); this.target=target; } /**......
  • cglib 动态代理
    Factoryclass文件publicclassProxyFactory{ privateObjecttarget; publicProxyFactory(Objecttarget){ super(); this.target=target; } /*......
  • vue源码分析-基础的数据代理检测
    简单回顾一下这个系列的前两节,前两节花了大量的篇幅介绍了Vue的选项合并,选项合并是Vue实例初始化的开始,Vue为开发者提供了丰富的选项配置,而每个选项都严格规定了合并的策......