IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> PHP知识库 -> 饿了吗?一饱眼福-不能不懂的web网站负载均衡群集 -> 正文阅读

[PHP知识库]饿了吗?一饱眼福-不能不懂的web网站负载均衡群集

理论

提示:运维面试常问题
1、以负载均衡的方式搭建网站有哪些技术?

Nginx:反向代理,适用于中小型网站服务

		优点:
			工作在七层之上,针对HTTP做分流策略,正则规则haproxy更灵活
			对网络的稳定性依赖小
			安装配置简单
			高负载高并发低消耗
			不仅能做代理,还可以做web服务器
			还能缓存静态网页和图片
			社区活跃,第三方模块非常多
			
		缺点:
			适应范围较小,仅能支持http、https、Email协议。
			对后端服务器的健康检查,只支持通过端口检测,不支持url来检测。

haproxy:适用于中小型网站服务

		优点:	
			HAProxy是支持虚拟主机的,可以工作在4、7层(支持多网段)
			HAProxy的优点能够补充Nginx的一些缺点,比如支持Session的保持,Cookie的引导;同时支持通过获取指定的url来检测后端服务器的状态。
			HAProxy跟LVS类似,本身就只是一款负载均衡软件;单纯从效率上来讲HAProxy会比Nginx有更出色的负载均衡速度,在并发处理上也是优于Nginx的。
			HAProxy支持TCP协议的负载均衡转发,可以对MySQL读进行负载均衡,对后端的MySQL节点进行检测和负载均衡
			HAProxy负载均衡策略非常多,HAProxy的负载均衡算法现在具体有8种
		缺点:
			不支持POP/SMTP协议
			不支持SPDY协议
			不支持HTTP cache功能
			重载配置的功能需要重启进程
			多进程模式支持不够好

lvs: Linux virtual service的简称,Linux虚拟化服务,适用于大型网站服务

		优点:   
			抗负载能力强、是工作在网络4层之上仅作分发之用   
			配置性比较低,这是一个缺点也是一个优点,简单不易出错
			工作稳定,抗负载能力很强,有完整的双机热备方案,如LVS(DR)+ Keepalived。
			无流量,LVS只分发请求,而流量并不从它本身出去
			应用范围比较广,几乎支持所有应用
			常用的调度算法: rr轮询   wrr加权轮询   lc最小连接数   wlc加权最小连接数 
		缺点:
			不支持正则表达式处理,不能做动静分离
			网站应用比较庞大的话,LVS/DR+Keepalived实施起来比较复杂

2、nginx的基础特性:

模块化设计,较好的扩展性
高可靠性
支持热部署,不停机更新配置文件,升级版本,更换日志文件
低内存消耗,10000个keep-alive下的非活动连接,仅需2.5M内存
event-driven(事件驱动),aio(异步非阻塞),mmap(内存映射),sendfile(代理转发)

3、基本功能:

静态资源的web服务器
http协议的反向代理
fastcgi、uWSGI(python)
pop3/imap4邮件反向代理
模块化,zip、ssl等模块

4、nginx进程结构:**

Master/Worker 结构:一个 master 进程,生成一个或多个 worker 进程。
master:
读取nginx配置文件,验证有效性和正确性
建立、绑定和关闭socket连接
接受外界指令,比如重启、开、关服务
不中断服务,平滑升级
处理perl脚本

worker:
接受处理客户的请求(按模块区分)
I/O调用
与后端服务器通信
缓存数据
发送请求结果
接受主程序的指令

5、nginx模块:

核心模块:core module
标准模块:
ngx_http_*
ngx_mail_*
ngx_upstream_*
第三方模块:


案例:

源码安装负载均衡,yum安装nginx网站节点,修改节点的默认首页,客户端访问验证。
配置负载均衡服务器追踪客户端的原始ip,启用nginx缓存。

1、 搭建环境
关闭防火墙或配置安全策略,
2、 安装前提软件(用命令检查,仅安装需要但本机未安装的)
请添加图片描述
3、 复制nginx和缓存包到/usr/src,解压

创建Nginx用户:
useradd -s /sbin/nologin nginx

解压:
cd /usr/src
tar xf nginx-goodies-nginx-sticky-module-ng-08a395c66e42.tar.gz
tar xf ngx_cache_purge-2.3.tar.gz
tar xf nginx-1.12.0.tar.gz

4、 进入目录,编译安装nginx

cd /usr/src/nginx-1.12.0
	./configure --prefix=/usr/local/nginx --user=nginx --group=nginx \
--with-http_stub_status_module --with-http_realip_module --with-http_ssl_module \
--with-http_gzip_static_module --http-client-body-temp-path=/var/tmp/nginx/client \
--http-proxy-temp-path=/var/tmp/nginx/proxy --http-fastcgi-temp-path=/var/tmp/nginx/fcgi \
--with-pcre --add-module=../ngx_cache_purge-2.3 --with-http_flv_module \
--add-module=../nginx-goodies-nginx-sticky-module-ng-08a395c66e42 \
&& make && make install

安装成功如下图:
在这里插入图片描述
命令验证:
在这里插入图片描述

5、添加nginx系统服务并启动

ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/
mkdir -p /var/tmp/nginx/client
chown -R nginx:nginx /var/tmp/nginx

vim /etc/init.d/nginx

#!/bin/bash
# chkconfig: 2345 99 20
# description: Nginx Service Control Script
PROG="/usr/local/nginx/sbin/nginx"
PIDF="/usr/local/nginx/logs/nginx.pid"
case "$1" in
 start)
 netstat -anplt |grep ":80" &> /dev/null && pgrep "nginx" &> /dev/null
 if [ $? -eq 0 ]
 then
 echo "Nginx service already running."
 else
 $PROG -t &> /dev/null
 if [ $? -eq 0 ] ; then 
 $PROG
 echo "Nginx service start success."
 else
 $PROG -t
 fi
 fi
 ;;
 stop)
 netstat -anplt |grep ":80" &> /dev/null && pgrep "nginx" &> /dev/null
 if [ $? -eq 0 ]
 then
 kill -s QUIT $(cat $PIDF)
 echo "Nginx service stop success." 
 else
 echo "Nginx service already stop"
 fi
 ;;
 restart)
 $0 stop
 $0 start
 ;;
 status)
 netstat -anplt |grep ":80" &> /dev/null && pgrep "nginx" &> /dev/null
 if [ $? -eq 0 ]
 then
 echo "Nginx service is running."
 else
 echo "Nginx is stop."
 fi
 ;; 
 reload)
 netstat -anplt |grep ":80" &> /dev/null && pgrep "nginx" &> /dev/null
 if [ $? -eq 0 ]
 then
 $PROG -t &> /dev/null
 if [ $? -eq 0 ] ; then
 kill -s HUP $(cat $PIDF)
 echo "reload Nginx config success."
 else
 $PROG -t
 fi
 else
 echo "Nginx service is not run." 
 fi 
 ;;
 *)
 echo "Usage: $0 {start|stop|restart|reload}"
 exit 1
esac

6、配置反向代理和缓存

(1)lb负载均衡服务器的配置:IP填自己的节点web
在这里插入图片描述
在这里插入图片描述
验证:不加sticky,访问来回切换,是每个web提供服务;
加上,第一次访问哪个服务器提供服务,以后会一直保持这个


  PHP知识库 最新文章
Laravel 下实现 Google 2fa 验证
UUCTF WP
DASCTF10月 web
XAMPP任意命令执行提升权限漏洞(CVE-2020-
[GYCTF2020]Easyphp
iwebsec靶场 代码执行关卡通关笔记
多个线程同步执行,多个线程依次执行,多个
php 没事记录下常用方法 (TP5.1)
php之jwt
2021-09-18
上一篇文章      下一篇文章      查看所有文章
加:2021-09-03 11:40:27  更:2021-09-03 11:40:30 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/15 10:40:36-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码