转载请注明出处:

1.nginx如何自定义负载均衡

  在Nginx中,可以通过配置文件自定义负载均衡策略。具体步骤如下:

  1. 首先,在Nginx配置文件中定义一个upstream模块,并设置负载均衡策略和后端服务器列表,例如:

upstream myapp {
server backend1.example.com weight=3;
server backend2.example.com;
server backend3.example.com;
hash $remote_addr consistent;
}

  其中,myapp是一个自定义的upstream名称,backend1.example.com、backend2.example.com、backend3.example.com是后端服务器的地址或域名。weight=3表示给backend1.example.com设置权重为3,而backend2.example.com和backend3.example.com的权重默认为1。hash $remote_addr consistent表示采用基于客户端IP地址的一致性哈希算法进行负载均衡。

  2. 然后,在server模块中配置具体的代理规则,将请求代理到upstream中定义的服务器列表中,例如:

server {
listen 80;
server_name example.com;
location / {
proxy_pass http://myapp;
}
}

   其中,proxy_pass http://myapp 表示将请求代理到myapp定义的服务器列表中进行负载均衡。

  3. 最后,重新加载Nginx配置文件,使其生效:

sudo nginx -s reload

  需要注意的是,Nginx支持多种负载均衡策略,例如轮询(默认)、IP哈希、URL哈希、加权轮询等。可以根据实际情况选择不同的负载均衡策略,并根据需要调整后端服务器列表的权重等参数,以实现自定义的负载均衡策略。

2.如何自定义根据cpu的运行情况进行负载均衡配置

  可以使用Nginx的ngx_http_upstream_module模块和Lua脚本语言实现根据CPU的运行情况进行负载均衡配置。具体步骤如下:

  1. 安装ngx_http_lua_module模块,该模块提供了在Nginx中运行Lua脚本的能力。

  2. 在Nginx配置文件中定义upstream模块,并设置负载均衡策略和后端服务器列表,例如:

upstream myapp {
server backend1.example.com;
server backend2.example.com;
}

  3.在server模块中定义Lua脚本,并在其中编写根据CPU运行情况进行负载均衡的代码,例如:  

server {
listen 80;
server_name example.com;
location / {
access_by_lua_block {
local status = require "ngx.status"
local cpu = status.get_cpu()
local servers = ngx.shared.servers
local peer = servers:get(cpu)
if not peer then
local peers = {"backend1.example.com", "backend2.example.com"}
local index = cpu % #peers + 1
peer = peers[index]
servers:set(cpu, peer, 60 * 5) -- 缓存5分钟
end
ngx.var.backend = peer
}
proxy_pass http://$backend;
}
}

  4. 在Nginx配置文件中添加shared_dict指令,用于共享服务器列表和CPU状态信息:

http {
lua_shared_dict servers 1m;
lua_shared_dict status 1m;
...
}

  5.最后,重新加载Nginx配置文件,使其生效:

sudo nginx -s reload

  该方法仅仅是一个参考,真实场景下,CPU的负载情况并不是唯一的考虑因素,还需要考虑网络延迟、后端服务器的性能、负载均衡的稳定性等因素。

nginx自定义负载均衡及根据cpu运行自定义负载均衡的更多相关文章

  1. CentOS 6.5 + Nginx 1.8.0 + PHP 5.6(with PHP-FPM) 负载均衡源码安装

    CentOS 6.5 + Nginx 1.8.0 + PHP 5.6(with PHP-FPM) 负载均衡源码安装 http://www.cnblogs.com/ppoo24/p/4918288.ht ...

  2. 【官方文档】Nginx负载均衡学习笔记(二)负载均衡基本概念介绍

    简介 负载均衡(Server Load Balancer)是将访问流量根据转发策略分发到后端多台 ECS 的流量分发控制服务.负载均衡可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应 ...

  3. HHvm Apache 2.4 Nginx建站环境搭建方法安装运行WordPress博客

    HHvm Apache 2.4 Nginx建站环境搭建方法安装运行WordPress博客 VPS主机   2014年06月02日 17:20   评论»       文章目录 Debian上安装 Ce ...

  4. 服务降级 托底预案 Nginx中使用Lua脚本检测CPU使用率,当达到阀值时开启限流,让用户排队

    https://mp.weixin.qq.com/s/FZAcQQAKomGEe95kln1HCQ 在京东我们是如何做服务降级的 https://mp.weixin.qq.com/s/FZAcQQAK ...

  5. linux启动后自动登录并运行自定义图形界面程序

    在<Ubuntu CTRL+ALT+F1~F6 进入命令模式后不支持中文显示的解决办法>一文中提到linux启动在以后运行一个独占显示器的图形程序的两种办法. 1.不启动xserver,使 ...

  6. cpu使用率低负载高,原因分析

    原因总结 产生的原因一句话总结就是:等待磁盘I/O完成的进程过多,导致进程队列长度过大,但是cpu运行的进程却很少,这样就体现到负载过大了,cpu使用率低. 下面内容是具体的原理分析:在分析负载为什么 ...

  7. LVS(Linus Virtual Server):三种负载均衡方式比较+另三种负载均衡方式

    还有个姊妹篇也可以参考这个文章:六大Web负载均衡原理与实现 什么是LVS (Linux Virtual Server)?   首先简单介绍一下LVS (Linux Virtual Server)到底 ...

  8. Linux下CPU利用率和负载的关系

    1.CPU利用率和负载 CPU利用率显示的是程序在运行期间实时占用的CPU百分比:cpu使用率反映的是当前cpu的繁忙程度,忽高忽低的原因在于占用cpu处理时间的进程可能处于io等待状态但却还未释放进 ...

  9. 在kubernetes上运行WASM负载

    在kubernetes上运行WASM负载 WASM一般用在前端业务中,但目前有扩展到后端服务的趋势.本文使用Krustlet 将WASM服务部署到kubernetes. 简介 Krustlet 是一个 ...

  10. 【转】多核CPU运行模式

    多核CPU运行模式主要有以下三种: •非对称多处理(Asymmetric multiprocessing,AMP)——每个CPU内核运行一个独立的操作系统或同一操作系统的独立实例(instantiat ...

随机推荐

  1. Unity学习笔记——坐标转换(1)

    1.Center与Pivot的区别 Pivot是模型坐标轴的真实位置,将辅助图标定位在网格的实际轴心点. Center是模型渲染边界的中心. 当包含子物体时,Pivaot模式辅助图标在物体的实际轴心点 ...

  2. Django: sqlite的版本问题小记 “SQLite 3.8.3 or later”

    问题概述 在Django中,默认的数据库时SQLite3. 可能会出现sqlite版本问题的报错,具体如下 起初我直接在django的project下面开了个cmd窗口,python python m ...

  3. LeetCode刷题4:寻找两个正序数组的中位数

    题目: 给定两个大小分别为 m 和 n 的正序(从小到大)数组 nums1 和 nums2.请你找出并返回这两个正序数组的 中位数 . 算法的时间复杂度应该为 O(log (m+n)) . 来源:力扣 ...

  4. test.sh 监听进程是否存在

    监听myloader进程是否结束,结束后把时间输出到 /root/time.log vim test.sh #!/bin/bash #确保PRO查询进程唯一 PRO="myloader&qu ...

  5. python3判断ip类型

    利用socket库附带的校验功能实现校验.

  6. idea 切换database数据库方言

    在适配各种国产数据库时常常遇到存在数据库方言的情况,例如openGauss支持oracle兼容模式.. 在这种情况下,就需要在idea里对方言进行切换,否则无法执行oracle语法的sql. 1.连接 ...

  7. MySQL 导出数据结构 If you don't want to restore GTIDs, pass --set-gtid-purged=OFF.

    应用场景MYSQL导出数据结构 Warning: A partial dump from a server that has GTIDs will by default include the GTI ...

  8. Jx9嵌入式脚本语言基本用法

    Jx9是一种嵌入式脚本语言,可用于编写嵌入式脚本和扩展. 以下是一些使用Jx9的示例: 1. 计算器 Jx9可以轻松实现一个计算器.例如: ```print("Enter two numbe ...

  9. ROS节点开机自启的方法

    ROS节点开机自启的方法(Ubuntu- melodic) 一. 使用命令 sudo apt install ros-melodic-robot-upstart 安装 robot-upstart工具包 ...

  10. OVS内核流表查询过程

    概括 现在的OVS使用microflow+megaflow缓存查询流表,ovs整体流程是从ovs_vport_receive(datapath/vport.c)开始,然后进入ovs_dp_proces ...