Bagaimana untuk menggunakan kunci yang diedarkan untuk mengawal akses serentak dalam MySQL?

WBOY
Lepaskan: 2023-07-30 22:04:47
asal
1401 orang telah melayarinya

Bagaimana untuk menggunakan kunci yang diedarkan untuk mengawal akses serentak dalam MySQL?

Dalam sistem pangkalan data, akses serentak yang tinggi adalah masalah biasa, dan kunci yang diedarkan adalah salah satu penyelesaian yang biasa digunakan. Artikel ini akan memperkenalkan cara menggunakan kunci teragih dalam MySQL untuk mengawal akses serentak dan menyediakan contoh kod yang sepadan.

1. Prinsip
Kunci yang diedarkan boleh digunakan untuk melindungi sumber yang dikongsi untuk memastikan hanya satu utas boleh mengakses sumber pada masa yang sama. Dalam MySQL, kunci teragih boleh dilaksanakan dengan cara berikut:

  • Buat jadual bernama lock_table untuk menyimpan status kunci. Jadual perlu mengandungi sekurang-kurangnya medan berikut: nama kunci, pemegang kunci, status kunci, dsb.
  • Akses dan ubah suai lock_table dengan menggunakan transaksi dan kunci peringkat baris. . Jadual ditakrifkan seperti berikut:
BUAT JADUAL jadual_kunci (

id INT NOT NULL AUTO_INCREMENT,
lock_name VARCHAR(64) NOT NULL,

pemegang_kunci
VARCHAR(64) LAILA NULL,

status INT lalai '0',
masa_dicipta TIMESTAMP lalai CURRENT_TIMESTAMP,

KUNCI UTAMA (id ),

UNIQUE KUNCI lock_name (lock_name)lock_table (
id INT NOT NULL AUTO_INCREMENT,
lock_name VARCHAR(64) NOT NULL,
lock_holder VARCHAR(64) DEFAULT NULL,
status INT DEFAULT '0',
created_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
PRIMARY KEY (id),
UNIQUE KEY lock_name (lock_name) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

Langkah 2: Dapatkan kunci yang diedarkan

The berikut ialah contoh Kod pemerolehan kunci yang diedarkan:

MULAKAN TRANSAKSI;

PILIH * DARI lock_table DI MANA lock_name = 'my_lock' UNTUK KEMASKINI;

-- Tentukan sama ada benang lain sudah memegang kunci

lock_table_NAME WHERE = lock 'my_lock' AND status = 1;

-- Jika tiada benang lain yang memegang kunci, anda boleh menetapkan diri anda sebagai pemegang kunci dan menetapkan status kunci kepada 1

MASUKKAN KE DALAM meja_kunci (nama_kunci, pemegang_kunci, status) NILAI ( 'my_lock', 'thread_id', 1);

COMMIT;

Langkah 3: Lepaskan kunci yang diedarkan

Apabila urutan menyelesaikan operasi sumber kongsi, kunci yang diedarkan harus dilepaskan tepat pada masanya. Berikut ialah contoh kod untuk melepaskan kunci yang diedarkan:

MULAKAN TRANSAKSI

PILIH * DARI lock_table DI MANA lock_name = 'my_lock' UNTUK KEMASKINI

-- Tentukan sama ada benang semasa memegang kunci

WHEREROM * WHEREROM; lock_name = ' my_lock' AND lock_holder = 'thread_id';

-- Jika benang semasa memegang kunci, kemudian tetapkan pemegang kunci dan status kepada null dan 0

KEMASKINI lock_table SET lock_holder = NULL, status = 0 WHERE lock_name = ' my_lock ' AND lock_holder = 'thread_id';

COMMIT;

3 Nota

Apabila menggunakan kunci yang diedarkan, anda perlu memberi perhatian kepada perkara berikut:

    Cuba elakkan urus niaga yang lama: Transaksi yang lama akan menduduki sumber kunci dan menyebabkan utas lain untuk Masa menunggu terlalu lama. Oleh itu, tempoh urus niaga harus diminimumkan dan operasi pada sumber yang dikongsi harus diselesaikan secepat mungkin.
  • Elak kebuntuan: Jalan buntu merujuk kepada situasi di mana dua atau lebih transaksi sedang menunggu antara satu sama lain untuk melepaskan sumber kunci, mengakibatkan ketidakupayaan untuk meneruskan. Untuk mengelakkan berlakunya kebuntuan, anda harus memberi perhatian kepada susunan pemerolehan dan pelepasan kunci apabila menggunakan kunci yang diedarkan.
  • Pertimbangkan pengurusan kunci dalam persekitaran teragih: Dalam persekitaran teragih, contoh pangkalan data yang berbeza mungkin menghadapi masalah seperti kelewatan rangkaian, jadi pengurusan dan penjadualan kunci teragih perlu dipertimbangkan. Anda boleh menggunakan perkhidmatan kunci teragih atau alat penyelarasan teragih lain untuk mengurus peruntukan dan pelepasan sumber kunci.
4 Ringkasan

Artikel ini memperkenalkan cara menggunakan kunci teragih untuk mengawal akses serentak dalam MySQL dan menyediakan contoh kod yang sepadan. Kunci teragih ialah cara yang biasa digunakan untuk menyelesaikan masalah akses serentak yang tinggi, tetapi langkah berjaga-jaga perlu diambil apabila menggunakannya untuk mengelakkan urus niaga yang lama dan kebuntuan. Dalam persekitaran yang diedarkan, pengurusan kunci dan penjadualan juga perlu dipertimbangkan.

Atas ialah kandungan terperinci Bagaimana untuk menggunakan kunci yang diedarkan untuk mengawal akses serentak dalam MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:php.cn
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!