Rumah > pangkalan data > Redis > teks badan

Cara Redis menggunakan pengagih memori yang berbeza untuk membandingkan kadar pemecahan

WBOY
Lepaskan: 2023-05-26 10:58:21
ke hadapan
1604 orang telah melayarinya

Dalam kod sumber zmalloc.c Redis, kita boleh melihat kod berikut:

/* Gantikan malloc/free dsbnya secara eksplisit apabila menggunakan tcmalloc */

#jika ditakrifkan(USE_TCMALLOC )

 #define malloc(size) tc_malloc(size)

tc_calloc(count,size) ialah takrifan calloc function

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

 #takrifkan percuma(ptr) tc_free(ptr)

 #elif ditakrifkan(USE_JEMALLOC)

 #takrifkan malloc(saiz) je_malloc(saiz) >

Ayat berikut ditulis semula seperti yang diminta: Pernyataan "#define calloc(count,size) je_calloc(count,size)" digunakan untuk menggantikan fungsi standard yang ditakrifkan "calloc" dengan fungsi tersuai bernama "je_calloc".

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

  #define free(ptr) je_free(ptr)

  #endif

Daripada kod di atas kita dapat lihat bahawa Redis adalah Semasa menyusun , ia akan terlebih dahulu menentukan sama ada untuk menggunakan tcmalloc Jika ya, pelaksanaan fungsi dalam libc standard akan digantikan dengan fungsi yang sepadan dengan tcmalloc. Selepas ini, ia akan menyemak sama ada jemalloc berkuat kuasa Jika tidak, fungsi pengurusan memori dalam libc standard akan digunakan.

Dalam versi 2.4.4 terkini, jemalloc telah dimasukkan ke dalam pakej kod sumber sebagai sebahagian daripada pakej kod sumber, jadi ia boleh digunakan secara langsung. Dan jika anda ingin menggunakan tcmalloc, anda perlu memasangnya sendiri.

Mari kita bincangkan secara ringkas tentang cara memasang pakej tcmalloc ialah sebahagian daripada google-proftools, jadi kita sebenarnya perlu memasang google-proftools. Apabila memasang pada mesin 64-bit, perpustakaan libunwind yang diperlukan mesti dipasang terlebih dahulu.

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

buat CFLAGS=-fPIC

buat pemasangan CFLAGS=-fPIC

Perbandingan kadar pemecahan cara Redis menggunakan pengagih memori yang berbeza

Kemudian pasang google-preftools:

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 #Jika anda tidak mempunyai fail ini, buat sendiri

sudo /sbin/ldconfig

Kemudian pasang Redis dan nyatakan parameter yang sepadan semasa membuat untuk mendayakan tcmalloc

$ curl -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=ya

>

 Selepas memulakan semula Redis, anda boleh melihat pengalokasi memori yang digunakan melalui arahan info.

Berbalik kepada topik artikel ini, artikel ini membincangkan tiga pengagih memori yang sepadan dengan tcmalloc, jemalloc dan libc. Di bawah ialah hasil ujian ringkas, diambil daripada maklumat Redis, direka untuk menilai prestasi dan kadar pemecahannya. Ujian menggunakan pengagih yang berbeza. Kita dapat melihat bahawa kadar pemecahan adalah paling rendah apabila menggunakan tcmalloc, iaitu 1.01, jemalloc ialah 1.02 dan kadar pemecahan pengalokasi libc ialah 1.31, seperti yang ditunjukkan di bawah:

used_memory:708391440

>

used_memory_rss:715169792

used_memory_peak:708814040

used_memory_puncak_manusia:675.98M 🎜> mem_allocator:tcmalloc - 1.7

used_memory:708381168

used_menory_human:675.56M

used_memory_rss:723587072

used_menory_human:675.56M

used_memory_rss:723587072

mem_fragmentation_ratio: 1.02

mem_allocator: jemalloc-2.2.1

.

Atas ialah kandungan terperinci Cara Redis menggunakan pengagih memori yang berbeza untuk membandingkan kadar pemecahan. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:yisu.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!