热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

nginx的4层负载均衡

nginx可以实现4层负载均衡。软件四层负载均衡:通过报文(数据包)中的目标地址和端口,加上分发机上的调度算法,决定最终选择哪个RIP。

nginx可以实现4层负载均衡。

软件四层负载均衡:
通过报文(数据包)中的目标地址和端口,加上分发机上的调度算法,决定最终选择哪个RIP。
LVS

软件七层负载均衡:
通过看客户端请求的具体内容(文字、图片、视频;网站交互)进行最终选择。

网络中常见的 SYN Flood 攻击。DOS。DDOS

nginx的4层负载均衡有2个条件:

1、版本在1.10以上

2、配置选项要有stream

[root@nginx-4c ~]# /usr/local/nginx/sbin/nginx -V
nginx version: nginx/1.17.6
built by gcc 4.8.5 20150623 (Red Hat 4.8.5-39) (GCC)
built with OpenSSL 1.0.2k-fips 26 Jan 2017
TLS SNI support enabled
configure arguments: --prefix&#61;/usr/local/nginx --user&#61;www --group&#61;www --with-http_stub_status_module --with-http_v2_module --with-http_ssl_module --with-http_sub_module --with-http_gzip_static_module --with-http_realip_module --with-stream--with-stream <--要这个选项

配置&#xff1a;

pid logs/nginx.pid;
events {worker_connections 1024;use epoll;
}
》》》》》》》》》》》》》》》》》》》》》》》》
stream {upstream p_ssh { hash $remote_addr consistent;server 172.16.12.71:22; server 172.16.12.72:22;}server {listen 24678;proxy_connect_timeout 3s; proxy_timeout 10s;proxy_pass p_ssh;}
}
》》》》》》》》》》》》》》》》》》》》》》》》

然后重启服务&#xff1a;
查端口&#xff0c;有24678那个新添加的端口

[root&#64;nginx-4c nginx]# netstat -antlup | grep nginx
tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 882/nginx: master p
tcp 0 0 0.0.0.0:24678 0.0.0.0:* LISTEN 882/nginx: master p

访问测试&#xff1a;

[root&#64;localhost mnt]# ssh -p 24678 root&#64;172.16.12.82root&#64;172.16.12.82&#39;s password:
Last login: Sat Jan 4 00:59:11 2020 from 172.16.12.1
[root&#64;chunk1 ~]# Connection to 172.16.12.82 closed by remote host.
Connection to 172.16.12.82 closed.

能够登录转发。

mysql

172.16.12.71

装个mysql

[root&#64;chunk1 ~]# yum install mariadb-server -y [root&#64;chunk1 ~]# systemctl restart mariadb
[root&#64;chunk1 ~]# mysqlMariaDB [(none)]> grant select on *.* to &#39;read&#39;&#64;&#39;172.16.%&#39; identified by &#39;12345&#39;;
MariaDB [(none)]> flush privileges;

172.16.12.72

MariaDB [(none)]> grant all on *.* to &#39;write&#39;&#64;&#39;172.16.%&#39; identified by &#39;12345&#39;;
MariaDB [(none)]> flush privileges;

stream {upstream mysql_read {hash $remote_addr consistent;server 172.16.12.71:3306 weight&#61;10 max_fails&#61;3 fail_timeout&#61;2s;} upstream mysql_write {hash $remote_addr consistent;server 172.16.12.72:3306 weight&#61;10 max_fails&#61;3 fail_timeout&#61;2s;} server {listen 3306;proxy_connect_timeout 3s;proxy_timeout 10s;proxy_pass mysql_read;}server {listen 3307;proxy_connect_timeout 3s;proxy_timeout 10s;proxy_pass mysql_write;}
}

重启查端口&#xff1a;
看到3306、3307&#xff0c;这两个是nginx启动的端口。

[root&#64;nginx-4c nginx]# netstat -antlup | grep nginx
tcp 0 0 0.0.0.0:3307 0.0.0.0:* LISTEN 882/nginx: master p
tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 882/nginx: master p
tcp 0 0 0.0.0.0:3306 0.0.0.0:* LISTEN 882/nginx: master p

访问测试&#xff1a;

[root&#64;client ~]# yum install -y mariadb

[root&#64;client ~]# mysql -h 172.16.12.82 -P 3306 -u read -p12345
Welcome to the MariaDB monitor. Commands end with ; or \g.

[root&#64;client ~]# mysql -h 172.16.12.82 -P 3307 -u write -p12345
Welcome to the MariaDB monitor. Commands end with ; or \g.
Your MariaDB connection id is 3

都能访问转发。ok了。


推荐阅读
  • Nginx入门指南:从零开始掌握基础配置与优化技巧
    Nginx入门指南:从零开始掌握基础配置与优化技巧 ... [详细]
  • 基于Linux开源VOIP系统LinPhone[四]
    ****************************************************************************************** ... [详细]
  • 本文详细介绍了在PHP中如何获取和处理HTTP头部信息,包括通过cURL获取请求头信息、使用header函数发送响应头以及获取客户端HTTP头部的方法。同时,还探讨了PHP中$_SERVER变量的使用,以获取客户端和服务器的相关信息。 ... [详细]
  • 本文详细介绍了如何搭建一个高可用的MongoDB集群,包括环境准备、用户配置、目录创建、MongoDB安装、配置文件设置、集群组件部署等步骤。特别关注分片、读写分离及负载均衡的实现。 ... [详细]
  • 第二章:Kafka基础入门与核心概念解析
    本章节主要介绍了Kafka的基本概念及其核心特性。Kafka是一种分布式消息发布和订阅系统,以其卓越的性能和高吞吐量而著称。最初,Kafka被设计用于LinkedIn的活动流和运营数据处理,旨在高效地管理和传输大规模的数据流。这些数据主要包括用户活动记录、系统日志和其他实时信息。通过深入解析Kafka的设计原理和应用场景,读者将能够更好地理解其在现代大数据架构中的重要地位。 ... [详细]
  • 在腾讯云服务器上部署Nginx的详细指南中,首先需要确保安装必要的依赖包。如果这些依赖包已安装,可直接跳过此步骤。具体命令包括 `yum -y install gcc gcc-c++ wget net-tools pcre-devel zlib-devel`。接下来,本文将详细介绍如何下载、编译和配置Nginx,以确保其在腾讯云服务器上顺利运行。此外,还将提供一些优化建议,帮助用户提升Nginx的性能和安全性。 ... [详细]
  • 负载均衡基础概念与技术解析
    随着互联网应用的不断扩展,用户流量激增,业务复杂度显著提升,单一服务器已难以应对日益增长的负载需求。负载均衡技术应运而生,通过将请求合理分配到多个服务器,有效提高系统的可用性和响应速度。本文将深入探讨负载均衡的基本概念和技术原理,分析其在现代互联网架构中的重要性及应用场景。 ... [详细]
  • Linux负载均衡LVS(IPVS)
    一、LVS简介LVS是LinuxVirtualServer的简称,也就是Linux虚拟服务器,是一个由章文嵩博士发起的自由软件项目,现在已经是Linux ... [详细]
  • 目录结构如下:Nginx基础知识NginxHTTP服务器的特色及优点Nginx的主要企业功能Nginx作为web服务器的主要应用场景包括:Nginx的安装安装环境 ... [详细]
  • LVS实现负载均衡的原理LVS负载均衡负载均衡集群是LoadBalance集群。是一种将网络上的访问流量分布于各个节点,以降低服务器压力,更好的向客户端 ... [详细]
  • Nginxgaodaima.comnginx属于七层架构,支持的是http协议,本身对tcp协议没有支持。所以不能代理mysql等实现负载均衡。但是lvs这个东西不熟悉,主要是公司 ... [详细]
  • SpringBoot底层注解用法及原理
    2.1、组件添加1、Configuration基本使用Full模式与Lite模式示例最佳实战配置类组件之间无依赖关系用Lite模式加速容器启动过程,减少判断配置类组 ... [详细]
  • 本文详细介绍了Socket在Linux内核中的实现机制,包括基本的Socket结构、协议操作集以及不同协议下的具体实现。通过这些内容,读者可以更好地理解Socket的工作原理。 ... [详细]
  • 本文主要从TLS1.3的优势、部署和时间发展线介绍了这上篇文章回顾:浅谈DHCP协议 ... [详细]
  • fidder监控请求响应时间和请求IP(摘抄至网络)
    增加监控请求的详情时间在CustomRules.js的classHandlers中增加添加请求的响应时间publicstaticBindU ... [详细]
author-avatar
高玉成
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有