cari
Rumahpembangunan bahagian belakangtutorial phpBagaimana untuk melaksanakan pembahagian pangkalan data Memcached dalam PHP

Bagaimana untuk melaksanakan pembahagian pangkalan data Memcached dalam PHP

May 16, 2023 am 09:40 AM
phpmemcachedPecahan pangkalan data

Dengan pembangunan aplikasi web, kerumitan pemprosesan data semakin tinggi. Untuk menyediakan kebolehskalaan dan prestasi yang lebih baik, banyak aplikasi telah menggunakan pangkalan data NoSQL. Memcached ialah cache dalam memori NoSQL yang popular yang boleh meningkatkan masa tindak balas aplikasi web dengan ketara sambil turut menyediakan ketersediaan data yang tinggi.

Walau bagaimanapun, apabila aplikasi anda berkembang, kapasiti storan satu contoh Memcached mungkin mencapai hadnya. Dalam kes ini, teknologi pembahagian pangkalan data Memcached perlu digunakan untuk menyebarkan data merentasi berbilang pelayan. Dalam artikel ini, kita akan belajar bagaimana untuk melaksanakan pembahagian pangkalan data Memcached menggunakan PHP.

Sharding pelayan Memcached

Dalam Memcached, fungsi cincang digunakan untuk memetakan kunci data ke pelayan tertentu. Fungsi hash boleh menjadi MD5, CRC32, dsb. Apabila data ditambah atau dikemas kini, Memcached menggunakan fungsi cincang untuk mengira kunci dan menentukan pelayan yang hendak digunakan. Apabila menggunakan pembahagian pangkalan data Memcached, kita perlu memetakan kunci ke pelayan tertentu menggunakan kaedah yang sama seperti fungsi cincang. Ini boleh dilakukan dengan mengikut langkah:

  1. Tentukan senarai pelayan
    Dalam pembahagian Memcached, data perlu disimpan dalam berbilang pelayan. Kita boleh menentukan tatasusunan yang mengandungi alamat IP dan nombor port pelayan. Contohnya:

$servers = array(

'192.168.1.101:11211', // Server 1
'192.168.1.102:11211', // Server 2
'192.168.1.103:11211' // Server 3

);

  1. Kira nilai cincang
    Untuk mencincang data, anda perlu menggunakan fungsi cincang A. Memcached menyediakan beberapa fungsi cincang terbina dalam, termasuk MD5 dan CRC32. Kita boleh menggunakan mana-mana daripadanya untuk mengira nilai cincang. Contohnya menggunakan fungsi cincang MD5:

$hash = md5('mykey');

  1. Pilih pelayan
    Nilai cincang yang dikira menggunakan fungsi cincang harus Peta ke pelayan Memcached sebenar. Ini boleh dilakukan dengan membahagikan nilai cincang ke dalam selang waktu. Contohnya, jika terdapat tiga pelayan, kami memetakan cincangan kepada julat 0-32, 33-64 dan 65-96. Ini boleh dilakukan dengan langkah berikut:
  • Kira cincang bagi integer 32-bit tidak bertanda
  • Bahagikan integer itu kepada selang
  • Petakan selang Ke pelayan

gunakan kod berikut untuk melaksanakan:

$hash = md5('mykey');
$hash_number = intval("0x".substr( $hash, 0, 8));
$server_index = $hash_number % count($servers);
$server = $servers[$server_index];

Dalam contoh ini, kita mula-mula menggunakan MD5 hash Hash memetakan "mykey" kepada nilai hash. Kami kemudian mengira nilai integer tidak bertanda 32-bit dan mengira modulus nilai itu menggunakan panjang tatasusunan pelayan. Ini akan memberi kami indeks pelayan dan kami boleh menggunakan indeks itu untuk mendapatkan alamat IP pelayan dan nombor port yang betul daripada senarai pelayan.

  1. Simpan data
    Dalam langkah ini, kami menyimpan data pada pelayan Memcached. Dalam kes menggunakan senarai pelayan, kita perlu menggunakan kelas Memcached daripada perpustakaan sambungan Memcached dan menyerahkan senarai pelayan kepada mereka. Pada masa yang sama, kita juga perlu menggunakan nilai hash dan pelayan dari langkah sebelumnya untuk menentukan pelayan sebenar tempat data disimpan. Contohnya:

$memcached = Memcached baharu();
$memcached->addServers($servers);

$hash = md5('mykey');
$hash_number = intval("0x".substr($hash, 0, 8));
$server_index = $hash_number % count($servers);
$server = $servers[$server_index] ;

$memcached->setByKey($server, 'mykey', 'data', 60);

Dalam contoh ini, kami mula-mula memanggil addServers() kelas Memcached menggunakan tatasusunan pelayan Kaedah yang menentukan senarai pelayan untuk digunakan. Kami kemudian menggunakan cincang dan pelayan untuk memanggil kaedah setByKey() untuk menyimpan data ke dalam pelayan yang betul. Kami juga menyediakan masa tamat tempoh (60 saat).

  1. Mendapatkan data
    Dalam kes sharding, anda perlu menggunakan kaedah getByKey() untuk mendapatkan semula data daripada pelayan yang betul. Contohnya:

$hash = md5('mykey');
$hash_number = intval("0x".substr($hash, 0, 8));
$server_index = $hash_number % count($servers);
$server = $servers[$server_index];

$data = $memcached->getByKey($server, 'mykey');

Dalam contoh ini, kami menggunakan nilai cincang dan pelayan untuk memanggil kaedah getByKey() untuk mendapatkan semula data daripada pelayan yang betul. Jika kunci tidak wujud, mengembalikan null.

Ringkasan

Apabila menggunakan Memcached, anda boleh menggunakan teknologi sharding untuk menyimpan data pada berbilang pelayan. Menggunakan PHP, kita boleh menggunakan kelas Memcached dalam perpustakaan sambungan Memcached, yang menyediakan pelbagai kaedah untuk menambah pelayan, menyediakan dan mendapatkan data. Menggunakan fungsi cincang, kami boleh mengira cincang kunci dan memetakannya ke pelayan yang betul. Ingat, pilihan fungsi cincang dan peruntukan selang akan secara langsung mempengaruhi keseimbangan dan prestasi data.

Atas ialah kandungan terperinci Bagaimana untuk melaksanakan pembahagian pangkalan data Memcached dalam PHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
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
Bagaimanakah jenis membayangkan jenis PHP, termasuk jenis skalar, jenis pulangan, jenis kesatuan, dan jenis yang boleh dibatalkan?Bagaimanakah jenis membayangkan jenis PHP, termasuk jenis skalar, jenis pulangan, jenis kesatuan, dan jenis yang boleh dibatalkan?Apr 17, 2025 am 12:25 AM

Jenis PHP meminta untuk meningkatkan kualiti kod dan kebolehbacaan. 1) Petua Jenis Skalar: Oleh kerana Php7.0, jenis data asas dibenarkan untuk ditentukan dalam parameter fungsi, seperti INT, Float, dan lain -lain. 2) Return Type Prompt: Pastikan konsistensi jenis nilai pulangan fungsi. 3) Jenis Kesatuan Prompt: Oleh kerana Php8.0, pelbagai jenis dibenarkan untuk ditentukan dalam parameter fungsi atau nilai pulangan. 4) Prompt jenis yang boleh dibatalkan: membolehkan untuk memasukkan nilai null dan mengendalikan fungsi yang boleh mengembalikan nilai null.

Bagaimanakah PHP mengendalikan pengklonan objek (kata kunci klon) dan kaedah sihir __clone?Bagaimanakah PHP mengendalikan pengklonan objek (kata kunci klon) dan kaedah sihir __clone?Apr 17, 2025 am 12:24 AM

Dalam PHP, gunakan kata kunci klon untuk membuat salinan objek dan menyesuaikan tingkah laku pengklonan melalui kaedah Magic \ _ _ _. 1. Gunakan kata kunci klon untuk membuat salinan cetek, mengkloning sifat objek tetapi bukan sifat objek. 2. Kaedah klon \ _ \ _ boleh menyalin objek bersarang untuk mengelakkan masalah menyalin cetek. 3. Beri perhatian untuk mengelakkan rujukan pekeliling dan masalah prestasi dalam pengklonan, dan mengoptimumkan operasi pengklonan untuk meningkatkan kecekapan.

PHP vs Python: Gunakan Kes dan AplikasiPHP vs Python: Gunakan Kes dan AplikasiApr 17, 2025 am 12:23 AM

PHP sesuai untuk pembangunan web dan sistem pengurusan kandungan, dan Python sesuai untuk sains data, pembelajaran mesin dan skrip automasi. 1.PHP berfungsi dengan baik dalam membina laman web dan aplikasi yang cepat dan berskala dan biasanya digunakan dalam CMS seperti WordPress. 2. Python telah melakukan yang luar biasa dalam bidang sains data dan pembelajaran mesin, dengan perpustakaan yang kaya seperti numpy dan tensorflow.

Huraikan tajuk caching HTTP yang berbeza (mis., Cache-Control, ETAG, Modified Last).Huraikan tajuk caching HTTP yang berbeza (mis., Cache-Control, ETAG, Modified Last).Apr 17, 2025 am 12:22 AM

Pemain utama dalam tajuk cache HTTP termasuk kawalan cache, ETAG, dan modifikasi terakhir. 1.Cache-Control digunakan untuk mengawal dasar caching. Contoh: Cache-Control: Max-Age = 3600, Awam. 2. ETAG mengesahkan perubahan sumber melalui pengenal unik, Contoh: ETAG: "686897696A7C876B7E". 3. Modified Last Menunjukkan Masa Pengubahsuaian Terakhir Sumber, Contoh: Modified Last: Wed, 21OCT201507: 28: 00GMT.

Terangkan hashing kata laluan yang selamat di PHP (mis., Password_hash, password_verify). Mengapa tidak menggunakan MD5 atau SHA1?Terangkan hashing kata laluan yang selamat di PHP (mis., Password_hash, password_verify). Mengapa tidak menggunakan MD5 atau SHA1?Apr 17, 2025 am 12:06 AM

Dalam php, kata laluan_hash dan kata laluan 1) password_hash menjana hash yang mengandungi nilai garam untuk meningkatkan keselamatan. 2) Kata Laluan_verify Sahkan kata laluan dan pastikan keselamatan dengan membandingkan nilai hash. 3) MD5 dan SHA1 terdedah dan kekurangan nilai garam, dan tidak sesuai untuk keselamatan kata laluan moden.

PHP: Pengenalan kepada bahasa skrip sisi pelayanPHP: Pengenalan kepada bahasa skrip sisi pelayanApr 16, 2025 am 12:18 AM

PHP adalah bahasa skrip sisi pelayan yang digunakan untuk pembangunan web dinamik dan aplikasi sisi pelayan. 1.Php adalah bahasa yang ditafsirkan yang tidak memerlukan kompilasi dan sesuai untuk perkembangan pesat. 2. Kod PHP tertanam dalam HTML, menjadikannya mudah untuk membangunkan laman web. 3. PHP memproses logik sisi pelayan, menghasilkan output HTML, dan menyokong interaksi pengguna dan pemprosesan data. 4. PHP boleh berinteraksi dengan pangkalan data, penyerahan borang proses, dan melaksanakan tugas-tugas sampingan pelayan.

PHP dan Web: Meneroka kesan jangka panjangnyaPHP dan Web: Meneroka kesan jangka panjangnyaApr 16, 2025 am 12:17 AM

PHP telah membentuk rangkaian sejak beberapa dekad yang lalu dan akan terus memainkan peranan penting dalam pembangunan web. 1) PHP berasal pada tahun 1994 dan telah menjadi pilihan pertama bagi pemaju kerana kemudahan penggunaannya dan integrasi lancar dengan MySQL. 2) Fungsi terasnya termasuk menghasilkan kandungan dinamik dan mengintegrasikan dengan pangkalan data, yang membolehkan laman web dikemas kini secara real time dan dipaparkan secara peribadi. 3) Aplikasi dan ekosistem PHP yang luas telah mendorong kesan jangka panjangnya, tetapi ia juga menghadapi kemas kini versi dan cabaran keselamatan. 4) Penambahbaikan prestasi dalam beberapa tahun kebelakangan ini, seperti pembebasan Php7, membolehkannya bersaing dengan bahasa moden. 5) Pada masa akan datang, PHP perlu menangani cabaran baru seperti kontena dan microservices, tetapi fleksibiliti dan komuniti aktif menjadikannya boleh disesuaikan.

Mengapa menggunakan PHP? Kelebihan dan faedah dijelaskanMengapa menggunakan PHP? Kelebihan dan faedah dijelaskanApr 16, 2025 am 12:16 AM

Manfaat utama PHP termasuk kemudahan pembelajaran, sokongan pembangunan web yang kukuh, perpustakaan dan kerangka yang kaya, prestasi tinggi dan skalabilitas, keserasian silang platform, dan keberkesanan kos. 1) mudah dipelajari dan digunakan, sesuai untuk pemula; 2) integrasi yang baik dengan pelayan web dan menyokong pelbagai pangkalan data; 3) mempunyai rangka kerja yang kuat seperti Laravel; 4) Prestasi tinggi dapat dicapai melalui pengoptimuman; 5) menyokong pelbagai sistem operasi; 6) Sumber terbuka untuk mengurangkan kos pembangunan.

See all articles

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)
1 bulan yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
1 bulan yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
1 bulan yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Arahan sembang dan cara menggunakannya
1 bulan yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

SecLists

SecLists

SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.

PhpStorm versi Mac

PhpStorm versi Mac

Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini

Dreamweaver Mac版

Dreamweaver Mac版

Alat pembangunan web visual

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual