LXXXVI. Memcache Functions
Introduction
Memcache module provides handy procedural and object oriented interface to memcached, highly effective caching daemon, which was especially designed to decrease database load in dynamic web applications.
More information about memcached can be found at http://www.danga.com/memcached/.
Requirements
This module uses functions of zlib to support on-the-fly data compression. Zlib is required to install this module.
PHP 4.3.3 or newer is required to use the memcache extension.
Installation
This PECL extension is not bundled with PHP. Information for installing this PECL extension may be found in the manual chapter titled Installation of PECL extensions. Additional information such as new releases, downloads, source files, maintainer information, and a CHANGELOG, can be located here: http://pecl.php.net/package/memcache.
In order to use these functions you must compile PHP with Memcache support
by using the --enable-memcache[=DIR] option.
You may optionally disable memcache session handler support by specifying
--disable-memcache-session.
Windows users will enable php_memcache.dll inside of php.ini in order to use these functions. The DLL for this PECL extension may be downloaded from either the PHP Downloads page or from http://pecl4win.php.net/
Runtime Configuration
The behaviour of these functions is affected by settings in php.ini.
Table 1. Memcache Configuration Options
| Name | Default | Changeable | Changelog |
|---|---|---|---|
| memcache.allow_failover | "1" | PHP_INI_ALL | Available since Memcache 2.0.2 |
| memcache.max_failover_attempts | "20" | PHP_INI_ALL | Available since Memcache 2.1.0 |
| memcache.chunk_size | "8192" | PHP_INI_ALL | Available since Memcache 2.0.2 |
| memcache.default_port | "11211" | PHP_INI_ALL | Available since Memcache 2.0.2 |
| session.save_handler | PHP_INI_ALL | Available since Memcache 2.1.2 | |
| session.save_path | PHP_INI_ALL | Available since Memcache 2.1.2 |
Here's a short explanation of the configuration directives.
memcache.allow_failoverbooleanWhether to transparently failover to other servers on errors.
memcache.max_failover_attemptsintegerDefines how many servers to try when setting and getting data. Used only in conjunction with memcache.allow_failover.
memcache.chunk_sizeintegerData will be transferred in chunks of this size, setting the value lower requires more network writes. Try increasing this value to 32768 if noticing otherwise inexplicable slowdowns.
memcache.default_portstringThe default TCP port number to use when connecting to the memcached server if no other port is specified.
session.save_handlerstringUse memcache as a session handler by setting this value to memcache.
session.save_pathstringDefines a comma separated of server urls to use for session storage, for example "tcp://host1:11211, tcp://host2:11211".
Each url may contain parameters which are applied to that server, they are the same as for the Memcache::addServer() method. For example "tcp://host1:11211?persistent=1&weight=1&timeout=1&retry_interval=15"
Resource Types
There is only one resource type used in memcache module - it's the link identifier for a cache server connection.
Predefined Constants
Table 2. MemCache Constants
| Name | Description |
|---|---|
| MEMCACHE_COMPRESSED (integer) | Used to turn on-the-fly data compression on with Memcache::set(), Memcache::add() and Memcache::replace(). |
Examples
In the above example, an object is being saved in the cache and then retrieved back. Object and other non-scalar types are serialized before saving, so it's impossible to store resources (i.e. connection identifiers and others) in the cache.
- Table of Contents
- Memcache::add -- Add an item to the server
- Memcache::addServer -- Add a memcached server to connection pool
- Memcache::close -- Close memcached server connection
- Memcache::connect -- Open memcached server connection
- memcache_debug -- Turn debug output on/off
- Memcache::decrement -- Decrement item's value
- Memcache::delete -- Delete item from the server
- Memcache::flush -- Flush all existing items at the server
- Memcache::get -- Retrieve item from the server
- Memcache::getExtendedStats -- Get statistics from all servers in pool
- Memcache::getServerStatus -- Returns server status
- Memcache::getStats -- Get statistics of the server
- Memcache::getVersion -- Return version of the server
- Memcache::increment -- Increment item's value
- Memcache::pconnect -- Open memcached server persistent connection
- Memcache::replace -- Replace value of the existing item
- Memcache::set -- Store data at the server
- Memcache::setCompressThreshold -- Enable automatic compression of large values
- Memcache::setServerParams -- Changes server parameters and status at runtime
