>백엔드 개발 >PHP 튜토리얼 >php memcache와 php memcached 및 문제 발생

php memcache와 php memcached 및 문제 발생

高洛峰
高洛峰원래의
2016-11-29 10:30:231247검색

PHP에는 php memcache와 php memcached라는 두 가지 Memcache 클라이언트가 있습니다.
php memcache는 PHP에서 독립적으로 구현됩니다. 실습을 통해 우리는 많은 문제가 있고 설정할 수 있는 속성이 거의 없다는 것을 발견했습니다.
php memcached는 기반입니다. 더 완전한 기본 c libmemcached 확장에서는 이를 php memcached로 교체하는 것이 좋습니다.

1. Php memcache 문제
1.1 배포 문제
php memcache는 기본적으로 인스턴스를 자동으로 전환하므로 오래된 데이터를 가져오거나 값이 불규칙할 때가 있습니다.
네티즌들이 공유한 질문:
요즘 제품 작업을 하다가 작은 문제를 겪었습니다. 현상이 꽤 이상했습니다. 두 개의 분산된 memcached 서버를 사용했습니다. 때때로 특정 카운터에 의해 검색된 숫자가 올바르지 않으며, 이는 최종적으로 php memcache 클라이언트의 장애 조치 메커니즘에서 발견됩니다.
Memcached 분산 환경에서는 해시 계산을 통해 특정 Memcached에 특정 키가 할당되는 것을 알고 있습니다.
php.ini에서 memcache.allow_failover = 1이면 분산 환경에서 하나의 memcached에 문제가 있으면 자동으로 다른 memcached를 시도하게 되어 위와 같은 문제가 발생하게 됩니다. 따라서,allow_failover=0으로 설정해야 합니다. 그러면 검색할 수 없는 경우 직접 실패를 반환하고 다른 MC에서 검색하지 않습니다. 이렇게 하면 네트워크 이상이나 서버 측 이상이 발생할 때 인스턴스를 자주 전환하고 오래된 데이터를 피할 수 있습니다. 검색됩니다.

1.2 높은 동시성에서 안정성 문제
Sina Weibo에서 언급된 교훈:
php memcache를 php memcached로 교체하면 높은 동시성에서 안정성이 크게 향상됩니다.
또한 기능이 업데이트되었습니다. 더 많은 오류 코드가 더 정확합니다.

Twitter의 캐싱 경험
일부 캐시 노드가 다운되는 영향을 줄이고 읽기 및 쓰기를 모두 캐시하는 다중 레벨 캐시
memcached API를 libmemcached로 균일하게 교체합니다. memcached에 대한 언어 액세스, 배포 및 기타 규칙을 일관되게 만듭니다. )

1.3 1초 시간 초과 간격은 수정할 수 없습니다.
php memcache 클라이언트에는 수정할 수 없는 1초 시간 초과 간격이 있습니다.
bool Memcache: :connect ( string $host [, int $port [, int $timeout ]] )
세 번째 매개변수는 원래 시간 초과를 초 단위로 설정할 수 있지만 수정할 수는 없습니다.
타임아웃을 수정하는 다음 세 가지 방법이 테스트되었으며 모두 유효하지 않습니다.
1.3.1. Memcache api Memcache::setServerParams는 수정할 수 없습니다.
1.3.2. h 매크로 정의는 수정할 수 없습니다.
1.3.3. php.ini의 이 구성: default_socket_timeout = 60은 이 시간 초과에 유효하지 않습니다.

2. memcache와 memcached의 비교
오래된 클라이언트인 Php memcache는 설정할 속성이 거의 없습니다.
오류 코드 세분성이 매우 조악하여 오류 발생 후 찾기가 어렵습니다.
그리고 많은 기능이 있습니다. 일부 부족한 부분:

PHP는 주로 두 클라이언트에 사용됩니다. 하나는 더 오래되고 더 광범위한 PECL/캐시이고 다른 하나는 새롭고 거의 사용되지 않으며 기능이 더 풍부한 PECL/캐시입니다.

기본, 값 설정, 값 가져오기, 증가, 감소 및 데이터 가져오기와 같은 다중 서버를 지원합니다.

다음은 몇 가지 고급 기능과 정보입니다.

项目 pecl/memcache pecl/memcached
First Release Date 2004-06-08 2009-01-29 (beta)
Actively Developed Yes Yes
External Dependency None libmemcached
Automatic Key Fixup1 Yes No
Append/Prepend No Yes
Automatic Serialzation2 Yes Yes
Binary Protocol No Optional
CAS No Yes
Compression Yes Yes
Communication Timeout Connect Only Various Options
Consistent Hashing Yes Yes
Delayed Get No Yes
Multi-Get Yes Yes
Session Support Yes Yes
Set/Get to a specific server No Yes
Stores Numerics Converted to Strings Yes


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.