Rumah Tutorial sistem LINUX Pika: Tambah senario yang berkenaan untuk storan Redis berkapasiti besar

Pika: Tambah senario yang berkenaan untuk storan Redis berkapasiti besar

Jan 08, 2024 pm 10:14 PM
linux tutorial linux Topi Merah sistem linux arahan linux pensijilan linux linux topi merah video linux

Pengenalan Kami memperkenalkan kelahiran pika, ciri-ciri pika, teras pika dan penggunaan pika dalam "Large Capacity Redis Storage - Everything About Pika". Artikel itu menganalisis fail penting dalam logik penyegerakan pika dengan terperinci: kaedah penyimpanan data dan prinsip pelaksanaan "write2file", yang sangat berbaloi untuk dibaca!
pika

pika ialah storan seperti Redis berkapasiti besar yang dibangunkan bersama oleh Jabatan Platform Web 360 DBA dan pasukan infrastruktur Kemunculan pika bukan untuk menggantikan Redis, tetapi untuk melengkapkan senario Redis. Pika berusaha untuk menyelesaikan masalah Redis dalam senario berkapasiti besar melalui storan berterusan pada premis yang serasi sepenuhnya dengan protokol Redis dan mewarisi reka bentuk operasi dan penyelenggaraan yang mudah bagi Redis, seperti masa pemulihan yang perlahan, kos tinggi bagi tuan-hamba. penyegerakan, benang tunggal yang agak rapuh, dan kapasiti galas beban Data adalah terhad, kos memori tinggi, dsb.

binlog prinsip replikasi tuan-hamba pika

Fail berkaitan Binlog mengandungi dua bahagian: manifes dan write2file merekodkan maklumat meta log, termasuk nombor fail log semasa dan fail log semasa write2file+num merekodkan semua arahan dan parameter tulis redis yang diterima oleh pika.

Format fail

Format fail nyata:

Log offset (8 bait)|con_offset (8 bait, tidak digunakan)|Bilangan elemen (4 bait, tidak digunakan)|Log nombor fail (4 bait).

Format fail binlog:

Saiz tetap fail Binlog ialah 100MB Setiap fail Binlog terdiri daripada berbilang Blok Saiz setiap Blok ditetapkan pada 64KB Setiap arahan tulis redis. Rekod boleh diedarkan dalam berbilang Blok, tetapi ia hanya akan diedarkan dalam satu fail Binlog, jadi fail Binlog mungkin lebih besar daripada 100MB.

Format rekod: Pengepala|Cmd

Tajuk: Panjang Rekod (3 bait) |.

Cmd: sebahagian atau semua arahan redis, bergantung pada sama ada ruang yang tinggal pada Blok semasa boleh menyimpan Rekod.

Kelas pelaksanaan

Kelas asas

Versi: Kelas maklumat meta, dipetakan melalui mmap dan fail manifes.

Binlog: Kelas log, dipetakan melalui fail mmap dan write2file.

PikaBinlogSenderThread: Kelas penggunaan log, membaca kandungan fail log secara berurutan dan menggunakan log.

Operasi asas

Construct Binlog

//file_size boleh ditentukan dalam fail konfigurasi, lalai ialah 100MB

Binlog::Binlog(const std::string& binlog_path, const int file_size)

1.1 Buat direktori fail binlog.

1.2 Semak sama ada fail manifes dalam direktori log wujud Jika ia tidak wujud, buat yang baharu.

1.3 Mulakan kelas Versi mengikut fail manifes.

1.4 Cari fail log yang sepadan mengikut nombor fail dalam manifes, cari kedudukan tambah fail mengikut pro_offset, mulakan penuding log, rekod panjang kandungan log dan bilangan blok Blok.

Kemas kini status pengeluaran log semasa

//pro_num: Nombor fail log

//pro_offset: fail log offset

// Digunakan untuk mengemas kini maklumat binlog yang sepadan dengan contoh hamba apabila penyegerakan penuh diperlukan

Status Binlog::SetProducerStatus(uint32_t pro_num, uint64_t pro_offset)

2.1 Padam write2file0.

2.2 Padam write2file+pro_num.

2.3 Bina fail write2file+pro_num baharu, isikan ruang pro_offset, mulakan versi->pro_num kepada pro_num, versi->pro_offset kepada pro_offset dan muat semulanya ke fail manifes.

2.4 Mulakan saiz fail semasa dan block_offset.

Kemas kini status pengeluaran log semasa

//nombor fail: nombor log semasa

//pro_offset: offset log semasa

Status Binlog::GetProducerStatus(uint32_t* filenum, uint64_t* pro_offset)

3.1 Baca pro_num dan pro_offset dalam versi dan kembalikan.

Log pengeluaran

//Put->Produce->EmitPhysicalRecord

Status Binlog::Put(const std::string &item)

4.1 Semak sama ada fail log semasa memenuhi syarat pemotongan, dan jika ya, potong.

4.1.1 pro_num meningkat sebanyak 1 dan memulakan fail log baharu, version->pro_num=pro_num, version->pro_offset = 0, binlog->filesize = 0, binlog->block_offset = 0.

4.1.2 Jika baki saiz blok semasa ialah

4.1.3 Produce ialah gelung, yang memastikan bahawa apabila saiz item melebihi kBlockSize, berbilang EmitPhysicalRecord boleh dilakukan untuk melengkapkan semua data item yang jatuh ke dalam fail binlog Syarat untuk gelung keluar seperti biasa dibiarkan==0.

4.1.3.1 Jika dibiarkan

4.1.3.2 Jika dibiarkan > avail, ini bermakna berbilang Blok diperlukan untuk menyimpan item, kemudian Type=kFirstType buat kali pertama dan EmitPhysicalRecord dipanggil berbilang kali.

4.1.3.3 Jika dibiarkan > memanfaatkan, dan ini bukan kali pertama untuk EmitPhysicalRecord, kemudian Taip=kMiddleType, hubungi EmitPhysicalRecord beberapa kali.

4.1.4PancarkanRekod Fizikal.

4.1.4.1 Splice RecordHeader (panjang 3-bait + masa 4-bait + Jenis 1-bait), tulis data dan kemas kini block_offset dan pro_offset.

Log Penggunaan

// calar: Hasil penggunaan mengembalikan cmd redis yang lengkap

//Consume->ReadPhysicalRecord, ReadPhysicalRecord membaca Rekod lengkap setiap kali, berbilang Rekod membentuk cmd redis lengkap

Status PikaBinlogSenderThread::Consume(std::string &calar)

5.1Consume ialah gelung, yang boleh memanggil ReadPhysicalRecord beberapa kali Syarat untuk keluar gelung ialah read_type==kFullType atau record_type==kLastType.

5.1.1 Jika kBlockSize-last_record_offset_ <= kHeaderSize yang dibaca bermakna hujung Blok telah dibaca dan ia diisi dengan data, langkau ia.

5.1.2 Baca data, kemas kini last_record_offset_, con_offset.

Atas ialah kandungan terperinci Pika: Tambah senario yang berkenaan untuk storan Redis berkapasiti besar. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

DeepSeek Web Versi Pintu Masuk Laman Web Rasmi DeepSeek DeepSeek Web Versi Pintu Masuk Laman Web Rasmi DeepSeek Feb 19, 2025 pm 04:54 PM

DeepSeek adalah alat carian dan analisis pintar yang kuat yang menyediakan dua kaedah akses: versi web dan laman web rasmi. Versi web adalah mudah dan cekap, dan boleh digunakan tanpa pemasangan; Sama ada individu atau pengguna korporat, mereka dapat dengan mudah mendapatkan dan menganalisis data besar-besaran melalui DeepSeek untuk meningkatkan kecekapan kerja, membantu membuat keputusan dan menggalakkan inovasi.

Cara Memasang DeepSeek Cara Memasang DeepSeek Feb 19, 2025 pm 05:48 PM

Terdapat banyak cara untuk memasang DeepSeek, termasuk: Menyusun dari Sumber (untuk pemaju berpengalaman) menggunakan pakej yang dikompilasi (untuk pengguna Windows) menggunakan bekas docker (untuk yang paling mudah, tidak perlu bimbang tentang keserasian) Dokumen rasmi dengan berhati -hati dan menyediakannya sepenuhnya untuk mengelakkan masalah yang tidak perlu.

Bagaimana untuk menyelesaikan masalah kebenaran yang dihadapi semasa melihat versi Python di Terminal Linux? Bagaimana untuk menyelesaikan masalah kebenaran yang dihadapi semasa melihat versi Python di Terminal Linux? Apr 01, 2025 pm 05:09 PM

Penyelesaian kepada Isu Kebenaran Semasa Melihat Versi Python di Terminal Linux Apabila anda cuba melihat versi Python di Terminal Linux, masukkan Python ...

Pemasangan Laman Web Rasmi Bitget (Panduan Pemula 2025) Pemasangan Laman Web Rasmi Bitget (Panduan Pemula 2025) Feb 21, 2025 pm 08:42 PM

Bitget adalah pertukaran cryptocurrency yang menyediakan pelbagai perkhidmatan perdagangan termasuk perdagangan tempat, perdagangan kontrak dan derivatif. Ditubuhkan pada tahun 2018, pertukaran itu beribu pejabat di Singapura dan komited untuk menyediakan pengguna dengan platform perdagangan yang selamat dan boleh dipercayai. Bitget menawarkan pelbagai pasangan perdagangan, termasuk BTC/USDT, ETH/USDT dan XRP/USDT. Di samping itu, pertukaran mempunyai reputasi untuk keselamatan dan kecairan dan menawarkan pelbagai ciri seperti jenis pesanan premium, perdagangan leverage dan sokongan pelanggan 24/7.

Dapatkan Pakej Pemasangan Gate.io secara percuma Dapatkan Pakej Pemasangan Gate.io secara percuma Feb 21, 2025 pm 08:21 PM

Gate.io adalah pertukaran cryptocurrency yang popular yang boleh digunakan pengguna dengan memuat turun pakej pemasangannya dan memasangnya pada peranti mereka. Langkah -langkah untuk mendapatkan pakej pemasangan adalah seperti berikut: Lawati laman web rasmi Gate.io, klik "Muat turun", pilih sistem operasi yang sepadan (Windows, Mac atau Linux), dan muat turun pakej pemasangan ke komputer anda. Adalah disyorkan untuk mematikan perisian antivirus atau firewall sementara semasa pemasangan untuk memastikan pemasangan yang lancar. Selepas selesai, pengguna perlu membuat akaun Gate.io untuk mula menggunakannya.

Pakej pemasangan OUYI OKX disertakan secara langsung Pakej pemasangan OUYI OKX disertakan secara langsung Feb 21, 2025 pm 08:00 PM

Ouyi Okx, pertukaran aset digital terkemuka di dunia, kini telah melancarkan pakej pemasangan rasmi untuk menyediakan pengalaman perdagangan yang selamat dan mudah. Pakej pemasangan OKX OUYI tidak perlu diakses melalui penyemak imbas. Proses pemasangan adalah mudah dan mudah difahami.

Bagaimana cara menetapkan kebenaran secara automatik UnixSocket selepas sistem dimulakan semula? Bagaimana cara menetapkan kebenaran secara automatik UnixSocket selepas sistem dimulakan semula? Mar 31, 2025 pm 11:54 PM

Bagaimana untuk menetapkan keizinan UnixSocket secara automatik selepas sistem dimulakan semula. Setiap kali sistem dimulakan semula, kita perlu melaksanakan perintah berikut untuk mengubahsuai keizinan UnixSocket: sudo ...

Portal rasmi muat turun Ouyi Exchange Portal rasmi muat turun Ouyi Exchange Feb 21, 2025 pm 07:51 PM

Ouyi, juga dikenali sebagai Okx, adalah platform perdagangan cryptocurrency terkemuka di dunia. Artikel ini menyediakan portal muat turun untuk pakej pemasangan rasmi Ouyi, yang memudahkan pengguna memasang klien OUYI pada peranti yang berbeza. Pakej pemasangan ini menyokong sistem Windows, Mac, Android dan iOS. Selepas pemasangan selesai, pengguna boleh mendaftar atau log masuk ke akaun OUYI, mula membuat kriptografi perdagangan dan nikmati perkhidmatan lain yang disediakan oleh platform.

See all articles