yac
1.0.0
YAC는 PHP 용 공유 및 잠금 메모리 사용자 데이터 캐시입니다.
APC 또는 로컬 멤버를 대체하는 데 사용할 수 있습니다.
$/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의 생성자, 설정/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 write right를 얻을 수 없습니다)
<?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 )
}
*/