Nginx stream 配置代理(Nginx TCP/UDP 负载均衡)

yizhihongxing

Nginx 服务器强大的功能和性能,是众多网站运维人员所喜爱的,其中也不乏用作代理服务器等用途。接下来,将为大家详细讲解如何在 Nginx 中配置代理,包括 TCP/UDP 负载均衡等用例,以及相关示例说明。

准备工作

在进行 Nginx 的配置之前,我们需要安装好相关环境,并开启 Nginx 服务。

TCP 代理配置

步骤一、打开 Nginx 配置文件

通常情况下,Nginx 配置文件的位置为 /etc/nginx/nginx.conf,使用 vi 命令来编辑该文件:

sudo vi /etc/nginx/nginx.conf

步骤二、创建 TCP 代理配置

在 http 配置块后加上 stream 配置块,如下所示:

stream {
    upstream backend {
        server backend1.example.com:12345;
        server backend2.example.com:12345;
    }

    server {
        listen 12345;
        proxy_pass backend;
    }
}

步骤三、重启 Nginx 服务

完成配置后,使用以下命令重启 Nginx 服务,使配置文件生效:

sudo systemctl restart nginx

UDP 代理配置

步骤一、打开 Nginx 配置文件

同样是打开 /etc/nginx/nginx.conf配置文件:

sudo vi /etc/nginx/nginx.conf

步骤二、创建 UDP 代理配置

在 stream 配置块下加上如下配置:

udp {

    upstream backend {
        server backend1.example.com:12345;
        server backend2.example.com:12345;
    }

    server {
        listen 12345 udp;
        proxy_pass backend;
    }
}

步骤三、重启 Nginx 服务

完成配置后,使用以下命令重启 Nginx 服务,使配置文件生效:

sudo systemctl restart nginx

示例说明

下面是两个详细的示例说明,以 UDP 代理为例。

示例一:UDP 负载均衡

在此示例中,我们将使用 Nginx 来实现 UDP 负载均衡功能。前提是需要加入 DNS 指向多个后端服务器,然后配置 Nginx 来负载均衡访问请求。

udp {
    upstream mybackend {
        server 192.168.1.2:8124 weight=3;
        server 192.168.1.3:8124;
    }

    server {
        listen 8124;
        proxy_pass mybackend;
    }
}

解释:

  • upstream:用来定义负载均衡池,其中可以添加多个后端服务器地址,使用 weight 来指定后端服务器的权重,默认为1。
  • server:该段配置用来配置 Nginx 监听哪个端口,并使用哪个 backend 作为代理服务器,用来实现负载均衡。

示例二:将 UDP 数据写入文件

在此示例中,我们将使用 Nginx 来将接收到的 UDP 数据写入到文件中。

user root;
worker_processes auto;
error_log  /var/log/nginx/error.log error;

events {
    worker_connections  1024;
}

stream {
    # 将所有UDP 数据都写到 /var/log/nginx/access.log文件中
    server {
        listen 12888 udp;
        proxy_pass filewriter;
    }
}

upstream filewriter {
    # 通过本地 socket 将数据发送到 log_writer 进程
    server unix:/var/run/log_writer.sock;
}

解释:

  • user:设置 Nginx 工作进程的用户权限 (root)。
  • worker_processes:使用多少个进程来处理请求,auto 表示使用可用 CPU 核心数的值。
  • error_log:设置错误日志的位置和文件名称
  • listen:监听指定端口 (12888),同时配置协议类型 (udp)。
  • proxy_pass:这里使用 filewriter 指定了一个 upstream 对象,用于将此 UDP 数据转发到 log_writer 进程。
  • upstream:同样定义了一个名为 filewriter 的 upstream 对象,其实现方式是通过 unix socket。

参考以上详细的配置攻略,相信大家已经能够了解如何在 Nginx 中进行代理配置,以及如何实现 TCP/UDP 负载均衡。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Nginx stream 配置代理(Nginx TCP/UDP 负载均衡) - Python技术站

(0)
上一篇 2023年5月16日
下一篇 2023年5月16日

相关文章

  • Nginx+Windows负载均衡配置方法

    下面是“Nginx+Windows负载均衡配置方法”的完整攻略,包含两个示例说明: 一、Nginx+Windows负载均衡配置方法 1.下载Nginx 在官网https://nginx.org/en/download.html下载Windows版的Nginx压缩包,并解压到本地。 2.配置Nginx 首先进入conf目录,修改nginx.conf文件。 (1…

    Nginx 2023年5月16日
    00
  • nginx的rewrite详解

    rewrite模块(ngx_http_rewrite_module) nginx通过ngx_http_rewrite_module模块支持url重写、支持if条件判断,但不支持else。另外该模块需要PCRE支持,应在编译nginx时指定PCRE支持。根据相关变量重定向和选择不同的配置,从一个location跳转到另一个location,不过这样的循环最多可…

    Nginx 2023年4月13日
    00
  • 修改Nginx源码实现worker进程隔离实现详解

    下面我将详细讲解“修改Nginx源码实现worker进程隔离实现详解”的完整攻略,并包含两条示例说明。 什么是worker进程隔离? 在Nginx中,worker进程是用来处理请求的进程。多个worker进程可以同时处理多个请求,以达到并行处理请求的目的。但是,在默认情况下,所有的worker进程之间是共享资源的,例如内存、文件描述符等。这样就会出现一个问题…

    Nginx 2023年5月16日
    00
  • kubernetes 之ingress-nginx对象实现代理后端主机并实现ssl回话卸载

    下载所需:https://github.com/kubernetes/ingress-nginx/tree/nginx-0.17.1 创建一个目录 mkdir -p /data [root@master ~]# tar xf ingress-nginx-nginx-0.17.1.tar.gz -C /data/ [root@master deploy]# c…

    Nginx 2023年4月12日
    00
  • [日常] nginx反代websocket

    去年的事 , 随便记记 ============================================================= 2017年11月6日 记录:   获取包的选择状态: dpkg –get-selections [package] dpkg –get-selections|grep nginx 完全卸载nginx: apt…

    Nginx 2023年4月9日
    00
  • nginx反向代理location中配置ip限制

    第一、在安装nginx的sbin目录下执行./nginx -v查看安装nginx的版本号 第二、在安装nginx的sbin目录下执行。./nginx -V查看安装nginx的版本号和模块 第三、 使用nginx的nginx_upstream_check模块来检测后端服务器的转态时,设置只允许某段IP访问,发现不生效,不在此网段的IP也可以访问。 原因为在允许…

    Nginx 2023年4月10日
    00
  • 编译安装nginx时配置开机自启

    详细编译安装nginx请参考【Nginx目录结构与配置文件详解】以及【Nginx安装部署】,在这里就进行简单安装 环境介绍 操作系统: [root@localhost ~]# cat /etc/redhat-release CentOS Linux release 7.6.1810 (Core) [root@localhost ~]# uname -a Li…

    Nginx 2023年4月12日
    00
  • nginx日志request_time 和upstream_response_time区别

    nginx常见的2个time 我们在通过tsar采集对nginx的数据进行采集时,发现tsar采集到的rt时间和nginx自身日志中打印的时间$request_time对不上,这让我们在收到报警后很难快速的和nginx的日志对应起来,从而找到我们响应慢的api。于是对nginx的几个处理时间进行了分析,原来$request_time包含了用户数据接收时间,而…

    Nginx 2023年4月10日
    00
合作推广
合作推广
分享本页
返回顶部