通常のWeb開発では、ユーザーがログインした後、ログインステータス情報がセッションに保存され、ユーザーがよく使うホットデータの一部がファイルキャッシュに保存され、ユーザーがアップロードした添付ファイル情報が保存されるのが一般的なモードです。 Web サーバー上のディレクトリに保存されます。この方法は非常に使いやすく、一般的な Web アプリケーションに完全に対応します。しかし、同時実行性の高いエンタープライズレベルの Web サイトの場合は、それを処理できません。負荷分散を実現するには、Web クラスターを使用する必要があります。
Webクラスター方式でデプロイした後、最初に調整するのはユーザーのステータス情報と添付ファイル情報です。ユーザー ステータスをセッションに保存できなくなり、キャッシュでローカル Web サーバーのファイル キャッシュを使用できなくなり、添付ファイルを Web サーバーに保存できなくなります。クラスター内の各 Web サーバーのステータスが完全に一貫していることを確認する必要があるためです。そのため、ユーザーステータスやキャッシュなどをMemcacheなどの専用キャッシュサーバーに保存する必要があります。添付ファイルは、Qiniu Cloud Storage、Alibaba Cloud Storage、Tencent Cloud Storage などのクラウド ストレージに保存する必要があります。
この記事では、ThinkPHP 開発フレームワークを例として、セッションやキャッシュなどを設定して Memcache キャッシュ サーバーに保存する方法を説明します。
以下に示すように、キャッシュされた Memcache 処理クラスをダウンロードして ThinkphpExtendDriverCache ディレクトリに配置します。Session Memcache 処理クラスをダウンロードして ThinkphpExtendDriverSession ディレクトリに配置します。
構成ファイルを変更してセッションを調整します。すべてが Memcache サーバーに記録されます。 ThinkPHPConfconvention.php を開き、構成項目を追加します:
/* Memcache缓存设置 */ 'MEMCACHE_HOST' => '192.168.202.20', 'MEMCACHE_PORT' => 11211,
。以下の図に示すように、データ キャッシュを Memcache に変更します:
'DATA_CACHE_TYPE' => 'Memcache',
。クラウド ストレージ、添付ファイル ストレージにはさまざまな種類があります。クラウド ストレージについては、各クラウド ストレージが提供する SDK の詳細については説明しません。上記の変更を行うと、Web サーバーを分散方式で展開できるようになります。
添付ファイル 1: CacheMemcache.class.php
'SESSION_TYPE' => 'Memcache',
添付ファイル 2: SessionMemcache.class.php
<?php // +---------------------------------------------------------------------- // | ThinkPHP [ WE CAN DO IT JUST THINK IT ] // +---------------------------------------------------------------------- // | Copyright (c) 2006-2012 http://thinkphp.cn All rights reserved. // +---------------------------------------------------------------------- // | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 ) // +---------------------------------------------------------------------- // | Author: liu21st <liu21st@gmail.com> // +---------------------------------------------------------------------- defined('THINK_PATH') or exit(); /** * Memcache缓存驱动 * @category Extend * @package Extend * @subpackage Driver.Cache * @author liu21st <liu21st@gmail.com> */ class CacheMemcache extends Cache { /** * 架构函数 * @param array $options 缓存参数 * @access public */ function __construct($options=array()) { if ( !extension_loaded('memcache') ) { throw_exception(L('_NOT_SUPPERT_').':memcache'); } $options = array_merge(array ( 'host' => C('MEMCACHE_HOST') ? C('MEMCACHE_HOST') : '127.0.0.1', 'port' => C('MEMCACHE_PORT') ? C('MEMCACHE_PORT') : 11211, 'timeout' => C('DATA_CACHE_TIMEOUT') ? C('DATA_CACHE_TIMEOUT') : false, 'persistent' => false, ),$options); $this->options = $options; $this->options['expire'] = isset($options['expire'])? $options['expire'] : C('DATA_CACHE_TIME'); $this->options['prefix'] = isset($options['prefix'])? $options['prefix'] : C('DATA_CACHE_PREFIX'); $this->options['length'] = isset($options['length'])? $options['length'] : 0; $func = $options['persistent'] ? 'pconnect' : 'connect'; $this->handler = new Memcache; $options['timeout'] === false ? $this->handler->$func($options['host'], $options['port']) : $this->handler->$func($options['host'], $options['port'], $options['timeout']); } /** * 读取缓存 * @access public * @param string $name 缓存变量名 * @return mixed */ public function get($name) { N('cache_read',1); return $this->handler->get($this->options['prefix'].$name); } /** * 写入缓存 * @access public * @param string $name 缓存变量名 * @param mixed $value 存储数据 * @param integer $expire 有效时间(秒) * @return boolen */ public function set($name, $value, $expire = null) { N('cache_write',1); if(is_null($expire)) { $expire = $this->options['expire']; } $name = $this->options['prefix'].$name; if($this->handler->set($name, $value, 0, $expire)) { if($this->options['length']>0) { // 记录缓存队列 $this->queue($name); } return true; } return false; } /** * 删除缓存 * @access public * @param string $name 缓存变量名 * @return boolen */ public function rm($name, $ttl = false) { $name = $this->options['prefix'].$name; return $ttl === false ? $this->handler->delete($name) : $this->handler->delete($name, $ttl); } /** * 清除缓存 * @access public * @return boolen */ public function clear() { return $this->handler->flush(); } }
PHP 分散デプロイメントについて詳しく説明する
PHP 拡張 Memcache 分散デプロイメント ソリューション_PHP
以上がThinkPHPプロジェクトの分散導入例を詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。