勉強したことのメモ

Webエンジニア / プログラマが勉強したことのメモ。

メモリキャッシュシステムであるMemcachedをPHPにて利用する方法

   2024/05/22  PHP

メモリキャッシュシステムであるMemcachedのインストール方法、IP制限、PHPでの簡単な使い方についてのメモ。

 

インストール

サーバにSSH接続し以下コマンドでインストールする。

yum install memcached php-pecl-memcache

 

IP制限

以下で設定ファイルを開く。

vi /etc/rc.d/init.d/memcached

以下を追記する。

OPTIONS=”-l アクセス許可したいIP”

以下で再起動すると反映される筈。

service memcached restart

 

使い方

ソースコード

<?php
/* memcachedとの接続 */
$memcache = new Memcache;
$memcache->addServer("IPアドレス", ポート);

/* データの保存 */
$memcache->add('key名', 'value値', 0, 3600);

/* データの検索 */
$data = $memcache->get('key名');
echo $data;

/* 切断 */
$memcache->close();
?>

尚、変数だけではなく配列も直接格納できる。

$hash = array(
    'name' => '田中',
    'age' => 19,
    'bool' => true
);
$memcache->add('test', $hash, 0, 3600);
$data = $memcache->get('test');
var_dump($data);

//以下が出力される
array(3) { ["name"]=> string(6) "田中" ["age"]=> int(19) ["bool"]=> bool(true) }

リファレンスについて

https://www.php.net/manual/ja/class.memcache.php

 

使いどころ

MySQLの検索結果をmemcachedに格納するのが良さそう。保存期間を10分とかにしておけば10分に1回しかMySQLに参照しにいかないので負荷も下がり、検索速度も上がる。

 

注意点

サーバーやmemcachedを再起動した際はデータが全て消える点に注意する。

 - PHP

  関連記事

UTF-16にエンコードされている文字列をUTF-8へデコード

エンコードされている文字列であまり見かけない感じのものがあった。UTF-8やSh ...

CodeIgniter4でGET / POSTパラメータの受け取りとルーティング設定方法

CodeIgniter4.4.4でページを開いた際にGET / POSTパラメー ...

PHPでエラーログ等のログファイルから指定した行数を表示させる方法

エラーログを最新分から指定行数表示させる プログラムがあって、どういった作りにな ...

PHPでPOST送信する際に多次元配列も送る方法

PHPでPOST送信する際に多次元配列も送りたかった。ただ普通に送ろうとするとO ...

PHPにて「一億二千万」等の漢数字と通常の数字(アラビア数字)の相互変換を行う方法

PHPにて漢数字と普通の数字の相互変換を行いたい。例えば「123465789」⇔ ...