本文目錄一覽:
- 1、memcache緩存 如何實現php
- 2、php 中的 memcache 是什麼 怎麼用的 越詳細越好,求大神 在線等
- 3、thinkphp裡面怎樣配置memcache
- 4、php操作memcacheq
- 5、php memcache隊列有什麼用
- 6、php 為什麼要使用memcache 隊列
memcache緩存 如何實現php
php實現memcache緩存示例講解
共享內存是一種在相同機器中的應用程序之間交換數據的有效方式,本文說的是php實現memcache緩存示例,大家參考使用吧
概述
共享內存是一種在相同機器中的應用程序之間交換數據的有效方式。一個進程可創建一個可供其他進程訪問的內存段,只要它分配了正確的許可權。每個內存段擁有一個惟一的 ID(稱為 shmid),這個 ID 指向一個物理內存區域,其他進程可在該區域操作它。創建並提供了合適的許可權之後,同一台機器中的其他進程就可以操作這些內存段:讀取、寫入和刪除。
這表明使用 C 語言編寫的應用程序可與使用其他語言(比如 Java™ 或 PHP)編寫的應用程序共享信息。它們都可以共享信息,只要它們可訪問和理解該信息。共享內存在針對大部分語言的實現中得到了廣泛使用,所以訪問應該不是問題。要理解信息,我們可以使用一種標準格式,比如 XML 或 JSON。
共享內存的使用是一種在進程之間交換數據的快速方法,主要因為在創建內存段之後傳遞數據,不會涉及內核。這種方法常常稱為進程間通信 (IPC)。其他 IPC 方法包括管道、消息隊列、RPC 和套接字。當使用需要彼此通信的應用程序的生態系統時,這種在應用程序之間快速、可靠地交換數據的能力非常有用。取決於生態系統的大小,使用資料庫在應用程序之間交換信息的常用方法常常會導致查詢緩慢,甚至 I/O 阻塞。使用共享內存,沒有 I/O 會減緩開發人員的進度。
本文的提議非常簡單,學習如何使用 PHP 創建和操作共享內存段,使用它們存儲可供其他應用程序使用的數據集。即使沒有使用共享內存交換數據的計劃,它本身也在許多好處,因為它使應用程序能夠遠離 I/O 問題。將數據集直接存儲在內存中具有諸多優勢,從 Web 服務數據緩存到會話共享。它是一個非常有用的概念,每個 PHP 開發人員都應該知道。
共享內存和 PHP
PHP 擁有豐富的可用擴展,共享內存也一樣。使用一些共享的函數,無需安裝任何擴展,開發人員就能夠輕鬆操作內存段。
創建內存段
共享內存函數類似於文件操作函數,但無需處理一個流,您將處理一個共享內存訪問 ID。第一個示例就是 shmop_open 函數,它允許您打開一個現有的內存段或創建一個新內存段。此函數非常類似於經典的 fopen 函數,後者打開用於文件操作的流,返回一個資源供其他希望讀取或寫入該打開的流的函數使用。讓我們看看清單 1 中的 shmop_open。
清單 1. shmop_open 函數
複製代碼代碼如下:
?php
$systemid = 864; // System ID for the shared memory segment
$mode = “c”; // Access mode
$permissions = 0755; // Permissions for the shared memory segment
$size = 1024; // Size, in bytes, of the segment
$shmid = shmop_open($systemid, $mode, $permissions, $size);
?
該函數中出現的第一個事物是系統 ID 參數。這是標識系統中的共享內存段的數字。第二個參數是訪問模式,它非常類似於 fopen 函數的訪問模式。您可以在 4 種不同的模式下訪問一個內存段:
•模式 「a」,它允許您訪問只讀內存段
•模式 「w」,它允許您訪問可讀寫的內存段
•模式 「c」,它創建一個新內存段,或者如果該內存段已存在,嘗試打開它進行讀寫
•模式 「n」,它創建一個新內存段,如果該內存段已存在,則會失敗
第三個參數是內存段的許可權。您必須在這裡提供一個八進位值。
第四個參數提供內存段大小,以位元組為單位。在寫入一個內存段之前,您必須在它之上分配適當的位元組數。
請注意,此函數返回一個 ID 編號,其他函數可使用該 ID 編號操作該共享內存段。這個 ID 是共享內存訪問 ID,與系統 ID 不同,它以參數的形式傳遞。請注意不要混淆這兩者。如果失敗,shmop_open 將返回 FALSE。
向內存段寫入數據
使用 shmop_write 函數向共享內存塊寫入數據。此函數的使用很簡單,它僅接受 3 個參數,如清單 2 所示。
清單 2. 使用 shmop_write 向共享內存塊寫入數據
複製代碼代碼如下:
?php
$shmid = shmop_open(864, ‘c’, 0755, 1024);
shmop_write($shmid, “Hello World!”, 0);
?
這個函數類似於 fwrite 函數,後者有兩個參數:打開的流資源(由 fopen 返回)和您希望寫入的數據。shmop_write 函數也執行此任務。
第一個參數是 shmop_open 返回的 ID,它識別您操作的共享內存塊。第二個參數是您希望存儲的數據,最後的第三個參數是您希望開始寫入的位置。默認情況下,我們始終使用 0 來表示開始寫入的位置。請注意,此函數在失敗時會返回 FALSE,在成功時會返回寫入的位元組數。
從內存段讀取數據
從共享內存段讀取數據很簡單。您只需要一個打開的內存段和 shmop_read 函數。此函數接受一些參數,工作原理類似於 fread。參見清單 3,讀取一個 PHP 文件的內容。
清單 3. 使用 shmop_read 讀取一個文件的內容
複製代碼代碼如下:
?php
$stream = fopen(‘file.txt’, ‘r+’);
fwrite($stream, “Hello World!”);
echo fread($stream, 11);
?
讀取共享內存段的內容的過程與此類似,如清單 4 所示:
清單 4. 讀取共享內存段的內容
複製代碼代碼如下:
?php
$shmid = shmop_open(864, ‘c’, 0755, 1024);
shmop_write($shmid, “Hello World!”, 0);
echo shmop_read($shmid, 0, 11);
?
請留意這裡的參數。shmop_read 函數將接受 shmop_open 返回的 ID,我們已知道它,不過它還接受另外兩個參數。第二個參數是您希望從內存段讀取的位置,而第三個是您希望讀取的位元組數。第二個參數可以始終為 0,表示數據的開頭,但第三個參數可能存在問題,因為我們不知道我們希望讀取多少位元組。
這非常類似於我們在 fread 函數中的行為,該函數接受兩個參數:打開的流資源(由 fopen 返回)和您希望從該流讀取的位元組數。使用filesize 函數(它返回一個文件中的位元組數)來完整地讀取它。
幸運的是,當使用共享內存段時,shmop_size 函數返回一個內存段的大小(以位元組為單位),類似於 filesize 函數。參見清單 5。
清單 5. shmop_size 函數返回內存段大小,以位元組為單位
複製代碼代碼如下:
?php
$shmid = shmop_open(864, ‘c’, 0755, 1024);
shmop_write($shmid, “Hello World!”, 0);
$size = shmop_size($shmid);
echo shmop_read($shmid, 0, $size);
?
回頁首
刪除內存段
我們學習了如何打開、寫入和讀取共享內存段。要完成我們的 CRUD 類,我們還需要學習如何刪除內存段。該任務可使用 shmop_delete 函數輕鬆完成,該函數僅接受一個參數:我們希望刪除的共享內存 ID。
清單 6. shmop_delete 標記要刪除的內存段
複製代碼代碼如下:
?php
$shmid = shmop_open(864, ‘c’, 0755, 1024);
shmop_write($shmid, “Hello World!”, 0);
shmop_delete($shmid);
?
這不會實際刪除該內存段。它將該內存段標記為刪除,因為共享內存段在有其他進程正在使用它時無法被刪除。shmop_delete 函數將該內存段標記為刪除,阻止任何其他進程打開它。要刪除它,我們需要關閉該內存段。
關閉內存段
打開一個共享內存段會 「附加」 到它。附加該內存段之後,我們可在其中進行讀取和寫入,但完成操作後,我們必須從它解除。這使用清單 7 中的 shmop_close 函數來完成。
這非常類似於處理文件時的 fclose 函數。打開包含一個文件的流並在其中讀取或寫入數據後,我們必須關閉它,否則將發生鎖定。
清單 7. 使用 shmop_close 與一個內存段分開
複製代碼代碼如下:
?php
$shmid = shmop_open(864, ‘c’, 0755, 1024);
shmop_write($shmid, “Hello World!”, 0);
shmop_delete($shmid);
shmop_close($shmid);
?
使用共享內存作為一個存儲選項
有了共享內存和共享內存段上基本 CRUD 操作的基本知識,是時候應用此知識了。我們可以使用共享內存作為一種獨特的存儲選項,提供快速讀/寫操作和進程互操作性等優勢。對於 Web 應用程序,這意味著:
•緩存存儲(資料庫查詢、Web 服務數據、外部數據)
•會話存儲
•應用程序之間的數據交換
在繼續之前,我想介紹一個名為 SimpleSHM 小型庫。SimpleSHM 是一個較小的抽象層,用於使用 PHP 操作共享內存,支持以一種面向對象的方式輕鬆操作內存段。在編寫使用共享內存進行存儲的小型應用程序時,這個庫可幫助創建非常簡潔的代碼。要了解 SimpleSHM,請訪問GitHub 頁面。
您可以使用 3 個方法進行處理:讀、寫和刪除。從該類中簡單地實例化一個對象,可以控制打開的共享內存段。清單 8 展示了基本用途。
清單 8. SimpleSHM 基本用途
複製代碼代碼如下:
?php
$memory = new SimpleSHM;
$memory-write(‘Sample’);
echo $memory-read();
?
請注意,這裡沒有為該類傳遞一個 ID。如果沒有傳遞 ID,它將隨機選擇一個編號並打開該編號的新內存段。我們可以以參數的形式傳遞一個編號,供構造函數打開現有的內存段,或者創建一個具有特定 ID 的內存段,如清單 9 所示。
清單 9. 打開一個特定的內存段
複製代碼代碼如下:
?php
$new = new SimpleSHM(897);
$new-write(‘Sample’);
echo $new-read();
?
神奇的方法 __destructor 負責在該內存段上調用 shmop_close 來取消設置對象,以與該內存段分離。我們將這稱為 「SimpleSHM 101」。現在讓我們將此方法用於更高級的用途:使用共享內存作為存儲。存儲數據集需要序列化,因為數組或對象無法存儲在內存中。儘管這裡使用了 JSON 來序列化,但任何其他方法(比如 XML 或內置的 PHP 序列化功能)也已足夠。清單 10 給出了一個示例。
清單 10. 使用共享內存作為存儲
複製代碼代碼如下:
?php
require(‘SimpleSHM.class.php’);
$results = array(
‘user’ = ‘John’,
‘password’ = ‘123456’,
‘posts’ = array(‘My name is John’, ‘My name is not John’)
);
$data = json_encode($results);
$memory = new SimpleSHM;
$memory-write($data);
$storedarray = json_decode($memory-read());
print_r($storedarray);
?
我們成功地將一個數組序列化為一個 JSON 字元串,將它存儲在共享內存塊中,從中讀取數據,去序列化 JSON 字元串,並顯示存儲的數組。這看起來很簡單,但請想像一下這個代碼片段帶來的可能性。您可以使用它存儲 Web 服務請求、資料庫查詢或者甚至模板引擎緩存的結果。在內存中讀取和寫入將帶來比在磁碟中讀取和寫入更高的性能。
使用此存儲技術不僅對緩存有用,也對應用程序之間的數據交換也有用,只要數據以兩端都可讀的格式存儲。不要低估共享內存在 Web 應用程序中的力量。可採用許多不同的方式來巧妙地實現這種存儲,惟一的限制是開發人員的創造力和技能
php 中的 memcache 是什麼 怎麼用的 越詳細越好,求大神 在線等
memcache 是一種緩存伺服器軟體,安裝了該軟體的電腦,即可稱為 緩存伺服器。
memcache 緩存伺服器是用來緩解 關係型資料庫(例如 Mysql)負載壓力的,第一次訪問 mysql資料庫(select)後,得到的數據放到緩存伺服器里,設定個生命周期(例如7天),然後7天內所有訪問該數據的語句就不用再到數據里查詢了,直接從緩存伺服器里取。
而你所問的 php中的 memcache 是一種客戶端,客戶端是用來訪問服務端的(例如用IE瀏覽器訪問網站,IE瀏覽器就是客戶端)。再說具體點,php中的 memcache 就是一種擴展,在php安裝目錄的 php.ini 配置文件里開啟 memcache 擴展後,你就能 用 memcache類實例對象,用memcache對象的各種方法 來訪問 memcache伺服器。
例:
?php
$mem = new Memcache();//實例化一個對象
//$mem-connect(“ip地址”,埠號);//連接memcache伺服器
$mem-connect(“localhost”,11211);//連接memcache伺服器
//添加數據,如果鍵名已經存在,則添加失敗
$res = $mem-add(‘name’,’xiaoqian’,MEMCACHE_COMPRESSED,3600);
var_dump($res);
//獲取數據
$str = $mem-get(‘name’);
var_dump($str);
?
詳細的怎麼開啟擴展後續什麼的,你在這個我上傳的word文檔里看看就行了
thinkphp裡面怎樣配置memcache
1、下載並安裝memcache
(1)window下安裝memcache. 下載memcached.exe
到d:/memcached/memcached.exe.在運行cmd 輸入
d:/memcached/memcached.exe -d install安裝
。
(2)運行d:/memcached/memcached.exe -d start
啟動memcache
(3)下載php_memcache.dll
到php安裝目錄擴展目錄 php\ext
(4)修改php.ini 加入
extension=php_memcache.dll 重啟apache.查看phpinfo.php 如果有memcache模塊 則
說明安裝成功
2、thinkphp 中memcache
的使用
(1)ThinkPHP/conf/convention.php 修改緩存類型
‘DATA_CACHE_TYPE’
= ‘Memcache’, //
數據緩存類型,
支持: File|Db|Apc|Memcache|Shmop|Sqlite|Xcache|Apachenote|Eaccelerator
(2)thinkphp官方下載擴展ThinkPHP_Extend_3.1.2/Extend/Driver/Cache/CacheMemcache.class.php
保存到
ThinkPHP/Lib/Driver/Cache/CacheMemcache.class.php
(3)測試:
S(‘test’,’memcache’);$test
= S(‘test’); echo $test;
輸出memcache
測試成功。
此為轉載,不是我原創,
php操作memcacheq
$arr=array(1,2,3,4,5);
$q-set(“queque_1”,$arr);
這樣,你取的時候就會是一個數組了
php memcache隊列有什麼用
是在網站並發量比較高時使用的一種方法,主要用在比如是搶購,秒殺中
php 為什麼要使用memcache 隊列
因為一般php不作為守護服務運行,所以php做隊列就不合適,而MYSQL做隊列又慢。
原創文章,作者:QJLT,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/148854.html