Nginx——端口负载均衡
前言
Nginx做的代理后面SpringBoot的项目,1N3T的架构,Tomcat的配置也进行了相应的调优。
配置
这里主要来简单的说下Nginx的端口负载均衡,具体的大家可以参考
Nginx文档 | Nginx 烹调书(Nginx Cookbook 中文版) | Nginx文档PLUS
upstream是nignx分配方式,默认是轮询
1. 轮询: 轮询是upstream的默认分配方式,即每个请求按照时间顺序轮流分配到不同的后端服务器。
2. weight: 按着权重的大小进行轮询。
3. ip_hash: 每个请求按照访问ip的hash结果分配,这样每个访客会固定访问一个后端服务器,可以解决session一致问题。
4. fair: 可以根据页面大小、加载时间长短智能的进行负载均衡,响应时间短的后端服务器优先分配请求。
5. url_hash: 与ip_hash类似,但是按照访问url的hash结果来分配请求,使得每个url定向到同一个后端服务器,主要应用于后端服务器为缓存时的场景下。
6. least_conn: 把请求转发给连接数较少的后端服务器
轮询
# max_fails=2 fail_timeout=30s 代表在30秒内请求某一应用失败2次,认为该应用宕机,等待30秒再次请求
upstream pool {
server 192.168.10.1:6001 weight=10 max_fails=2 fail_timeout=30s;
server 192.168.10.1:51001 weight=10 max_fails=2 fail_timeout=30s;
server 192.168.10.1:6005 weight=10 max_fails=2 fail_timeout=30s;
server 192.168.10.1:6004 weight=10 max_fails=2 fail_timeout=30s;
}
ip_hash
upstream pool {
ip_hash;
server 192.168.10.1:6001 weight=10 max_fails=2 fail_timeout=30s;
server 192.168.10.1:51001 weight=10 max_fails=2 fail_timeout=30s;
server 192.168.10.1:6005 weight=10 max_fails=2 fail_timeout=30s;
server 192.168.10.1:6004 weight=10 max_fails=2 fail_timeout=30s;
}
完整配置
我这边是虚拟主机的,所以直接配置对应的虚拟主机的配置就好了,完整配置如下
# 负载的地址池
upstream pool {
ip_hash;
server 192.168.10.1:6001 weight=10 max_fails=2 fail_timeout=30s;
server 192.168.10.1:51001 weight=10 max_fails=2 fail_timeout=30s;
server 192.168.10.1:6005 weight=10 max_fails=2 fail_timeout=30s;
server 192.168.10.1:6004 weight=10 max_fails=2 fail_timeout=30s;
}
server
{
listen 80;
listen 443 ssl;
server_name app.xxxx.net;
index index.html index.htm index.php default.html default.htm default.php;
underscores_in_headers on;
root /usr/local/nginx/conf/html;
ssl_certificate /cert/app.xxxx.net.pem;
ssl_certificate_key /cert/app.xxxx.net.key;
ssl_session_timeout 5m;
ssl_ciphers xxxxxxxxxxxxxxxx;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_prefer_server_ciphers on;
location / {
proxy_set_header Host $host:80;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header x-forwarded-for $remote_addr;
#地址池名称pool
proxy_pass http://pool;
}
location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$ {
#地址池名称pool
proxy_pass http://pool;
expires 30d;
}
location ~ .*\.(js|css)?$ {
#地址池名称pool
proxy_pass http://pool;
expires 12h;
}
access_log /home/wwwlogs/app.xxxx.net.log;
}
pool是自己命名的一个变量,你可以命名为别的值
Nginx端口负载均衡就是这么的简单,但是不要忘记reload一下哦~
Nginx——端口负载均衡的更多相关文章
- nginx+tomcat负载均衡
最近练习nginx+tomcat负载均衡.根据一些资料整理了大体思路,最终实现了1个nginx+2个tomcat负载均衡. 安装JDK 1>进入安装目录,给所有用户添加可执行的权限 #chmod ...
- 【Nginx】配置Nginx的负载均衡
参考的优秀文章 tomcat配置文件server.xml详解 AJP协议总结与分析 Using nginx as HTTP load balancer 在本机运行2个Tomcat 现需要运行两个Tom ...
- Nginx的负载均衡 - 整体架构
Nginx的负载均衡 - 整体架构 Nginx版本:1.9.1 我的博客:http://blog.csdn.net/zhangskd Nginx目前提供的负载均衡模块: ngx_http_upstre ...
- Nginx之负载均衡
转自:http://www.360doc.com/content/13/1114/12/7694408_329125489.shtml 注,大家可以看到,由于我们网站是发展初期,nginx只代理了后端 ...
- [转]CENTOS 6.5 配置YUM安装NGINX+服务器负载均衡
原文连接: CENTOS 6.5 配置YUM安装NGINX http://blog.sina.com.cn/s/blog_69f467b70102uyux.html 参考博文: Centos下安装. ...
- 架构之路 之 Nginx实现负载均衡
[前言] 在大型网站中,负载均衡是有想当必要的.尤其是在同一时间访问量比较大的大型网站,例如网上商城,新闻等CMS系统,为了减轻单个服务器的处理压力,我们引进了负载均衡这一个概念,将一个服务器的压力分 ...
- Nginx实现负载均衡&Nginx缓存功能
一.Nginx是什么 Nginx (engine x) 是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP服务器.Nginx是由伊戈尔·赛索耶夫为俄罗斯访问量第二的Rambl ...
- 利用nginx实现负载均衡和动静分离
1.Nginx介绍 Nginx ("engine x") 是一个高性能的 HTTP 和 反向代理 服务器,也是一个 IMAP/POP3/SMTP 代理服务器 . Nginx 是由 ...
- 6.Nginx作为负载均衡服务器应用
案例:Nginx作为负载均衡服务器应用 nginx的负载均衡功能是通过upstream命令实现的,因此他的负载均衡机制比较简单,是一个基于内容和应用的7层交换负载均衡的实现.Nginx负载均衡默认对后 ...
随机推荐
- [LeetCode] 266. Palindrome Permutation 回文全排列
Given a string, determine if a permutation of the string could form a palindrome. Example 1: Input: ...
- 《30天自制操作系统》笔记3 --- (Day2 上节)完全解析文件系统
Day2 汇编语言学习与Makefile入门 本文仅带着思路,研究源码里关于文件系统的参数 关于day2主程序部分及更多内容,请看<30天自制操作系统>笔记 导航 发现学习中的变化 源码差 ...
- Harbor 忘记密码
Harbor密码重置 01,登入到harbor容器里面的数据库上 docker exec -it harbor-db /bin/bash 02,登入数据库 psql -h postgresql -d ...
- ElasticSearch6.3.2 集群做节点冷(warm) 热(hot) 分离
拿一个小规模的5节点ES集群做冷热分离尝试,它上面已经有60多个索引,有些索引按月.每月生成一个索引,随着数据的不断写入,历史数据(只需保留三个月数据,三个月之前的数据视为历史数据)越来越占磁盘空间和 ...
- 汉字转拼音,TinyPinyin、Pinyin4j与JPinyin哪个库更快
1. 介绍 本文对TinyPinyin.Pinyin4j与JPinyin三个汉字转拼音库的用法.测试代码及转换的结果做一个简单的总结. TinyPinyin 适用于Java和Android的快速.低内 ...
- mysql备份、还原数据库(命令行)
这里记录下MySQL如何通过命令行备份和还原数据库. 简单的三个步骤 方法很简单,可以分为三个步骤: 1.打开cmd控制台(命令行). 2.输入相应命令完成备份还原操作. 3.关闭cmd控制台. 就和 ...
- nginx产生【413 request entity too large】错误的原因与解决方法
项目上在做上传文件(清单导入)的时候产生了这个错误: 从字面上看,说的是请求的实体太大的问题,那么可以联想到是HTTP请求中的Body大小被限制了的原因. Nginx中的[client_max_bod ...
- Linux进程启动/指令执行方式研究
1. 通过glibc api执行系统指令 0x1:system() glibc api system是linux系统提供的函数调用之一,glibc也提供了对应的封装api. system函数的原型为: ...
- FormData的Ajax提交注意事项
Ajax提交表单一般有下面两种形式: var form_data = $('#form').serialize(); var form_data = new FormData($('#form')[0 ...
- IEEE浮点表示 (原发布 csdn 2018-10-14 10:29:33)
目录 观察IEEE浮点表示 工作中遇到过整型转浮点型(union那种转换),碰到就看下书,过后就遗忘了.等过段时间又出现此现象,又重新拿起书本,这次记录了过程.然而一直等到今天才写出来,以防以后还用到 ...