Redis가 다양한 메모리 할당자를 사용하여 조각화 속도를 비교하는 방법

WBOY
풀어 주다: 2023-05-26 10:58:21
앞으로
1606명이 탐색했습니다.

 Redis의 zmalloc.c 소스 코드에서 다음 코드를 볼 수 있습니다.

   /* tcmalloc을 사용할 때 malloc/free 등을 명시적으로 재정의합니다. */

  #if 정의(USE_TCMALLOC)

  #define malloc(size) tc_malloc (크기)

tc_calloc(count,size)는 calloc 함수의 정의

 #define realloc(ptr,size) tc_realloc(ptr,size)

 #define free(ptr) tc_free(ptr)

 #elif Defined( USE_JEMAALLOC)

  #define malloc(size) je_malloc(size)

다음 문장은 요청에 따라 다시 작성되었습니다. "#define calloc(count,size) je_calloc(count,size)" 문은 표준 정의 함수 "calloc"을 "je_calloc"이라는 사용자 정의 함수로 바꾸는 데 사용됩니다.

  #define realloc(ptr,size) je_realloc( ptr, size)

  #define free(ptr) je_free(ptr)

  #endif

  위의 코드를 보면 Redis가 컴파일되면 먼저 tcmalloc을 사용할지 여부를 결정하게 된다는 것을 알 수 있습니다. tcmalloc을 사용하십시오. 해당 함수는 표준 libc의 함수 구현을 대체합니다. 그런 다음 jemalloc이 적용되는지 확인합니다. 그렇지 않으면 표준 libc의 메모리 관리 기능이 사용됩니다.

 최신 버전 2.4.4에서는 jemalloc이 소스코드 패키지의 일부로 포함되어 있어 바로 사용할 수 있습니다. 그리고 tcmalloc을 사용하려면 직접 설치해야 합니다.

  tcmalloc 패키지 설치 방법에 대해 간략하게 설명하겠습니다. tcmalloc은 google-proftools의 일부이므로 실제로 google-proftools를 설치해야 합니다. 64비트 시스템에 설치하는 경우 필수 libunwind 라이브러리를 먼저 설치해야 합니다.

 wget http://download.savannah.gnu.org/releases/libunwind/libunwind-0.99-alpha.tar.gz

 tar zxvf libunwind-0.99-alpha.tar.gz

 cd libunwind-0.99-alpha/

  CFLAGS=-fPIC ./configure

  make CFLAGS=-fPIC

  make CFLAGS=-fPIC install

  Redis가 조각화 속도를 비교하기 위해 다양한 메모리 할당자를 사용하는 방법

  그런 다음 google-pre를 설치합니다. ftools:

 wget http: //google-perftools.googlecode.com/files/google-perftools-1.8.1.tar.gz

 tar zxvf google-perftools-1.8.1.tar.gz

 cd google-perftools-1.8.1 /

  ./configure --disable-cpu-profiler --disable-heap-profiler --disable-heap-checker --disable-debugalloc --enable-minimal

 make && make install

  sudo echo "/usr /local /lib" > /etc/ld.so.conf.d/usr_local_lib.conf #이 파일이 없으면 직접 생성하세요

  sudo /sbin/ldconfig

  그런 다음 Redis를 설치하고 Corresponding 작성 시 지정합니다. tcmalloc

 $ 컬 -O http://redis.googlecode.com/files/redis-2.4.4.tar.gz

 $ tar xzvf redis-2.4.4.tar.gz

 $ cd redis를 활성화하는 매개변수 -2.4.4

 $ make USE_TCMALLOC=yes FORCE_LIBC_MALLOC=yes

 $ sudo make install

 Redis를 다시 시작한 후 info 명령을 통해 사용된 메모리 할당자를 확인할 수 있습니다.

이 기사의 주제로 돌아가서 이 기사에서는 tcmalloc, jemalloc 및 libc에 해당하는 세 가지 메모리 할당자에 대해 설명합니다. 다음은 성능과 조각화율을 평가하기 위해 고안된 Redis 정보 정보에서 가져온 간단한 테스트 결과입니다. 테스트에서는 다른 할당자를 사용했습니다. 아래와 같이 tcmalloc을 사용할 때 조각화 속도가 1.01이고 jemalloc이 1.02이며 libc의 할당자 조각화 속도가 1.31임을 알 수 있습니다. 5.98M

 mem_fragmentation_ratio: 1.01

 mem_allocator:tcmalloc-1.7

Used_memory:708381168

Used_menory_human:675.56M

Used_memory_rss:723587072

Used_memory_peak:70880 3768

Used_memory_peak_human:675 .97 M

  mem_fragmentation_ratio:1.02

mem_allocator:jemalloc-2.2. 1

used_memory:869000400

used_menory_human:828.74M

used_memory_rss:11 36689152

 used_memory_peak:868992208

 used_memory_peak _human:828.74M

 mem_fragmentation_ratio:1.31

 mem_allocator :libc

위 내용은 Redis가 다양한 메모리 할당자를 사용하여 조각화 속도를 비교하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:yisu.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!