Transaksi teragih dalam PHP
Dengan perkembangan pesat era maklumat, industri e-dagang terus berkembang, dan teknologi yang sepadan sentiasa dikemas kini dan diulang. Antaranya, sistem teragih adalah salah satu seni bina arus perdana dalam industri e-dagang semasa, yang bertujuan untuk meningkatkan ketersediaan dan kebolehskalaan sistem. Dalam sistem yang diedarkan, pemprosesan transaksi adalah masalah yang tidak dapat dielakkan, dan transaksi yang diedarkan adalah kunci kepada pemprosesan transaksi. Artikel ini akan memperkenalkan transaksi teragih dalam PHP.
1. Gambaran keseluruhan urus niaga yang diedarkan
Dalam persekitaran yang berdiri sendiri, urus niaga merujuk kepada satu set operasi, yang semuanya berjaya dilaksanakan atau semuanya dibatalkan. Dalam persekitaran yang diedarkan, urus niaga perlu menjangkau berbilang nod untuk diselesaikan. Operasi setiap nod adalah seperti yang dijangkakan, tetapi jika mana-mana operasi gagal atau gagal, keseluruhan transaksi akan gagal. Oleh itu, urus niaga teragih merujuk kepada transaksi yang berjalan dalam persekitaran teragih.
Urus niaga yang diedarkan boleh menjadikan sistem lebih berskala dan sangat tersedia, di samping meningkatkan prestasi sistem. Walau bagaimanapun, pelaksanaan transaksi yang diedarkan adalah lebih kompleks, dan objek yang menjadi perhatian telah berubah daripada data itu sendiri ke lokasi data, dan juga melibatkan proses komunikasi dan penyelarasan yang sepadan.
2. Protokol urus niaga teragih biasa
Protokol transaksi teragih biasa termasuk Komit Dua fasa (2PC) dan Komit Tiga fasa (3PC) .
2PC merujuk kepada protokol dua peringkat dalam persekitaran yang diedarkan. Pada fasa pertama, penyelaras bertanya kepada semua peserta sama ada mereka bersedia untuk melakukan transaksi. Jika semua peserta sudah bersedia, pada fasa kedua, penyelaras meminta semua peserta untuk melakukan transaksi. Jika mana-mana peserta tidak bersedia, penyelaras akan meminta semua peserta membalikkan operasi mereka sebelum ini.
3PC merujuk kepada protokol tiga peringkat dalam persekitaran yang diedarkan. Fasa pertama adalah sama seperti 2PC, penyelaras bertanya kepada semua peserta sama ada mereka bersedia untuk melakukan transaksi. Jika semuanya sudah siap, pada fasa kedua, penyelaras bertanya kepada semua peserta sama ada transaksi itu berjaya dilakukan. Jika semua peserta berjaya menghantar, maka dalam fasa ketiga, penyelaras akan memberitahu semua peserta bahawa sumber boleh dikeluarkan.
3PC mempunyai kelebihan berbanding 2PC, iaitu jika mana-mana peserta tidak menjawab permintaan pada fasa pertama, penyelaras akan membenarkan semua peserta melakukan transaksi kerana ia mengetahui sama ada peserta bersedia untuk melakukan. hal ehwal. Dalam 2PC, jika mana-mana peserta gagal menjawab permintaan, penyelaras akan meminta semua peserta membalikkan operasi mereka sebelum ini.
3. Pelaksanaan transaksi teragih dalam PHP
Dalam PHP, terdapat banyak cara untuk melaksanakan transaksi teragih, termasuk melalui perisian tengah transaksi teragih, melalui baris gilir mesej, melalui penyerahan dan penyelesaian separa, dsb.
1. Diselesaikan oleh middleware
Middleware boleh menggabungkan berbilang transaksi untuk membentuk transaksi teragih, dengan itu melindungi atomicity dan konsistensi keseluruhan operasi, seperti TCC (Cuba, Sahkan, Batal, ini model mencapai atomicity transaksi melalui sumber terpelihara dan semakan status) dan XA (komit dua fasa).
Antaranya, 2PC milik XA, tetapi 2PC mempunyai masalah, seperti kegagalan titik tunggal penyelaras, kesesakan rangkaian, tamat masa dan masalah lain, yang boleh membawa kepada penyekatan dan pengecualian dengan mudah. Pelaksanaan TCC adalah agak mudah Ia memastikan pelaksanaan transaksi yang diedarkan dengan mengawal sumber dan status simpanan.
2. Selesaikan melalui baris gilir mesej
Baris gilir mesej ialah teknologi baru muncul yang boleh menyelesaikan masalah transaksi dalam sistem teragih. Melalui baris gilir mesej, transaksi boleh dibahagikan kepada beberapa sub-urus niaga dan diproses melalui baris gilir.
Apabila sub-urus niaga berjaya dilaksanakan, mesej dihantar ke baris gilir mesej Mesej ini memberitahu pengguna bahawa sub-urus niaga telah selesai. Jika semua sub-urus niaga berjaya dilaksanakan, maka keseluruhan transaksi dilakukan, jika tidak, keseluruhan urus niaga dibatalkan.
Transaksi teragih yang dilaksanakan melalui baris gilir mesej mempunyai prestasi dan kebolehpercayaan yang lebih baik, tetapi pelaksanaannya agak rumit dan memerlukan pelabelan dan statistik untuk setiap sub-urus niaga.
3. Selesaikan melalui penyerahan separa
Malah, masalah transaksi yang diedarkan boleh diselesaikan melalui penyerahan separa dalam PHP. Penyerahan separa yang dipanggil adalah untuk membahagikan proses penyerahan keseluruhan asal kepada pelaksanaan dan penyerahan beberapa sub-tugas.
Apabila setiap subtugas dilaksanakan, ia hanya mengubah suai transaksi setempat dan melaksanakannya secara setempat, tanpa berinteraksi dengan nod lain. Selepas semua subtugas dilaksanakan, tunggu isyarat "boleh komit" dihantar oleh pemprofil, dan kemudian komit secara keseluruhan untuk memastikan konsistensi transaksi.
4. Ringkasan
PHP ialah bahasa pengaturcaraan yang biasa digunakan dan secara beransur-ansur digunakan dalam sistem teragih. Dalam sistem yang diedarkan, pemprosesan transaksi adalah masalah yang tidak dapat dielakkan, dan transaksi yang diedarkan adalah kunci kepada pemprosesan transaksi. Dalam PHP, transaksi yang diedarkan boleh diselesaikan melalui perisian tengah, melalui baris gilir mesej, melalui penyerahan tempatan, dsb. Memilih kaedah yang berbeza memerlukan mempertimbangkan senario aplikasi sebenar transaksi yang diedarkan, serta keperluan untuk prestasi, kebolehskalaan dan toleransi kesalahan.
Atas ialah kandungan terperinci Transaksi teragih dalam PHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Artikel ini akan menerangkan secara terperinci bagaimana PHP memformat baris ke dalam CSV dan menulis penunjuk fail saya rasa ia agak praktikal, jadi saya berkongsi dengan anda sebagai rujukan saya harap anda boleh memperoleh sesuatu selepas membaca artikel ini. Format baris ke CSV dan tulis ke penuding fail Langkah 1: Buka penuding fail $file=fopen("path/to/file.csv","w"); kepada rentetan CSV. Fungsi ini menerima parameter berikut: $fail: penuding fail $medan: medan CSV sebagai tatasusunan $pembatas: pembatas medan (pilihan) $kepungan: petikan medan (

Artikel ini akan menerangkan secara terperinci tentang menukar umask semasa dalam PHP Editor berpendapat ia agak praktikal, jadi saya berkongsi dengan anda sebagai rujukan saya harap anda boleh memperoleh sesuatu selepas membaca artikel ini. Gambaran keseluruhan PHP yang menukar umask semasa umask ialah fungsi php yang digunakan untuk menetapkan kebenaran fail lalai untuk fail dan direktori yang baru dibuat. Ia menerima satu hujah, iaitu nombor perlapanan yang mewakili kebenaran untuk menyekat. Sebagai contoh, untuk menghalang kebenaran menulis pada fail yang baru dibuat, anda akan menggunakan 002. Kaedah menukar umask Terdapat dua cara untuk menukar umask semasa dalam PHP: Menggunakan fungsi umask(): Fungsi umask() menukar secara langsung umask semasa. Sintaksnya ialah: intumas

Artikel ini akan menerangkan secara terperinci cara membuat fail dengan nama fail yang unik dalam PHP Editor berpendapat ia agak praktikal, jadi saya berkongsi dengan anda sebagai rujukan saya harap anda boleh memperoleh sesuatu selepas membaca artikel ini. Mencipta fail dengan nama fail unik dalam PHP Pengenalan Mencipta fail dengan nama fail unik dalam PHP adalah penting untuk mengatur dan mengurus sistem fail anda. Nama fail yang unik memastikan bahawa fail sedia ada tidak ditimpa dan menjadikannya lebih mudah untuk mencari dan mendapatkan semula fail tertentu. Panduan ini akan merangkumi beberapa cara untuk menjana nama fail unik dalam PHP. Kaedah 1: Gunakan fungsi uniqid() Fungsi uniqid() menjana rentetan unik berdasarkan masa semasa dan mikrosaat. Rentetan ini boleh digunakan sebagai asas untuk nama fail.

SpringCloudSaga menyediakan cara deklaratif untuk menyelaraskan transaksi yang diedarkan, memudahkan proses pelaksanaan: tambah kebergantungan Maven: spring-cloud-starter-saga. Cipta pengatur Saga (@Orkestra Saga). Tulis peserta untuk melaksanakan SagaExecution untuk melaksanakan logik perniagaan dan logik pampasan (@SagaStep). Tentukan peralihan keadaan dan pelakon dalam Saga. Dengan menggunakan SpringCloudSaga, atomicity antara operasi perkhidmatan mikro yang berbeza dipastikan.

Artikel ini akan menerangkan secara terperinci tentang PHP mengira cincangan fail MD5. Editor berpendapat ia agak praktikal, jadi saya berkongsi dengan anda sebagai rujukan saya harap anda boleh memperoleh sesuatu selepas membaca artikel ini. PHP mengira cincangan MD5 bagi fail MD5 (MessageDigest5) ialah algoritma penyulitan sehala yang menukarkan mesej dengan panjang sewenang-wenangnya kepada nilai cincang 128-bit panjang tetap. Ia digunakan secara meluas untuk memastikan integriti fail, mengesahkan ketulenan data dan mencipta tandatangan digital. Mengira cincang MD5 fail dalam PHP PHP menyediakan berbilang kaedah untuk mengira cincang MD5 bagi fail: Gunakan fungsi md5_file() Fungsi md5_file() mengira secara langsung nilai cincang MD5 bagi fail dan mengembalikan 32 aksara.

Artikel ini akan menerangkan secara terperinci bagaimana PHP memotong fail mengikut panjang tertentu Editor berpendapat ia agak praktikal, jadi saya berkongsi dengan anda sebagai rujukan saya harap anda boleh memperoleh sesuatu selepas membaca artikel ini. Pengenalan kepada pemangkasan fail PHP Fungsi file_put_contents() dalam PHP boleh digunakan untuk memotong fail pada panjang yang ditentukan. Pemangkasan bermaksud mengalih keluar sebahagian daripada hujung fail, dengan itu memendekkan panjang fail. Syntax file_put_contents($filename,$data,SEEK_SET,$offset);$filename: laluan fail yang akan dipotong. $data: Rentetan kosong untuk ditulis pada fail. SEEK_SET: ditetapkan sebagai permulaan fail

Artikel ini akan menerangkan secara terperinci bagaimana PHP mengembalikan tatasusunan selepas membalikkan nilai utama Editor berpendapat ia agak praktikal, jadi saya berkongsi dengan anda sebagai rujukan saya harap anda boleh memperoleh sesuatu selepas membaca artikel ini. PHP key value flip Array key value flip ialah operasi pada tatasusunan yang menukar kunci dan nilai dalam tatasusunan untuk menjana tatasusunan baharu dengan kunci asal sebagai nilai dan nilai asal sebagai kunci. Kaedah pelaksanaan Dalam PHP, anda boleh melakukan pembalik nilai kunci tatasusunan melalui kaedah berikut: fungsi array_flip(): Fungsi array_flip() digunakan khas untuk operasi flip nilai kunci. Ia menerima tatasusunan sebagai hujah dan mengembalikan tatasusunan baharu dengan kunci dan nilai ditukar. $original_array=[

Artikel ini akan menerangkan secara terperinci pengekodan digital mesej ralat yang dikembalikan oleh PHP dalam operasi Mysql sebelumnya. Editor berpendapat ia agak praktikal, jadi saya berkongsi dengan anda sebagai rujukan . Menggunakan PHP untuk mengembalikan maklumat ralat MySQL Pengekodan Berangka Pengenalan Semasa memproses pertanyaan mysql, anda mungkin menghadapi ralat. Untuk mengendalikan ralat ini dengan berkesan, adalah penting untuk memahami pengekodan berangka mesej ralat. Artikel ini akan membimbing anda menggunakan php untuk mendapatkan pengekodan berangka mesej ralat Mysql. Kaedah mendapatkan pengekodan berangka maklumat ralat 1. mysqli_errno() Fungsi mysqli_errno() mengembalikan nombor ralat terkini sambungan MySQL semasa. Sintaksnya adalah seperti berikut: $erro
