NGNIX NACOS 模块
nginx 通过订阅 nacos ip 端口, 进行反向代理。后端服务发布,不用修改 nginx 配置 和 reload 重启进程。
配置示例
基于 NGINX 1.20.2 和 NACOS 2.x 版本开发。
nacos {
server_list localhost:8848; # nacos 服务器列表,空格隔开
# 可以使用 grpc 订阅。 nacos 2.x 版本才支持,推荐使用。
grpc_server_list localhost:9848; # nacos grpc服务器列表,空格隔开。一般是 nacos 端口 + 1000
# 也可使用udp。都配置的情况下使用 udp。
#udp_port 19999; #udp 端口号
#udp_ip 127.0.0.1; #udp ip 地址。
#udp_bind 0.0.0.0:19999; # 绑定udp 地址
error_log logs/nacos.log info;
default_group DEFAULT_GROUP; # 默认的nacos group name
cache_dir cmake-build-debug/nacos/;
}
http {
upstream s {
# 如果provider使用的spring,data_id 要和 spring.application.name一致
# 不知道 provider 端怎么写请参考 https://github.com/zhwaaaaaa/springmvc-nacos-registry
use_nacos_address data_id=springmvc-nacos-demo;
}
server {
# ... other config
location ^~ / {
proxy_pass http://s;
}
}
}
编译
本项目包含 nginx 1.20 的代码。由于使用了 grpc 连接 nacos,所以需要安装 protobuf 和 protobuf-c 库。 ubuntu 下安装方式为
sudo apt install libprotobuf-dev libprotobuf-c-dev
grpc 使用的是 http2 传输,所以 nacos 模块需要和 http2 模块一起安装(ps: 可能还需提前安装 libopenssl,除非使用不加密的 http2):
./configure --add-module=modules/auxiliary --add-module=modules/nacos --with-http_ssl_module --with-http_v2_module && make
原理
- 新增加一个 auxiliary 模块, 启动一个单独辅助进程,用于订阅和接受 nacos 的 grpc 或者 udp 消息推送,不影响 worker 进程的工作。
- 收到消息推送后更新到共享内存,便于 worker 进程可以拿到最新的推送。 推送的数据也会缓存到磁盘,下次启动时候首先从磁盘读取。