千万级PV网站架构

2024-05-07 09:38
文章标签 网站 架构 千万级 pv

本文主要是介绍千万级PV网站架构,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1 架构背景

        CleverCode了解了一下架构。现在的情况是:一共约有50台服务器,安装的服务nginx,mysql,memcached,squid,solor等。
现在日均纯PHP访问的PV是2500万,最高峰值可以抗住5000万访问。

       以下只列出来一些常用域名,部分访问域名未列出来,其中的机器也只列出来部分。


2 架构原理图



3 架构原理说明

3.1 LVS部分

1)首先让所有的域名都通过DNS指向211.181.168.168。211.181.168.168是一个外网IP。对于LVS结构来说他是一个虚拟IP。
   这个ip可以配置到eth0:1(一个网卡多个ip),禁止登陆用。eth0(211.181.168.151)的ip用于登陆。
   
2)当请求到了VIP之后,LVS会进行负载均衡,通过IP隧道将请求发送到某一个实际的服务器上,即(192.168.1.100,192.168.1.101,192.168.1.102)其中一个上。
   LVS的负载均衡时IP层的负载均衡,速度特别快,给服务器的压力也特别小。

说明:
   211.181.168.168通常只用与负载均衡用,尽量不要安装其他的服务,比如mysql。可以用配置较低的服务器当VIP。 


3.2 Nginx反向代理负载均衡

3)192.168.1.100,192.168.1.101,192.168.1.102是三台Nginx反向代理服务器。三台机器的nginx配置完全一样。
4)当请求到达比如192.168.1.102后,nginx会根据请求的域名做负载均衡。这时候可以使一组域名,用同一个upstream。upstream中的服务器可以根据配置设置权重。
5)如果访问的是css,js,图片,可以负载均衡到squid服务器。

说明:
   三台RealServer,也尽量不要安装其他的服务,比如mysql。也可以用配置较低的服务器当RealServer。 

3.3 squid透明代理

6)squid服务器收到js,css,images请求后,首先看自己的缓存是否命中,如有命中再去后面的nginx源站中去取数据,然后在缓存一份。
7)squid取数据的时候可以根据域名做透明的反向代理。


说明:

   squid服务器尽量配置2台,每台服务器都缓存,同一个图片会被缓存2次。防止一台挂掉后,静态资源访问不了。squid软件需要占用80端口,所以不能安装nginx服务。

这篇关于千万级PV网站架构的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/966989

相关文章

Knife4j+Axios+Redis前后端分离架构下的 API 管理与会话方案(最新推荐)

《Knife4j+Axios+Redis前后端分离架构下的API管理与会话方案(最新推荐)》本文主要介绍了Swagger与Knife4j的配置要点、前后端对接方法以及分布式Session实现原理,... 目录一、Swagger 与 Knife4j 的深度理解及配置要点Knife4j 配置关键要点1.Spri

MyBatisPlus如何优化千万级数据的CRUD

《MyBatisPlus如何优化千万级数据的CRUD》最近负责的一个项目,数据库表量级破千万,每次执行CRUD都像走钢丝,稍有不慎就引起数据库报警,本文就结合这个项目的实战经验,聊聊MyBatisPl... 目录背景一、MyBATis Plus 简介二、千万级数据的挑战三、优化 CRUD 的关键策略1. 查

mysql中的服务器架构详解

《mysql中的服务器架构详解》:本文主要介绍mysql中的服务器架构,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、mysql服务器架构解释3、总结1、背景简单理解一下mysqphpl的服务器架构。2、mysjsql服务器架构解释mysql的架

k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)

《k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)》本文记录在K8s上运行的MySQL/MariaDB备份方案,通过工具容器执行mysqldump,结合定时任务实... 目录前言一、获取需要备份的数据库的信息二、备份步骤1.准备工作(X86)1.准备工作(arm)2.手

如何关闭Mac的Safari通知? 3招教你关闭Safari浏览器网站通知的技巧

《如何关闭Mac的Safari通知?3招教你关闭Safari浏览器网站通知的技巧》当我们在使用Mac电脑专注做一件事情的时候,总是会被一些消息推送通知所打扰,这时候,我们就希望关闭这些烦人的Mac通... Safari 浏览器的「通知」功能本意是为了方便用户及时获取最新资讯,但很容易被一些网站滥用,导致我们

Web技术与Nginx网站环境部署教程

《Web技术与Nginx网站环境部署教程》:本文主要介绍Web技术与Nginx网站环境部署教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、Web基础1.域名系统DNS2.Hosts文件3.DNS4.域名注册二.网页与html1.网页概述2.HTML概述3.

Maven 插件配置分层架构深度解析

《Maven插件配置分层架构深度解析》:本文主要介绍Maven插件配置分层架构深度解析,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Maven 插件配置分层架构深度解析引言:当构建逻辑遇上复杂配置第一章 Maven插件配置的三重境界1.1 插件配置的拓扑

Java异常架构Exception(异常)详解

《Java异常架构Exception(异常)详解》:本文主要介绍Java异常架构Exception(异常),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. Exception 类的概述Exception的分类2. 受检异常(Checked Exception)

nginx部署https网站的实现步骤(亲测)

《nginx部署https网站的实现步骤(亲测)》本文详细介绍了使用Nginx在保持与http服务兼容的情况下部署HTTPS,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值... 目录步骤 1:安装 Nginx步骤 2:获取 SSL 证书步骤 3:手动配置 Nginx步骤 4:测

MySQL 缓存机制与架构解析(最新推荐)

《MySQL缓存机制与架构解析(最新推荐)》本文详细介绍了MySQL的缓存机制和整体架构,包括一级缓存(InnoDBBufferPool)和二级缓存(QueryCache),文章还探讨了SQL... 目录一、mysql缓存机制概述二、MySQL整体架构三、SQL查询执行全流程四、MySQL 8.0为何移除查