linux篇—Nginx反向代理负载均衡
一、环境准备
反向代理功能架构
3台web服务器,组建出web服务器集群
web01 10.0.0.7 172.16.1.7
web02 10.0.0.8 172.16.1.8
web03 10.0.0.9 172.16.1.9
1台负载均衡服务器
lb01 10.0.0.5 172.16.1.5
二、部署web服务和负载均衡服务
1. 安装部署nginx
在三台web服务器和负载均衡服务器上都部署上nginx
- mkdir /server/tools -p
- cd /server/tools
- wget http://nginx.org/download/nginx-1.12.2.tar.gz
- tar xf nginx-1.12.2.tar.gz
- yum install -y pcre-devel openssl-devel
- useradd -M -s /sbin/nologin www
- cd nginx-1.12.2
- ./configure --prefix=/application/nginx-1.12.2 --user=www --group=www --with-http_ssl_module --with-http_stub_status_module
- make && make install
- ln -s /application/nginx-1.12.2 /application/nginx
- /application/nginx/sbin/nginx
- netstat -lntup|grep nginx
2. 编辑nginx配置文件
- server {
- listen 80;
- server_name www.etiantian.org;
- root html/www;
- index index.html index.htm;
- }
- server {
- listen 80;
- server_name bbs.etiantian.org;
- root html/bbs;
- index index.html index.htm;
- }
#将配置文件分发到其他两台web服务器- scp -rp /application/nginx/conf/nginx.conf 172.16.1.8:/application/nginx/conf/
- scp -rp /application/nginx/conf/nginx.conf 172.16.1.8:/application/nginx/conf/
3. 在三台web服务器上创建模拟测试环境
- mkdir /application/nginx/html/{www,bbs} -p
- for name in www bbs;do echo "$(hostname) $name.etiantian.org" >/application/nginx/html/$name/test.html;done
- for name in www bbs;do cat /application/nginx/html/$name/test.html;done
4. 在负载均衡服务器上,进行测试访问
- curl -H host:www.etiantian.org 10.0.0.7/test.html
- web01 www.etiantian.org
- curl -H host:bbs.etiantian.org 10.0.0.7/test.html
- web01 bbs.etiantian.org
- curl -H host:www.etiantian.org 10.0.0.8/test.html
- web02 www.etiantian.org
- curl -H host:bbs.etiantian.org 10.0.0.8/test.html
- web02 bbs.etiantian.org
- curl -H host:www.etiantian.org 10.0.0.9/test.html
- web03 www.etiantian.org
- curl -H host:bbs.etiantian.org 10.0.0.9/test.html
- web03 bbs.etiantian.org
5. 在负载均衡lb01服务器上编写nginx反向代理配置文件
01. 简化配置文件
- cd /application/nginx/conf/
- grep -Ev "#|^$" nginx.conf.default >nginx.conf
02. 在nginx.conf中编写upstream和proxy_pass模块
说明:upstream模块就类似定一个一个地址池或者说定一个web服务器组
官方链接:http://nginx.org/en/docs/http/ngx_http_upstream_module.html#upstream
语法:
- Syntax: upstream name { ... }
- Default: —
- Context: http
eg:
- #添加web服务器节点
upstream oldboy {- server 10.0.0.7:80;
- server 10.0.0.8:80;
- server 10.0.0.9:80;
- }
说明:proxy_pass主要用于进行抛送用户访问请求给upstream模块中的相应节点服务器
官方文档:http://nginx.org/en/docs/http/ngx_http_proxy_module.html#proxy_pass
- Syntax: proxy_pass URL;
- Default: —
- Context: location, if in location, limit_except
- eg:
- location / {
- proxy_pass http://test;
- }
eg:
- worker_processes 1;
- events {
- worker_connections 1024;
- }
- http {
- include mime.types;
- default_type application/octet-stream;
- sendfile on;
- keepalive_timeout 65;
- upstream test {
- server 10.0.0.7:80;
- server 10.0.0.8:80;
- server 10.0.0.9:80;
- }
- server {
- listen 80;
- server_name localhost;
- root html;
- index index.html index.htm;
- location / {
- proxy_pass http://test;
- }
- }
- }
编写完后重启nginx服务
- /application/nginx/sbin/nginx -t
- /application/nginx/sbin/nginx -s reload
6. 进行访问负载均衡服务器测试
- 1)利用浏览器进行测试
- 进行hosts解析
- http://www.etiantian.org/oldboy.html <--利用ctrl+F5刷新测试,检查是否进行负载调度
- 2)利用curl命令进行测试
- [root@lb01 conf]# curl -H host:www.etiantian.org 10.0.0.5/test.html
- web01 www.etiantian.org
- [root@lb01 conf]# curl -H host:www.etiantian.org 10.0.0.5/test.html
- web02 www.etiantian.org
- [root@lb01 conf]# curl -H host:www.etiantian.org 10.0.0.5/test.html
- web03 www.etiantian.org
linux篇—Nginx反向代理负载均衡的更多相关文章
- Linux 下 Nginx 反向代理 负载均衡配置
转载请注明出处:http://blog.csdn.net/smartbetter/article/details/52036350 上一篇分享了 Nginx + JDK + Tomcat + MySQ ...
- linux (09) nginx反向代理,负载均衡
一.nginx域名分配 1.创建一个新的服务器 server server{ listen 80; server_name www.s15oumei.com; #定义访问域名 location / { ...
- Linux下nginx反向代理负载均衡几种方式以及配置
下面以ip地址192.168.1.1 和192.168.1.2举例 1.轮询 (1).轮询:每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除. upstream ...
- Nginx 反向代理 负载均衡 虚拟主机配置
Nginx 反向代理 负载均衡 虚拟主机配置 通过本章你将学会利用Nginx配置多台虚拟主机,清楚代理服务器的作用,区分正向代理和反向代理的区别,搭建使用Nginx反向搭理和负载均衡,了解Nginx常 ...
- Nginx 反向代理 负载均衡 虚拟主机
Nginx 反向代理 负载均衡 虚拟主机配置 通过本章你将学会利用Nginx配置多台虚拟主机,清楚代理服务器的作用,区分正向代理和反向代理的区别,搭建使用Nginx反向搭理和负载均衡,了解Nginx常 ...
- 十.nginx反向代理负载均衡服务实践部署
期中集群架构-第十章-nginx反向代理负载均衡章节章节====================================================================== 0 ...
- 【转】Nginx 反向代理 负载均衡 虚拟主机配置
原文:http://www.cnblogs.com/itdragon/p/8059000.html Nginx 反向代理 负载均衡 虚拟主机配置 通过本章你将学会利用Nginx配置多台虚拟主机,清楚代 ...
- Centos7.4 Nginx反向代理+负载均衡配置
Ningx是一款高性能的HTTP和反向代理服务器,配置起来也比较简单. 测试环境: 172.16.65.190 Nginx-反向代理 172.16.65.191 Ningx-Web 172.16.65 ...
- 如何使用Weave以及Docker搭建Nginx反向代理/负载均衡服务器
Hi, 今天我们将会学习如何使用 Weave 和 Docker 搭建 Nginx 的反向代理/负载均衡服务器.Weave 可以创建一个虚拟网络将 Docker 容器彼此连接在一起,支持跨主机部署及自动 ...
随机推荐
- 【leetcode】394. Decode String
题目如下: 解题思路:这种题目和四则运算,去括号的题目很类似.解法也差不多. 代码如下: class Solution(object): def decodeString(self, s): &quo ...
- Java浏览器弹出下载框,多个文件导出压缩包
项目里一直有这个功能,也一直没怎么注意,今天研究了一下 依据逻辑往下走: 首先是要下载的ajax的Java方法,只有返回值需要设定一下,其他的不用管: Map<String, Object> ...
- python中sort与sorted区别
1.sort()函数 (只对list有用) sort(...) L.sort(key = None,reverse=False) key = 函数 这个函数会从每个元素中提取一个用于比较的关键字.默认 ...
- Spark在MaxCompute的运行方式
一.Spark系统概述 左侧是原生Spark的架构图,右边Spark on MaxCompute运行在阿里云自研的Cupid的平台之上,该平台可以原生支持开源社区Yarn所支持的计算框架,如Spark ...
- selenium 浏览器无界面模式运行
以Chrome浏览器为例: 方法一: from selenium.webdriver import Chrome, ChromeOptions opt = ChromeOptions() # 创建Ch ...
- 相同name,取最小的id的值,mysql根据相同字段 更新其它字段
id name info1 a 1232 a 2353 a 1244 b 125 b 987相同name,取最小的id的值id name info1 a 1232 a 1233 a 1234 b 12 ...
- 穿戴-智能穿戴-ProjectGlass:谷歌眼镜(Google Project Glass)
ylbtech-穿戴-智能穿戴-ProjectGlass:谷歌眼镜(Google Project Glass) 谷歌眼镜(Google Project Glass)是由谷歌公司于2012年4月发布的一 ...
- ajax跨域处理 No 'Access-Control-Allow-Origin' header is present on the requested resource 问题
Controller层的类上增加@CrossOrign注解,当前文件的所有接口就都可以被调用 spring注解@CrossOrigin不起作用的原因 1.是springMVC的版本要在4.2或以上版本 ...
- Centos7配置定时重启服务器
Crontab是一个很方便的在unix/linux系统上定时(循环)执行某个任务的程序. 用 service crond status 查看 crond服务状态,如果没有启动则 systemctl s ...
- 大数据学习笔记之Zookeeper(三):Zookeeper理论篇(二)
文章目录 3.1 数据结构 3.2 节点类型 3.3 特点 3.4 选举机制 3.5 stat结构体 3.6 监听器原理 3.1 数据结构 ZooKeeper数据模型的结构与Unix文件系统很类似,整 ...