阿里云实验
10.0.0.132 LB
10.0.0.133 web01
10.0.0.134 web02

步骤:
1.安装nginx1.14

获取官网repo文件
yum install -y nginx

2.配置文件,web服务器都是一样的

[root@web01 conf.d]# cat www.conf
server {
listen ;
server_name ali.xiao.com; location / {
root /code/ali;
index index.html;
}
} mkdir -p /code/ali
echo "web01 10.0.0.133" >/code/ali/index.html

3.检测语法,并启动服务

nginx -t
systemctl start nginx

4.配置七层负载均衡
1)创建proxy_params
2)创建负载均衡配置

[root@proxy conf.d]# cat proxy.conf
upstream ali {
server 10.0.0.133:;
server 10.0.0.134:;
} server {
listen ;
server_name ali.xiao.com; location / {
proxy_pass http://ali;
include proxy_params;
}
}

5.配置四层负载均衡
1)修改主配置文件/etc/nginx/nginx.conf,在http上面添加如下信息

# 添加四层代理
include /etc/nginx/conf.c/*.conf

2) 配置四层负载文件

mkdir -p /etc/nginx/conf.c
vim /etc/nginx/conf.c/proxy.conf
stream {
upstream ssh_web01{
server 10.0.0.133:;
}
upstream ssh_web02{
server 10.0.0.134:;
} server {
listen ;
proxy_pass ssh_web01;
} server {
listen ;
proxy_pass ssh_web02;
}
}

Nginx负载均衡TCP实践

配置nginx4层负载均衡实现如下需求
1.通过访问负载均衡的5555端口,实际是后端web01的22端口提供服务的
2.通过访问负载均衡的6666端口,实际是mysql的3306端口在提供服务

四层负载均衡 基于MySQL

1).实验环境

lb01   172.16.1.5    10.0.0.5
web01 172.16.1.7
db01 172.16.1.71

2).创建四层负载均衡配置目录

mkdir /etc/nginx/conf.c -p

3).修改lb01的主配置文件
vim /etc/nginx/nginx.conf,在http上面添加如下信息

# 添加四层代理
include /etc/nginx/conf.c/*.conf

4).创建四层负载均衡配置文件

[root@1b01 conf.c]# vim stream.conf
stream {
#定义虚拟资源池
upstream ssh {
server 172.16.1.7:;
} upstream mysql {
server 172.16.1.71:;
}
#调用虚拟资源池
server {
listen ;
proxy_connect_timeout 1s;
proxy_timeout 300s;
proxy_pass ssh;
} server {
listen ;
proxy_connect_timeout 1s;
proxy_timeout 300s;
proxy_pass mysql;
}
}

5).语法检查,并重启服务

nginx -t
systemctl reload nginx

Nginx动静分离
动静分离,通过中间件将动态请求和静态请求进行分离,分离资源,减少不必要的请求消耗,减少请求延时。
好吃:动静分离后,即使动态服务不可用,但静态资源不受影响

1.环境准备

系统         服务      服务           地址
centso7. 负载均衡 Nginx Proxy 10.0.1.5
centso7. 静态资源 Nginx Static 10.0.1.7
centso7. 动态资源 Nginx Server 10.0.1.8

2.在10.0.1.7服务器上配置静态资源

[root@web01 conf.d]# cat df.conf
server {
listen ;
server_name ds.xiao.com;
root /soft/code;
index index.html; location ~* .*\.(jpg|png|gif)$ {
root /soft/code/images;
}
} # 准备,目录已经静态相关图片
mkdir -p /soft/code/images
wget -O /soft/code/images/nginx.png http://nginx.org/nginx.png
systemctl reload nginx

3.在10.0.1.8服务器上配置动态资源

yum install -y tomcat
systemctl start tomcat
mkdir /usr/share/tomcat/webapps/ROOT
cd /usr/share/tomcat/webapps/ROOT/
[root@web02 ROOT]# cat java_test.jsp
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<HTML>
<HEAD>
<TITLE> jsp </TITLE>
</HEAD>
<BODY>
<%
Random rand = new Random();
out.println("<h1>Random number:</h1>");
out.println(rand.nextInt()+);
%>
</BODY>
</HTML>

4.在负载均衡10.0.1.5上配置调度,实现访问jsp和png

[root@1b01 conf.d]# cat ds.conf
upstream static {
server 172.16.1.7:;
} upstream java {
server 172.16.1.8:;
} server {
listen ;
server_name ds.xiao.com; location / {
root /code/soft;
index index.html;
} location ~ .*\.(jpg|png|gif)$ {
proxy_pass http://static;
include proxy_params;
} location ~ .*\.jsp$ {
proxy_pass http://java;
include proxy_params;
}
}

5.通过负载测试访问静态资源
6.通过负载测试访问动态资源
7.在负载均衡10.0.1.5整合动态和静态资源的html文件

mkdir -p /code/soft
[root@1b01 conf.d]# cat /code/soft/index.html
<html lang="en">
<head>
<meta charset="UTF-8" />
<title>测试ajax和跨域访问</title>
<script src="http://libs.baidu.com/jquery/2.1.4/jquery.min.js"></script>
</head>
<script type="text/javascript">
$(document).ready(function(){
$.ajax({
type:"GET",
url:"http://ds.xiao.com/java_test.jsp",
success: function(data) {
$("#get_data").html(data)
},
error: function() {
alert("fail!!,请刷新重试"); }
});
});
</script>
<body>
<h1>测试动静分离</>
<img src="http://ds.xiao.com/nginx.png">
<div id="get_data"></data>
</body>
</html>

8.测试动态和静态资源是否能正常加载在一个html文件中
9.当使用systemctl stop nginx停止Nginx后,会发现静态内容无法访问,动态内容依旧运行正常
10.当使用systemctl stop tomcat停止tomcat后,静态内容依旧能正常访问,动态内容将不会被请求到

nginx四层负载及动静分离的更多相关文章

  1. nginx+tomcat负载均衡+动静分离+redis集中管理session

    1.服务器A安装ng,服务器B.C安装tomcat: 2.服务器A建立/data/www目录,用于发布静态文件: 3.ng无动静分离配置: user root root; worker_process ...

  2. 面试 之 nginx,负载,动静分离

    大家先看这个逻辑图 为什么我们要这样去架构我们的一个项目呢? 这样做的话,动态请求要先访问 A,A 转发访问 B,再由 B 返回结果给 A,A 最后又将结果返回给客户端这样是不是很麻烦? 最初开发的时 ...

  3. Nginx 和 IIS 实现动静分离

    前段时间,搞Nginx+IIS的负载均衡,想了解的朋友,可以看这篇文章:<nginx 和 IIS 实现负载均衡>,然后也就顺便研究了Nginx + IIS 实现动静分离.所以,一起总结出来 ...

  4. Nginx 和 IIS 实现动静分离【转载】

    前段时间,搞Nginx+IIS的负载均衡,想了解的朋友,可以看这篇文章:<nginx 和 IIS 实现负载均衡>,然后也就顺便研究了Nginx + IIS 实现动静分离.所以,一起总结出来 ...

  5. nginx四层负载均衡配置

    nginx四层负载均衡配置代理Mysql集群 环境如下: ip 192.168.6.203 Nginx ip 192.168.6.*(多台) Mysql 步骤一 查看Nginx是否安装stream模块 ...

  6. Nginx 和 IIS 实现动静分离(转)

    转载地址:https://www.cnblogs.com/paul8339/p/5825201.html 动静分离,说白了,就是将网站静态资源(HTML,JavaScript,CSS,img等文件)与 ...

  7. Nginx四层负载均衡概述

    目录 Nginx四层负载均衡概述 什么是负载均衡 负载均衡应用场景 四层,七层集群架构 四层负载均衡总结 Nginx如何配置四层负载均衡 nginx四层负载均衡端口转发 Nginx四层负载均衡概述 什 ...

  8. Nginx 反向代理功能-动静分离

    Nginx 反向代理功能-动静分离 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任.

  9. 14、Nginx四层负载均衡

    1.Nginx四层负载均衡基本概述 1.1.什么是四层负载均衡 四层负载均衡基于传输层协议包来封装的(如:TCP/IP),那我们前面使用到的七层是指的应用层,它的组装在四层基础之上,无论四层还是七层都 ...

随机推荐

  1. 想要写好Synthesis Essay,学会审题很重要

    很多留学生都不太愿意写synthesis essay,因为它的难度要比其他类型的essay要大得多.写一篇synthesis essay需要有能力消化相关的信息,通过语言组织之后再呈现.虽然这种写作技 ...

  2. Python 删除文件与文件夹

    版权所有,未经许可,禁止转载 章节 Python 介绍 Python 开发环境搭建 Python 语法 Python 变量 Python 数值类型 Python 类型转换 Python 字符串(Str ...

  3. kafka管理神器-kafkamanager

    好久没发过kafka的文章了,今天整理一下kafka-manager神器. java环境要求 jdk8 kafkamanager源码下载 https://github.com/yahoo/kafka- ...

  4. UVA - 11925 Generating Permutations(生成排列)(构造)

    题意:将序列1,2,3,……,n,用不超过2n^2次操作,通过下列操作变成给定序列.(1<=n<=300) 1.交换前两个元素 2.将第一个元素移到最后 分析:因为将序列变成升序更容易操作 ...

  5. Distributed--分布式架构

    如果我们期望实现一套严格满足ACID特性的分布式事务,很可能出现的情况就是在系统的可用性和严格一致性之间出现冲突. 在可用性和一致性之间,永远无法存在一个两全其美的方案. 从集中式到分布式 集中式系统 ...

  6. JQ+AJAX 发送异步请求

    1. load() ; 作用:通过ajax 请求从服务器加载数据,并添加到符合要求的节点上 用法:$node.load(请求地址,请求参数) 请求参数写法: --"username=admi ...

  7. soap调用Jar包冲突,SOAPMessageContext

    ================================ ©Copyright 蕃薯耀 2020-01-07 https://www.cnblogs.com/fanshuyao/ soap调用 ...

  8. 三、在SAP中文本如何换行

    一.在一段文字前面,加上右斜杠符合\ ,这句话就会换行了,如图: 效果如下:

  9. 51Nod1049 最大子段和

    我们来先看题: N个整数组成的序列a1,a2,a3,-,an,求该序列如ai+ai+1+-+aj的连续子段和的最大值.当所给的整数均为负数时和为0. 例如:-2,11,-4,13,-5,-2,和最大的 ...

  10. web网页外部分享到微信、朋友圈、扣扣、微博等功能、自动生成二维码等

    1.这里重中之重是分享到微信:web端网页通常是没有权限分享过去的 所以用: weixin://dl/business/?ticket=ta428dhj739hg3efe6e  但是这个ticket真 ...