日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > php >内容正文

php

PHP高并发高负载系统架构

發布時間:2025/3/8 php 41 豆豆
生活随笔 收集整理的這篇文章主要介紹了 PHP高并发高负载系统架构 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

2019獨角獸企業重金招聘Python工程師標準>>>

一、高并發和高負載的約束條件

  • 硬件

  • 部署

  • 操作系統

  • Web 服務器

  • PHP

  • MySQL

  • 測試

  • 二、解決之道——硬件篇

    處理能力的提升:部署多顆CPU,選擇多核心、具備更高運算頻率、更大高速緩存的CPU;

    處理能力的提升最直接的反應在于Web請求的處理效率和PHP程序的執行效率。

    內存帶寬與容量:更大的內存帶寬和容量;

    內存帶寬與容量的提升最直接的反應在于應對數據庫大量的數據交換。

    磁盤搜索與I/O能力:選擇更高的轉速、更大的硬盤緩存、組件磁盤陣列(RAID);

    磁盤搜索與I/O能力的提升最直接反應在于數據庫大量的查詢和讀寫以及文件的讀寫。

    網絡帶寬的提升可考慮的因素包括: 更大帶寬、多線路接入、獨享帶寬;

    服務器在大負載的情況下,對網絡帶寬的占用是十分可觀的。

    策略:硬件設施是應對大負載的基礎,硬件設施的投入可根據實際壓力和預算量力而行。

    ?

    三、解決之道——部署篇

    3.1、服務器分離

    32、數據庫集群和庫表散列

    3.3、鏡像

    3.4、負載均衡

    ?

    分類:

    1)、DNS輪循

    2)代理服務器負載均衡

    3)地址轉換網關負載均衡

    4)NAT負載均衡

    5)反向代理負載均衡

    6)混合型負載均衡

    策略:根據硬件投入和業務需求,選擇合理的部署方案。

    ?

    部署方案1

    適用范圍:靜態內容為主體的網站和應用系統;對系統安全要求較高的網站和應用系統。

    Main Server:主服務器

    承載程序的主體運行壓力,處理網站或應用系統中的動態請求;

    將靜態頁面推送至多個發布服務器;

    將附件文件推送至文件服務器;

    安全要求較高,以靜態為主的網站,可將服務器置于內網屏蔽外網的訪問。

    ?

    DB Server:數據庫服務器

    承載數據庫讀寫壓力;

    只與主服務器進行數據量交換,屏蔽外網訪問。

    ?

    File/Video Server:文件/視頻服務器

    承載系統中占用系統資源和帶寬資源較大的數據流;

    作為大附件的存儲和讀寫倉庫;

    作為視頻服務器將具備視頻自動處理能力。

    ?

    發布服務器組:

    只負責靜態頁面的發布,承載絕大多數的Web請求;

    通過Nginx進行負載均衡部署。

    ?

    部署方案2:

    適用范圍:以動態交互內容為主體的網站或應用系統;負載壓力較大,且預算比較充足的網站或應用系統;

    ?

    Web服務器組:

    Web服務無主從關系,屬平行冗余設計;

    通過前端負載均衡設備或Nginx反向代理實現負載均衡;

    劃分專用文件服務器/視頻服務器有效分離輕/重總線;

    每臺Web服務器可通過DEC可實現連接所有數據庫,同時劃分主從。

    ?

    數據庫服務器組:

    相對均衡的承載數據庫讀寫壓力;

    通過數據庫物理文件的映射實現多數據庫的數據同步。

    共享磁盤/磁盤陣列

    將用于數據物理文件的統一讀寫

    用于大型附件的存儲倉庫

    通過自身物理磁盤的均衡和冗余,確保整體系統的IO效率和數據安全;

    ?

    方案特性:

    通過前端負載均衡,合理分配Web壓力;

    通過文件/視頻服務器與常規Web服務器的分離,合理分配輕重數據流;

    ?

    通過數據庫服務器組,合理分配數據庫IO壓力;

    每臺Web服務器通常只連接一臺數據庫服務器,通過DEC的心跳檢測,可在極短時間內自動切換至冗余數據庫服務器;

    磁盤陣列的引入,大幅提升系統IO效率的同時,極大增強了數據安全性。

    ?

    四、解決之道——環境篇

    41、操作系統

    操作系統的選擇,關注點在于

    ?是否適應于搭建SiteEngine所需要的環境程序?

    ?系統本身占用的資源比;

    ?系統安全性;

    ?系統是否易于操作?

    策略:我們選擇FreeBSD,而且是最小化安裝以后的FreeBSD。

    ?

    4.2、Web服務器

    Web服務器很大一部分資源占用來自于處理Web請求,通常情況下這也就是Apache產生的壓力,Apache是世界使用排名第一的Web服務器軟件。它可以運行在幾乎所有廣泛使用的計算機平臺上。

    ?

    在高并發連接的情況下,Nginx是Apache服務器不錯的替代品。Nginx (“engine x”) 是俄羅斯人編寫的一款高性能的 HTTP 和反向代理服務器。在國內,已經有新浪、搜狐通行證、網易新聞、網易博客、金山逍遙網、金山愛詞霸、校內網、YUPOO相冊、豆瓣、迅雷看看等多家網站、 頻道使用 Nginx 服務器。

    ?

    Nginx的優勢:

    高并發連接:官方測試能夠支撐5萬并發連接,在實際生產環境中跑到2~3萬并發連接數。

    內存消耗少:在3萬并發連接下,開啟的10個Nginx 進程才消耗150M內存(15M*10=150M)。

    內置的健康檢查功能:如果 Nginx Proxy 后端的某臺 Web 服務器宕機了,不會影響前端訪問。

    策略:相對于老牌的Apache,我們選擇Lighttpd和Nginx這些具有更小的資源占用率和更高的負載能力的web服務器。

    ?

    4.3、Mysql

    MySQL本身具備了很強的負載能力,MySQL優化是一項很復雜的工作,因為這最終需要對系統優化的很好理解。數據庫工作就是大量的、短時的查詢 和讀寫,除了程序開發時需要注意建立索引、提高查詢效率等軟件開發技巧之外,從硬件設施的角度影響MySQL執行效率最主要來自于磁盤搜索、磁盤IO水 平、CPU周期、內存帶寬。

    ?

    根據服務器上的硬件和軟件條件進行MySQl優化。MySQL優化的核心在于系統資源的分配,這不等于無限制的給MySQL分配更多的資源。

    在MySQL配置文件中最值得關注的參數:

    l???????? 改變索引緩沖區長度(key_buffer)

    l???????? 改變表長(read_buffer_size)

    l???????? 設定打開表的數目的最大值(table_cache)

    l???????? 對緩長查詢設定一個時間限制(long_query_time)

    ?

    如果條件允許 ,一般MySQL服務器安裝在Linux操作系統中,而不是安裝在FreeBSD中。

    ?

    策略: MySQL優化需要根據業務系統的數據庫讀寫特性和服務器硬件配置,制定不同的優化方案,并且可以根據需要部署MySQL的主從結構。

    ?

    4.4、PHP

    1、加載盡可能少的模塊;

    2、安裝加速器(都是通過緩存php代碼預編譯的結果和數據庫結果來提高php代碼的執行速度)

    ?

    eAccelerator

    eAccelerator是一個自由開放源碼php加速器,優化和動態內容緩存,提高了性能php腳本的緩存性能,使得PHP腳本在編譯的狀態下,對服務器的開銷幾乎完全消除。

    ?

    Apc

    Alternative PHP Cache(APC)是 PHP 的一個免費公開的優化代碼緩存。它用來提供免費,公開并且強健的架構來緩存和優化 PHP 的中間代碼。

    ?

    memcache

    memcache是由Danga Interactive開發的,高性能的,分布式的內存對象緩存系統,用于在動態應用中減少數據庫負載,提升訪問速度。主要機制是通過在內存里維護一個統 一的巨大的hash表,Memcache能夠用來存儲各種格式的數據,包括圖像、視頻、文件以及數據庫檢索的結果等

    策略: 為PHP安裝加速器。

    ?

    4.5、代理服務器(緩存服務器)

    Squid Cache(簡稱為Squid)是一個流行的自由軟件(GNU通用公共許可證)的代理服務器和Web緩存服務器。Squid有廣泛的用途,從作為網頁服務 器的前置cache服務器緩存相關請求來提高Web服務器的速度,到為一組人共享網絡資源而緩存萬維網,域名系統和其他網絡搜索,到通過過濾流量幫助網絡 安全,到局域網通過代理上網。Squid主要設計用于在Unix一類系統運行。

    ?

    策略:安裝Squid 反向代理服務器,能夠大幅度提高服務器效率。

    ?

    5、解決之道——SiteEngine

    SiteEngine(網站引擎)是指針對應用系統程序的架構設計的一套程序化語言框架。目前最主流的是基于多層架構,分級處理,模塊化設計的框架,支持mvc動態頁面展示,核心程序分層處理,增加靜態化引擎,借助ajax 異步高效處理請求。

    ?

    6、解決之道——測試篇

    ?

    6.1、測試方法

    6.2、測試用例

    6.3、壓力測試

    壓力測試是一種基本的質量保證行為,它是每個重要軟件測試工作的一部分。壓力測試的基本思路很簡單:不是在常規條件下運行手動或自動測試,而是在計 算機數量較少或系統資源匱乏的條件下運行測試。通常要進行壓力測試的資源包括內部內存、CPU 可用性、磁盤空間和網絡帶寬等。一般用并發來做壓力測試。

    ?

    壓力測試工具:webbench,ApacheBench等

    ?

    6.4、漏洞測試

    在我們的系統中漏洞主要包括:sql注入漏洞,xss跨站腳本攻擊等。安全方面還包括系統軟件,如操作系統漏洞,mysql、apache等的漏洞,一般可以通過升級來解決。


    轉載于:https://my.oschina.net/angelangel/blog/338456

    總結

    以上是生活随笔為你收集整理的PHP高并发高负载系统架构的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。