久久精品五月,日韩不卡视频在线观看,国产精品videossex久久发布 ,久久av综合

站長資訊網
最全最豐富的資訊網站

系統講解PHP緩存技術

本篇文章給大家帶來了關于PHP的相關知識,其中主要介紹了緩存技術的相關內容,緩存已經成了項目中必不可少的一部分,是提高性能最好的方式,下面一起來看一下,希望對大家有幫助。

系統講解PHP緩存技術

概述

系統講解PHP緩存技術

緩存已經成了項目中是必不可少的一部分,它是提高性能最好的方式,例如減少網絡I/O、減少磁盤I/O 等,使項目加載速度變的更快。

緩存可以是CPU緩存、內存緩存、硬盤緩存,不同的緩存查詢速度也不一樣(CPU緩存 優于 內存緩存 優于 硬盤緩存)。

接下來,給大家逐一進行介紹。

瀏覽器緩存

瀏覽器將請求過的頁面存儲在客戶端緩存中,當訪問者再次訪問這個頁面時,瀏覽器就可以直接從客戶端緩存中讀取數據,減少了對服務器的訪問,加快了網頁的加載速度。

強緩存

用戶發送的請求,直接從客戶端緩存中獲取,不請求服務器。

根據 Expires 和 Cache-Control 判斷是否命中強緩存。

代碼如下:

header('Expires: '. gmdate('D, d M Y H:i:s', time() + 3600). ' GMT'); header("Cache-Control: max-age=3600"); //有效期3600秒
登錄后復制

Cache-Control 還可以設置以下參數:

  • public:可以被所有的用戶緩存(終端用戶的瀏覽器/CDN服務器)

  • private:只能被終端用戶的瀏覽器緩存

  • no-cache:不使用本地緩存

  • no-store:禁止緩存數據

協商緩存

用戶發送的請求,發送給服務器,由服務器判定是否使用客戶端緩存。

代碼如下:

$last_modify = strtotime($_SERVER['HTTP_IF_MODIFIED_SINCE']); if (time() - $last_modify < 3600) {    header('Last-Modified: '. gmdate('D, d M Y H:i:s', $last_modify).' GMT');    header('HTTP/1.1 304'); //Not Modified    exit; } header('Last-Modified: '. gmdate('D, d M Y H:i:s').' GMT');
登錄后復制

用戶操作行為對緩存的影響

系統講解PHP緩存技術

文件緩存

數據文件緩存

將更新頻率低,讀取頻率高的數據,緩存成文件。

比如,項目中多個地方用到城市數據做三級聯動,我們就可以將城市數據緩存成一個文件(city_data.json),JS 可以直接讀取這個文件,無需請求后端服務器。

全站靜態化

CMS(內容管理系統),也許大家都比較熟悉,比如早期的 DEDE、PHPCMS,后臺都可以設置靜態化HTML,用戶在訪問網站的時候讀取的都是靜態HTML,不用請求后端的數據庫,也不用Ajax請求數據接口,加快了網站的加載速度。

靜態化HTML有以下優點:

  • 有利于搜索引擎的收錄(SEO)

  • 頁面打開速度快

  • 減少服務器負擔

CDN緩存

CDN(Content Delivery Network)內容分發網絡。

用戶訪問網站時,自動選擇就近的CDN節點內容,不需要請求源服務器,加快了網站的打開速度。

緩存主要包括 HTML、圖片、CSS、JS、XML 等靜態資源。

NoSQL緩存

Memcached 緩存

Memcached 是高性能的分布式內存緩存服務器。

一般的使用目的是,通過緩存數據庫查詢結果,減少數據庫訪問次數,以提高動態Web應用的速度、提高可擴展性。

它也能夠用來存儲各種格式的數據,包括圖像、視頻、文件等。

Memcached 僅支持K/V類型的數據,不支持持久化存儲。

Memcache 與 Memcached 的區別

Memcached 從0.2.0開始,要求PHP版本>=5.2.0,Memcache 要求PHP版本>=4.3。

Memcached 最后發布時間為2018-12-24,Memcache 最后發布時間2013-04-07。

Memcached 基于libmemcached,Memcache 基于PECL擴展。

可以將 Memcached 看作是 Memcache 的升級版。

PHP Memcached 使用手冊:

http://www.php.net/manual/zh/book.memcached.php

Memcached 經常拿來與 Redis 做對比,接下來介紹下 Redis 緩存。

Redis緩存

Redis 是一個高性能的 K/V 數據庫。

Redis 很大程度補償了 Memcached K/V存儲的不足,比如 List(鏈表)、Set(集合)、Zset(有序集合)、Hash(散列),既可以將數據存儲在內存中,也可以將數據持久化到磁盤上,支持主從同步。

總的來說,可以將 Redis 看作是 Memcached 的擴展版,更加重量級,功能更強大。

Redis 在日常工作中使用的居多。

Redis 學習網址:http://www.redis.cn/

MongoDB緩存

MongoDB 是一個基于分布式文件存儲的數據庫。由 C++ 語言編寫。

旨在為 WEB 應用提供可擴展的高性能數據存儲解決方案。

MongoDB 是一個介于關系數據庫和非關系數據庫之間的產品,是非關系數據庫當中功能最豐富,最像關系數據庫的。

MongoDB 學習網址:http://www.mongodb.org.cn

WEB服務器緩存

Apache緩存

利用 mod_expires ,指定緩存的過期時間,可以緩存HTML、圖片、JS、CSS 等。

打開 http.conf,開啟模塊:

LoadModule expires_module modules/mod_expires.so
登錄后復制

指定緩存的過期時間:

<IfModule expires_module>     #打開緩存     ExpiresActive on     #css緩存(8640000秒=10天)     ExpiresByType text/css A8640000     #js緩存     ExpiresByType application/x-javascript A8640000     ExpiresByType application/javascript A8640000     #html緩存     ExpiresByType text/html A8640000     #圖片緩存     ExpiresByType image/jpeg A8640000     ExpiresByType image/gif A8640000     ExpiresByType image/png A8640000     ExpiresByType image/x-icon A8640000 </IfModule>
登錄后復制

Nginx緩存

利用 expire 參數,指定緩存的過期時間,可以緩存HTML、圖片、JS、CSS 等。

打開 nginx.conf :

//以圖片為例: location ~.(gif|jpg|jepg|png|bmp|ico)$ { #加入新的location    root html;    expires 1d; #指定緩存時間 }
登錄后復制

大家也可以了解下:proxycachepath 和 proxy_cache,進行緩存的設置。

Opcode緩存

Opcode(Operate Code)操作碼。

PHP程序運行完后,馬上釋放所有內存,所有程序中的變量都銷毀,每次請求都要重新翻譯、執行,導致速度可能會偏慢。

當解釋器完成對腳本代碼的分析后,便將它們生成可以直接運行的中間代碼,也稱為操作碼。

操作碼 的目地是避免重復編譯,減少CPU和內存開銷。

APC緩存

APC(Alternative PHP Cache)可選 PHP 緩存。

APC 的目標是提供一個自由、 開放,和健全的框架,用于緩存、優化 PHP 中間代碼。

APC 可以去掉 php 動態解析以及編譯的時間,使php腳本可以執行的更快。

APC 擴展最后的發布時間為 2012-09-03。

感興趣可以了解下,官方介紹:http://php.net/manual/zh/book.apc.php

eAccelerator

eAccelerator:A PHP opcode cache。

感興趣可以了解下,官方介紹:http://eaccelerator.net/

XCache

XCache 是一個又快又穩定的 PHP opcode 緩存器。

感興趣可以了解下,官方介紹:http://xcache.lighttpd.net/

小結

文章主要簡單的介紹了 瀏覽器緩存、文件緩存、NoSQL緩存、WEB服務器緩存、Opcode緩存。

每一種緩存都可以深入研究,從介紹 -> 安裝 -> 使用 -> 總結應用場景。

大家可以思考下,通過上面的介紹,工作中我們使用了哪些緩存?

還可以再使用哪些緩存,可以對我們的項目有幫助?

關于緩存的常見問題

用過緩存,大家肯定遇到過比較頭痛的問題,比如數據一致性,雪崩,熱點數據緩存,緩存監控等等。

給大家列出幾個問題,純屬拋轉引玉。

當項目中使用到緩存,我們是選擇 Redis 還是 Memcached ,為什么?

舉一些場景:

一、比如實現一個簡單的日志收集功能或發送大量短信、郵件的功能,實現方式是先將數據收集到隊列中,然后有一個定時任務去消耗隊列,處理該做的事情。

直接使用 Redis 的 lpush,rpop 或 rpush,lpop。

//進隊列 $redis->lpush(key, value); //出隊列 $redis->rpop(key); Memcached 沒有這種數據結構。
登錄后復制

二、比如我們要存儲用戶信息,ID、姓名、電話、年齡、身高 ,怎么存儲?

方案一:key => value

key = userdata用戶ID

value = json_encode(用戶數據)

查詢時,先取出key,然后進行json_decode解析。

方案二:hash

key = userdata用戶ID

hashKey = 姓名,value = xx

hashKey = 電話,value = xx

hashKey = 年齡,value = xx

hashKey = 身高,value = xx

查詢時,取出key即可。

//新增 $redis->hSet(key, hashKey, value); $redis->hSet(key, hashKey, value); $redis->hSet(key, hashKey, value); //編輯 $redis->hSet(key, hashKey, value); //查詢 $redis->hGetAll(key); //查詢所有屬性 $redis->hGet(key, hashKey); //查詢某個屬性
登錄后復制

方案二 優于 方案一。

三、比如社交項目類似于新浪微博,個人中心的關注列表和粉絲列表,雙向關注列表,還有熱門微博,還有消息訂閱 等等。

以上都用 Redis 提供的相關數據結構即可。

四、Memcached 只存儲在內存中,而 Redis 既可以存儲在內存中,也可以持久化到磁盤上。

如果需求中的數據需要持久化,請選擇 Redis 。

個人在工作中沒有用到 Memcached ,通過查詢資料得到 Memcached 內存分配時優于 Redis。

Memcached 默認使用 Slab Allocation 機制管理內存,按照預先規定的大小,將分配的內存分割成特定長度的塊以存儲相應長度的key-value數據記錄,以完全解決內存碎片問題。

如何保證,緩存與數據庫的數據一致性?

新增數據:先新增到數據庫,再新增到緩存。

編輯數據:先刪除緩存數據,再修改數據庫中數據,再新增到緩存。

刪除數據:先刪除緩存數據,再刪除數據庫中數據。

查詢數據:先查詢緩存數據,沒有,再查詢數據庫,再新增到緩存。

強一致性是很難保證的,比如事務一致性,時間點一致性,最終一致性等。

具體問題具體分析吧。

緩存穿透怎么辦?

用戶請求緩存中不存在的數據,導致請求直接落在數據庫上。

一、設置有規則的Key值,先驗證Key是否符合規范。

二、接口限流、降級、熔斷,請研究 istio:https://istio.io/

三、布隆過濾器。

四、為不存在的key值,設置空緩存和過期時間,如果存儲層創建了數據,及時更新緩存。

雪崩怎么辦?

一、互斥鎖,只允許一個請求去重建索引,其他請求等待緩存重建執行完,重新從緩存獲取數據。

系統講解PHP緩存技術

二、雙緩存策略,原始緩存和拷貝緩存,當原始緩存失效請求拷貝緩存,原始緩存失效時間設置為短期,拷貝緩存設置為長期。

推薦學習:《PHP視頻教程》

贊(0)
分享到: 更多 (0)
?
網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
久久精品五月,日韩不卡视频在线观看,国产精品videossex久久发布 ,久久av综合
av不卡在线| 日本一区二区中文字幕| 国产亚洲一区| 国产精品调教视频| 久久久久久一区二区| 国精品产品一区| 99久久精品费精品国产| 999在线观看精品免费不卡网站| av不卡在线| 日韩精品成人| av中文字幕在线观看第一页 | 欧美日中文字幕| 国产亚洲毛片在线| 日韩不卡在线观看日韩不卡视频| 久久久久久久久成人| 日韩欧美午夜| 国产一区二区高清| 亚洲制服一区| 国产精品高清一区二区| 一本大道色婷婷在线| 亚洲乱亚洲高清| 日韩av免费大片| 免费日韩视频| 精品国产不卡一区二区| 欧美午夜不卡| 国产精品亚洲产品| 国产一区亚洲| 国产精品久久久久久久久久白浆 | 日韩午夜精品| 国产精品a久久久久| 亚洲91精品| 国产毛片精品| 好看的av在线不卡观看| 国产精区一区二区| 国产真实久久| 国产情侣一区在线| 亚洲调教视频在线观看| 国产亚洲观看| 欧美精选一区二区三区| 久久av影院| 视频一区二区三区中文字幕| 久久精品五月| 日韩精品中文字幕一区二区| 日韩国产一区二区| 日韩av影院| 国产日韩专区| 韩国三级一区| 欧美精品99| 美国三级日本三级久久99| 91日韩免费| 欧美啪啪一区| 99精品99| 999久久久精品国产| 久久精品国产成人一区二区三区| 在线精品福利| 国产视频一区欧美| 三级小说欧洲区亚洲区| 国产精品啊啊啊| 欧美日韩国产高清| 国产精品专区免费| 久久精品九色| 国产精品一国产精品k频道56| 蜜桃av一区二区三区电影| 欧美午夜精品一区二区三区电影| 精品视频在线一区二区在线| 欧美日本一区| 日本国产欧美| 日本不卡高清| 亚洲va久久久噜噜噜久久| 野花国产精品入口| 天堂资源在线亚洲| 久久婷婷亚洲| 欧美日韩精品免费观看视欧美高清免费大片| 久久99久久人婷婷精品综合| 在线观看亚洲精品福利片| 99在线精品免费视频九九视 | 日韩av电影一区| 在线国产日韩| 一区二区91| 免费在线观看日韩欧美| 99综合视频| 欧美专区一区二区三区| 亚洲欧洲一区二区天堂久久| 91九色精品国产一区二区| 欧美亚洲国产精品久久| av综合电影网站| 欧洲一区二区三区精品| 欧美sm一区| 成人看片网站| 久久国产亚洲精品| 久久亚洲国产| 在线综合欧美| 亚洲精品裸体| 日韩精选在线| 国产精品毛片视频| 国产一区二区三区不卡av| 不卡专区在线| 亚洲91久久| 亚洲资源av| 日欧美一区二区| 日韩精品导航| 国产精品18| 日韩成人精品一区| 香蕉精品久久| 男人操女人的视频在线观看欧美| 视频一区视频二区在线观看| 日韩黄色在线观看| 国产精品调教视频| 日本一区二区免费高清| 久久久成人网| 欧美va亚洲va日韩∨a综合色| 一本色道久久精品| 久久精品av麻豆的观看方式| 精品久久99| 免费毛片在线不卡| 一区二区高清| 欧美成人aaa| 日韩在线不卡| 老司机久久99久久精品播放免费| 亚洲毛片在线免费| 精品视频在线你懂得| 亚洲第一精品影视| 97久久亚洲| 国产粉嫩在线观看| 老牛国产精品一区的观看方式| 欧美日韩精品一区二区三区视频| 福利一区二区免费视频 | 国产尤物精品| 日本国产亚洲| 国产激情欧美| 伊人精品一区| 国产欧美另类| 久久在线免费| 久久国内精品自在自线400部| 中文字幕色婷婷在线视频| 亚洲深夜影院| 国产不卡一区| 中文视频一区| 98精品久久久久久久| 国产亚洲精品自拍| 老司机免费视频一区二区| 激情五月综合| 国产伦精品一区二区三区千人斩| 99精品在线观看| 日韩视频1区| 日韩精品dvd| 国产欧美在线| 视频一区在线视频| 国产色播av在线| 青青草视频一区| 亚洲手机在线| 精品资源在线| 日韩免费精品| 午夜免费一区| 岛国av免费在线观看| 91精品视频一区二区| 亚洲调教视频在线观看| 国产精品hd| 中文字幕av一区二区三区四区| 精品一区二区三区免费看 | 日韩欧美一区二区三区免费看| 亚洲五月综合| 1000部精品久久久久久久久| 久久99久久人婷婷精品综合| 石原莉奈一区二区三区在线观看| 欧美丰满日韩| 你懂的网址国产 欧美| 亚洲日韩中文字幕一区| 欧美精品羞羞答答| 国产99在线| 国产精品久av福利在线观看| 亚洲欧美日韩精品一区二区| 91看片一区| 久久精品免费看| 91精品国产自产观看在线| 亚洲一区二区网站| 欧美日韩亚洲在线观看| 91一区二区| 九九九精品视频| 国产亚洲一区| 97久久亚洲| 日韩中出av| 久久国产成人| 日韩视频免费| 精品日韩毛片| 欧美不卡高清| 97精品一区二区| 久久精品国产999大香线蕉| 久久国产乱子精品免费女| 四虎国产精品免费久久| 欧美综合二区| 在线视频亚洲| 伊人久久成人| 亚洲激情另类| 一区二区自拍| 日韩一区二区久久| 亚洲黄色在线| 国产视频一区三区| 亚洲视频www| 麻豆亚洲精品|