热门标签 | 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了。


推荐阅读
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • mac php错误日志配置方法及错误级别修改
    本文介绍了在mac环境下配置php错误日志的方法,包括修改php.ini文件和httpd.conf文件的操作步骤。同时还介绍了如何修改错误级别,以及相应的错误级别参考链接。 ... [详细]
  • 使用freemaker生成Java代码的步骤及示例代码
    本文介绍了使用freemaker这个jar包生成Java代码的步骤,通过提前编辑好的模板,可以避免写重复代码。首先需要在springboot的pom.xml文件中加入freemaker的依赖包。然后编写模板,定义要生成的Java类的属性和方法。最后编写生成代码的类,通过加载模板文件和数据模型,生成Java代码文件。本文提供了示例代码,并展示了文件目录结构。 ... [详细]
  • Question该提问来源于开源项目:react-native-device-info/react-native-device-info ... [详细]
  • 自动轮播,反转播放的ViewPagerAdapter的使用方法和效果展示
    本文介绍了如何使用自动轮播、反转播放的ViewPagerAdapter,并展示了其效果。该ViewPagerAdapter支持无限循环、触摸暂停、切换缩放等功能。同时提供了使用GIF.gif的示例和github地址。通过LoopFragmentPagerAdapter类的getActualCount、getActualItem和getActualPagerTitle方法可以实现自定义的循环效果和标题展示。 ... [详细]
  • FeatureRequestIsyourfeaturerequestrelatedtoaproblem?Please ... [详细]
  • JDK源码学习之HashTable(附带面试题)的学习笔记
    本文介绍了JDK源码学习之HashTable(附带面试题)的学习笔记,包括HashTable的定义、数据类型、与HashMap的关系和区别。文章提供了干货,并附带了其他相关主题的学习笔记。 ... [详细]
  • iOS超签签名服务器搭建及其优劣势
    本文介绍了搭建iOS超签签名服务器的原因和优势,包括不掉签、用户可以直接安装不需要信任、体验好等。同时也提到了超签的劣势,即一个证书只能安装100个,成本较高。文章还详细介绍了超签的实现原理,包括用户请求服务器安装mobileconfig文件、服务器调用苹果接口添加udid等步骤。最后,还提到了生成mobileconfig文件和导出AppleWorldwideDeveloperRelationsCertificationAuthority证书的方法。 ... [详细]
  • AFNetwork框架(零)使用NSURLSession进行网络请求
    本文介绍了AFNetwork框架中使用NSURLSession进行网络请求的方法,包括NSURLSession的配置、请求的创建和执行等步骤。同时还介绍了NSURLSessionDelegate和NSURLSessionConfiguration的相关内容。通过本文可以了解到AFNetwork框架中使用NSURLSession进行网络请求的基本流程和注意事项。 ... [详细]
  • python中安装并使用redis相关的知识
    本文介绍了在python中安装并使用redis的相关知识,包括redis的数据缓存系统和支持的数据类型,以及在pycharm中安装redis模块和常用的字符串操作。 ... [详细]
  • java实现rstp格式转换使用ffmpeg实现linux命令第一步安装node.js和ffmpeg第二步搭建node.js启动websocket接收服务
    java实现rstp格式转换使用ffmpeg实现linux命令第一步安装node.js和ffmpeg第二步搭建node.js启动websocket接收服务第三步java实现 ... [详细]
  • 本文介绍了在实现了System.Collections.Generic.IDictionary接口的泛型字典类中如何使用foreach循环来枚举字典中的键值对。同时还讨论了非泛型字典类和泛型字典类在foreach循环中使用的不同类型,以及使用KeyValuePair类型在foreach循环中枚举泛型字典类的优势。阅读本文可以帮助您更好地理解泛型字典类的使用和性能优化。 ... [详细]
  • 抽空写了一个ICON图标的转换程序
    抽空写了一个ICON图标的转换程序,支持png\jpe\bmp格式到ico的转换。具体的程序就在下面,如果看的人多,过两天再把思路写一下。 ... [详细]
  • 原文地址http://balau82.wordpress.com/2010/02/28/hello-world-for-bare-metal-arm-using-qemu/最开始时 ... [详细]
  • 三、查看Linux版本查看系统版本信息的命令:lsb_release-a[root@localhost~]#lsb_release-aLSBVersion::co ... [详细]
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社区 版权所有