PHPerKaigi 2025

Configuración en tiempo de ejecución

El comportamiento de estas funciones se ve afectado por la configuración de php.ini.

Opciones de configuración de Memcache
Nombre Por defecto Cambiable Historial de cambios
memcache.allow_failover "1" INI_ALL Disponible desde memcache 2.0.2.
memcache.max_failover_attempts "20" INI_ALL Disponible desde memcache 2.1.0.
memcache.chunk_size "8192" INI_ALL Disponible desde memcache 2.0.2.
memcache.default_port "11211" INI_ALL Disponible desde memcache 2.0.2.
memcache.hash_strategy "standard" INI_ALL Disponible desde memcache 2.2.0.
memcache.hash_function "crc32" INI_ALL Disponible desde memcache 2.2.0.
session.save_handler "files" INI_ALL Soportado desde memcache 2.1.2
session.save_path "" INI_ALL Soportado desde memcache 2.1.2
memcache.protocol ascii INI_ALL Soportado desde memcache 3.0.0
memcache.redundancy 1 INI_ALL Soportado desde memcache 3.0.0
memcache.session_redundancy 2 INI_ALL Soportado desde memcache 3.0.0
memcache.compress_threshold 20000 INI_ALL Soportado desde memcache 3.0.3
memcache.lock_timeout 15 INI_ALL Soportado desde memcache 3.0.4
Para más detalles y definiciones de los modos de INI_*, vea Dónde se puede realizar un ajuste de configuración.

He aquí una breve explicación de las directivas de configuración.

memcache.allow_failover bool

Si se quiere hacer visible los failover en otros servidores en caso de errores.

memcache.max_failover_attempts int

Define el número de servidores a probar cuando se añade y se obtiene información. Úsese solamente en conjunción con memcache.allow_failover.

memcache.chunk_size integer

La información será transferida en bloques del tamaño indicado, definir este valor a un número más pequeño requerirá más escrituras de red. Pruebe de incrementar este valor a 32768 si se nota una lentitud inexplicable.

memcache.default_port string

El puerto TCP por defecto a usar cuando se conecta a el servidor memcached si no se especifica otro puerto.

memcache.hash_strategy string

Controla el tipo de estrategia a usar cuando se mapean claves en los servidores. Definir este valor como consistent para habilitar hashing consistente que permite a los servidores ser añadidos o eliminados del grupo sin causar que las claves sean remapeadas. Si se define este valor como standard se usará la antigua estrategia.

memcache.hash_function string

Controla que tipo de función hash se utiliza cuando se mapean claves a los servidores, crc32 utiliza el stándar hash CRC32 hash mientras que fnv utiliza FNV-1a.

session.save_handler string

Si define esta opción como memcache podrá usar memcache como manejador de sesiones.

session.save_path string

Define una lista de urls de servidores separados por comas para el almacenamiento de sesiones, por ejemplo "tcp://host1:11211, tcp://host2:11211".

Cada url puede contener parámetros que son aplicados al servidor, son los mismos que en el método Memcache::addServer(). Por ejemplo "tcp://host1:11211?persistent=1&weight=1&timeout=1&retry_interval=15"

memcache.protocol string

memcache.redundancy int

memcache.session_redundancy int

memcache.compress_threshold int

memcache.lock_timeout int

add a note

User Contributed Notes 1 note

up
-2
kross at escapistmag dot com
14 years ago
There's a currently undocumented variable that is now available (you can see it in php_info()) for session handling:

memcache.session_redundancy

The default seems to be "2", and it is supposed to influence how many copies of a particular session object that Memcache will store for failover purposes (so with a redundancy of 2, it will store a session on 2 different shards).

This will add slight overhead with extra writes, but overall seems worth it for purposes of failover.
To Top