1.

.nginx负载均衡的实现
.准备三台机器,准备3台虚拟机,或者和俩同桌交流一下 192.168.226.128 是nginx资源服务器,返回页面的
192.168.226.129 用作nginx负载均衡服务器
192.168.226.130 也用作nginx资源服务器 .分别配置三台机器
确保 128和130这2台机器,能正确的资源返回即可
这三个机器,都是通过修改nginx.conf来实现效果的
128此时返回 超哥 一米五的 页面
130返回
129配置反向代理 .配置关键点如下
129负载均衡配置修改nginx.conf如下 添加负载均衡地址池的参数
#默认是轮询方式,两台服务器
upstream s18django {
server 192.168.226.128;
server 192.168.226.130;
}
添加反向代理参数如下
proxy_pass http://s18django; .配置完毕后,重启nginx,检测负载均衡效果 访问192.168.226.129这个负载均衡器
它会默认轮询的,丢给upstream中的地址池,每人一次 .nginx负载均衡的算法
.轮询方式
.加权轮询
upstream s18django {
server 192.168.226.128 weight=;
server 192.168.226.130 weight=;
}
.ip_hash方式,对你的ip地址进行哈希,ip_hash方式不得与权重共用 upstream s18django {
server 192.168.226.128;
server 192.168.226.130;
ip_hash;
}

模拟负载均衡:

现在我们直接访问128服务器,

退出虚拟环境,关闭防火墙,打开nginx

我们在xshell中依次,登录129和130两个客户端

昨天已经装上了nginx了

安装nginx的三种方式:1.yum 2.源码包安装 3.rpm安装,需要解决大量依赖关系

上图是yum方式的安装方式,老师用的是这种,我用的是源码安装.,这台服务器是130

我们现在需要处理的是129

操作处理nginx.conf

原来的情况是,我们只把nginx服务器129当成代理的功能服务器,现在我们将服务器当成中间负载均衡的工具

添加的内容见上图.

server=>location=>s18django=>upstream里边的两个地址,默认是轮询的方式查找.

需要的是128和130应该是一样的代码,

保存退出

两种检查配置是否正确的方式

下面,我们打开修改一下

找到第59行

在代理前面,加上请求头和分号

保存,退出

这个时候,我们就测试成功了

下面我们将130的服务器的防火墙关上,nginx打开

访问浏览器的130服务器,得到下面的界面

129的防火墙也关上,我们再访问129服务器

再次刷新得到下面的结果:

128和130里边的来回走

如果出不来可以在"负载服务器上"重新加载一下

再次在浏览器中访问:http://192.168.34.129/

可以在128和130服务器之间来回跳转

下面我们开始查看129日志,看一下地址的流向

上图最后一行,运行进入日志

我们查看128的日志

130也开始日志

这个时候,我们对三者都开启了日志监控

老师讲解的通过yum安装的nginx就不在opt下面,在下图所示的地址

流程:

浏览器(1)==>服务器129==>服务器128

新开一个客户端,自己给自己发消息

得到这个地址,130也得到信息

130服务器没有

再次请求:

这个时候只有129和130接到了请求

curl相当于浏览器发起一个请求

下面我们看下反向代理和负载均衡//server和upstream是平级关系

重点:

3.配置关键点如下:

129负载均衡配置修改nginx.conf如下

添加的负载均衡地址池的参数:默认是轮询方式,两台服务器

添加反向代理参数如下

4.配置完毕后,重启nginx,检测负载均衡效果

访问192.168.226.129这个负载均衡器它会默认轮询的,丢给upstream中的两个地址,每人一次

这个proxy_pass里边的地址http://s18django  指向的是上边的upstream

5.nginx负载均衡的算法

    .nginx负载均衡的算法
.轮询方式
.加权轮询
upstream s18django {
server 192.168.226.128 weight=;
server 192.168.226.130 weight=;
}
.ip_hash方式,对你的ip地址进行哈希,ip_hash方式不得与权重共用 upstream s18django {
server 192.168.226.128;
server 192.168.226.130;
ip_hash;
}

第一点:轮询方式

第二点:加权轮询,也就是在负载均衡后边加上  weight=参数(数字).

保存退出,平滑加载一下

"我该睡了"就出现了4次,nginx页面出现1次

访问四次"天天想你",再出现"html"

第三点:ip_hash方式,对你的ip地址进行哈希.

  注意:ip_hash方式不得与权重共用

用法,见下图,只需要将权重信息删除,加上ip_hash

保存退出,重新加载

这个时候,再次访问,就只是一个界面了,访问浏览器或者在服务器上测试,只是一个结果:

换一台机器,结果可能发生变化.

最少链接数和url哈希

2.

3.

巨蟒python全栈开发linux之centos6 第二篇的更多相关文章

  1. 巨蟒python全栈开发linux之centos6

    1.nginx复习 .nginx是什么 nginx是支持反向代理,负载均衡,且可以实现web服务器的软件 在129服务器中查看,我们使用的是淘宝提供的tengine,也是一种nginx服务器 我们下载 ...

  2. 巨蟒python全栈开发linux之centos3

    1.作业讲解 (1)递归创建文件夹/tmp/oldboy/python/{alex,wusir,nvshen,xiaofeng} 下面中的路径没有必要换,在哪里创建都行,根目录下或者tmp目录下或者其 ...

  3. 巨蟒python全栈开发linux之centos1

    1.linux服务器介绍 2.linux介绍 3.linux命令学习 linux默认有一个超级用户root,就是linux的皇帝 注意:我的用户名是s18,密码是centos 我们输入密码,点击解锁( ...

  4. 巨蟒python全栈开发linux之centos2

    1.一些命令回顾 在vm中,右击"打开终端",输入命令ifconfig,得到的下图算是一个终端,并且我们可以看到服务器的ip是192.168.34.128 我们通过windows上 ...

  5. 巨蟒python全栈开发linux之cento9

    1.docker入门学习 查看机器中已经启动的所有的进程. ps -ef 2.docker常用命令学习 3.docker学习3 4.dockerfile与镜像 5.docker私有仓库 6.rabbi ...

  6. 巨蟒python全栈开发linux之centos7

    1.crm项目部署回顾(小BOSS) crm部署 nginx+uwsgi+django+mysql nginx    前端 uwsgi+django     后端 mysql   数据支撑 crm是一 ...

  7. 巨蟒python全栈开发linux之centos5

    1.nginx安装使用 2.nginx访问日志和压测命令 3.nginx反向代理配置 nginx的404页面 访问:淘宝官网的一个错误地址:http://taobao.com/eeeeeeee 淘宝的 ...

  8. 巨蟒python全栈开发linux之centos4

    1.linux虚拟环境1-4 2.linux运行crm代码

  9. 巨蟒python全栈开发linux之cento8

    1.复习路飞部署学习 2.mysql数据库远程访问 3.mysql主从复制 4.redis安全方式启动 5.redis数据类型 6.redis发布订阅 7.redis持久化 8.redis哨兵 9.r ...

随机推荐

  1. Odoo8在TreeView左上角增加自定义按钮以及通过继承生成自定义的View_Mode

    今天有网友在问怎么在TreeView左上角增加一个自定义的按钮,在查询Odoo 自带的模块,发现在purchase_requisition中有使用,并且此模块还应用到了自定义View_Mode的情况, ...

  2. activiti入门3排他网关,并行网管,包括网关,事件网关

    网关用来控制流程的流向 网关能够消费也能够生成token. 网关显示成菱形图形,内部有有一个小图标. 图标表示网关的类型. 基本分支 首先 利用 流程变量  写个带有分支的一个基本流程 流程图: wa ...

  3. 用BSF + Beanshell使Java程序能够运行字符串形式的代码(转载)

    BSF(Bean Scripting Framework)最初是IBM Alpha工作组的项目,后来贡献给了Apache,BSF使Java能够更好的与各种流行脚本语言整合,实现不同语言之间的交互功能. ...

  4. Python中json.loads解析包含\n的字符串会出错

    用python中的json.loads解析字符串,失败了. [解决过程] 1.调试了半天,终于发现,如果把其中的: "呵呵加那么多连接啊\n\n这个标准还是不错的\n\n给大家推荐一个更多的 ...

  5. webpack打包vue2.0项目时必现问题(转载)

    原文地址:http://www.imooc.com/article/17868 [Vue warn]: You are using the runtime-only build of Vue wher ...

  6. vb调试dll

    1.有两个工程BW_DetectCard.vbp(生成dll)及识别卡检测软件.vbp(生成exe) 2.打开工程<识别卡检测软件.vbp>,在文件--添加工程--现存,找到要引用的dll ...

  7. Atitit.java相比c#.net的优点 优缺点  v2 q330

    Atitit.java相比c#.net的优点 优缺点  v2 q330 1. 跨平台可在LINUX上,mac跑以外.主要如下: 1 2. IDE ECLIPSE(500m)是绿色的,换机器不用安装,C ...

  8. Closure闭包示例

    var foo = function(){ var cnt = 0; return function(){ return cnt++; }; }; var closure = foo(); conso ...

  9. Shell脚本与vi编辑器:vi启动与退出、工作模式、命令大全

    Vi简介 Vi是一种广泛存在于各种UNIX和Linux系统中的文本编辑程序. Vi不是排版程序,只是一个纯粹的文本编辑程序. Vi是全屏幕文本编辑器,它没有菜单,只有命令. Vi不是基于窗口的,所以, ...

  10. 使用spring-boot-maven-plugin打包

    <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> ...