YAC - это общий и беззамажный кэш данных пользователей памяти для PHP.
Его можно использовать для замены APC или Local Memcached.
$/path/to/phpize
$./configure --with-php-config=/path/to/php-config
$make && make install
yac.enable = 1
yac.keys_memory_size = 4M ; 4M can get 30K key slots, 32M can get 100K key slots
yac.values_memory_size = 64M
yac.compress_threshold = -1
yac.enable_cli = 0 ; whether enable yac with cli, default 0
yac.serializer = php ; since yac 2.2.0 , specific seralizer yac used
could be json(--enable-json), msgpack(--enable-msgpack) or igbinary(--enable-igbinary)
YAC_VERSION
YAC_MAX_KEY_LEN = 48 ; if your key is longer than this, maybe you can use md5 result as the key
YAC_MAX_VALUE_RAW_LEN = 64M
YAC_MAX_VALUE_COMPRESSED_LEN = 1M
YAC_SERIALIZER_PHP = 0 ; since yac-2.2.0
YAC_SERIALIZER_JSON = 1 ; since yac-2.2.0
YAC_SERIALIZER_MSGPACK = 2 ; since yac-2.2.0
YAC_SERIALIZER_IGBINARY = 3 ; since yac-2.2.0
YAC_SERIALIZER ; serializer according to yac.serializer, default is YAC_SERIALIZER_PHP
Yac:: __construct ([string $ prefix = "" ])Конструктор YAC, вы можете указать префикс, который будет использоваться для подготовки к любым ключам при выполнении SET/GET/DELETE
<?php
$ yac = new Yac ( " myproduct_ " );
?> Yac:: set ( $ key , $ value [, $ ttl = 0 ])
Yac:: set (array $ kvs [, $ ttl = 0 ])Установите значение в кэше YAC, клавиши являются кэш-юником, поэтому хранение второго значения с одним и тем же ключом будет перезаписать исходное значение.
Вернуть True на успех, вернуть False по ошибке (например, память, не может получить правильно CAS, правильно)
<?php
$ yac = new Yac ();
$ yac -> set ( " foo " , " bar " );
$ yac -> set (
array (
" dummy " => " foo " ,
" dummy2 " => " foo " ,
)
);
?> Как YAC 2.1, магазин может пройти неудачу, если конкуренция CAS не удается, вам может потребоваться:
while (!( $ yac -> set ( " important " , " value " )));Если вам нужно значение, чтобы хранить должным образом.
Yac::get(array|string $key[, &$cas = NULL])
Приносит хранимую переменную из кеша. Если массив проходит, то каждый элемент получен и возвращен.
Вернуть значение успеха, вернуть False по ошибке (например, память, не может получить справедливую запись CAS)
<?php
$ yac = new Yac ();
$ yac -> set ( " foo " , " bar " );
$ yac -> set (
array (
" dummy " => " foo " ,
" dummy2 " => " foo " ,
)
);
$ yac -> get ( " dummy " );
$ yac -> get ( array ( " dummy " , " dummy2 " ));
?> Yac::delete(array|string $keys[, $delay=0])
Удаляет хранимую переменную из кэша. Если указана задержка, то значение будет удалено через секунды за задержку.
Yac::flush()
Немедленно невидит все существующие предметы. На самом деле он не освобождает никаких ресурсов, он только отмечает все предметы как недействительные.
Yac::info(void)
Получите информацию о кеше
<?php
. . . .
var_dump ( $ yac -> info ());
/* will return an array like :
array ( 11) {
[ " memory_size "]=> int(541065216)
[ "slots_memory_size" ] => int ( 4194304 )
[ "values_memory_size" ] => int ( 536870912 )
[ "segment_size" ] => int ( 4194304 )
[ "segment_num" ] => int ( 128 )
[ "miss" ] => int ( 0 )
[ "hits" ] => int ( 955 )
[ "fails" ] => int ( 0 )
[ "kicks" ] => int ( 0 )
[ "slots_size" ] => int ( 32768 )
[ "slots_used" ] => int ( 955 )
}
*/