Linux的负载均衡详解

Linux的负载均衡详解,第1张

Linux的负载均衡常用的有三种技术:中国人搞出来的大神级产品 LVS Linux Virtual Server,俄罗斯的Nginx,来发法国的HAProxy。都是基于Linux的开源免费的负载均衡软件。

1. 抗负载能力强,性能高,能达到F5的60%,对内存和CPU资源消耗比较低

2. 工作在网络4层,通过VRRP协议(仅作代理之用),具体的流量是由linux内核来处理,因此没有流量的产生。

3. 稳定,可靠性高,自身有完美的热备方案(Keepalived+lvs)

4. 不支持正则处理,不能做动静分离。

5. 支持多种负载均衡算法:rr(轮询),wrr(带权轮询)、lc(最小连接)、wlc(带权最小连接)

6. 配置相对复杂,对网络依赖比较大,稳定性很高。

7. LVS工作模式有4种:

    (1) nat 地址转换

    (2) dr 直接路由

    (3) tun 隧道

    (4) full-nat

1. 工作在网络7层,可以针对http应用做一些分流的策略,比如针对域名,目录结构

2. Nginx对网络的依赖较小,理论上能ping通就能进行负载功能

3. Nginx安装配置比较简单,测试起来很方便

4. 也可以承担较高的负载压力且稳定,nginx是为解决c10k问题而诞生的

5. 对后端服务器的健康检查,只支持通过端口来检测,不支持通过url来检测

6. Nginx对请求的异步处理可以帮助节点服务器减轻负载压力

7. Nginx仅能支持http、https和Email协议,这样就在适用范围较小。

8. 不支持Session的直接保持,但能通过ip_hash来解决。对Big request header的支持不是很好。

9. Nginx还能做Web服务器即Cache功能。

1.支持两种代理模式:TCP(四层)和HTTP(七层),支持虚拟主机;

2.能够补充Nginx的一些缺点比如Session的保持,Cookie的引导等工作

3.支持url检测后端的服务器出问题的检测会有很好的帮助。

4.更多的负载均衡策略比如:动态加权轮循(DynamicRoundRobin),加权源地址哈希(Weighted SourceHash),加权URL哈希和加权参数哈希(WeightedParameterHash)已经实现

5.单纯从效率上来讲HAProxy更会比Nginx有更出色的负载均衡速度。

6.HAProxy可以对Mysql进行负载均衡,对后端的DB节点进行检测和负载均衡。

7.支持负载均衡算法:Round-robin(轮循)、Weight-round-robin(带权轮循)、source(原地址保持)、RI(请求URL)、rdp-cookie(根据cookie)

8.不能做Web服务器即Cache。

1. 负载能力

lvs抗负载能力最强,因为仅作分发不处理请求,相当于只作转发不做进一步处理直接在内核中完成,对系统资源消耗低(LVS DR模式);

nginx和haproxy相对来说会弱,但是日PV2000万也没什么问题,因为不仅接受客户端请求,还与后端upstream节点进行请求并获取响应,再把响应返回给客户端,对系统资源和网络资源消耗高;

注:建议如果公司网站流量日PV在2000万以上,并发在7,8万以上才考虑用lvs+keepalived架构

2. 功能性

lvs仅支持4层tcp负载均衡,haproxy可以支持4层tcp和7层http负载均衡,nginx可以支持7层http负载均衡(新版本也支持7层负载均衡);

nginx功能强大,配置灵活,可做web静态站点,静态缓存加速,动静分离,并支持域名,正则表达式,Location匹配,rewrite跳转,配置简单直观明了,还可以结合etc或consule做发布自动化上下线等等;

haproxy相对nginx的7层负载均衡会弱一些,灵活性不足,个人建议一般用haproxy做TCP负载均衡更合适一些;

3. 运维复杂度

lvs相对来说部署架构更复杂一些,lvs对网络是有要求,lvs必须与real server在同一个网段,也更费资源,需要多2台服务器成本;

nginx和haproxy部署架构更简单,对网络也没要求,更便于后续维护;

像对于大型的,需要进行高并发的网站或者对网络不太严格的时候,可以使用nginx;

对于大型的Web服务器的时候可以使用haproxy;

对性能有严格要求的时候可以使用lvs,就单纯从负载均衡的角度来说,lvs也许会成为主流,更适合现在大型的互联网公司。

注:lvs,nginx,haproxy要实现高可用,都需要借助keepalived软件

按照这个路线图学习就好了

Linux云计算运维到底要学哪些东西?

1.Linux基础

1.Linux企业级安装(kickstart,cobbler批量安装)

Centos7

互联网企业

麒麟Linux

传统企业国企事业单位央企,少量互联网公司

ubuntu20.04

程序员主导互联网公司

2.企业级优化

3.常用命令

01.目录命令

cd/pwd/ls/cp/mv/rm -fr/mkdir

02.文件命令

touch/cat/echo/less/more/head/tail/sed/awk/grep/egrep/find/which/where

03.用户命令

useradd,usermod,userdel,passwd,chpasswd,chage,su,sudo,visudo

04.权限命令

chown/chmod/chattr/lsattr

05.基本命令

reboot,halt,shutdown,init,uname,hostname

06.网络命令

ifconfig/ip/arp/ifup/ifdown/netstat/ss/lsof/nc/nmap/tcpdump

07.监测资源

top/uptime/iostat/iftop/htop/sar/vmstat

08.磁盘管理

fdisk/parted/mkfs/mount/umount

09.Linux三剑客

grep/egrep/sed/awk

4.常用知识

1.文件、目录及属性

2.用户管理

3.权限管理

4.网络管理

5.正则表达式

6.定时任务

7.磁盘管理

8.安装系统

5.基础网络服务

NFS网络文件系统、Ceph分布式文件系统

rsync异地同步

sersync异地实时同步

nginx web(Apache)

php-fpm/tomcat/python/go动态服务

mysql/redis/mongodb/es搜索

nginx/lvs/haproxy

hearbeat/keepalived

安全:jumpserver/iptables/firewalld/openvpn

批量管理:ssh/ansible/saltstack

6.高级网络服务

01.代码上线CICD

svn/git/gitlab

jenkins

maven/ant编译工具

jira

02.分布式日志收集

ELFK分布式日志收集集群

03.监控

ZABBIX

普罗米修斯

04.云计算

KVM/OPENSTACK(过时了,又难又不好学)

05.容器技术

docker+k8s(必会)

微服务

7.DBA课程专业中级水平(15K)

mysql

redis

monbodb

es

8.DEVOPS自动化

bash shell

python基础

go基础

01.代码上线CICD

svn/git/gitlab

jenkins

maven/ant编译工具

jira

9.kafka消息队列/ceph分布式存储/zookeper

10.安全、python、go一部分内容

11.详细就业指导

年龄大

年龄小

学历低

没经验


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/8549790.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-17
下一篇 2023-04-17

发表评论

登录后才能评论

评论列表(0条)

保存