Rumah >Java >javaTutorial >Urus niaga yang diedarkan: skim ketekalan akhirnya mesej yang boleh dipercayai
Semua orang mesti biasa dengan hal ehwal, seperti
ACID
, tetapi untukKandungan transaksi
yang diedarkan, mari kita bincangkannya dahuluACID
, dan kemudian memperkenalkan apa ituTransaksi teragih
, dan akhirnya fokus padaBerita yang boleh dipercayai
Penyelesaian transaksi yang diedarkan.ACID
,但是为了后续的分布式事务
的内容,我们先来聊聊ACID
,然后再介绍下什么是分布式事务
,最后着重讲下基于可靠消息
的分布式事务解决方案。
严格意义上的事务应该是具备原子性、一致性、隔离性和持久性,简称 ACID
ACID
. 🎜Atomicity ( Atomicity)
, yang boleh difahami kerana semua operasi dalam transaksi sama ada dilaksanakan atau tidak dilaksanakan. 原子性(Atomicity)
,可以理解为一个事务内的所有操作要么都执行,要么都不执行。一致性(Consistency)
,可以理解为数据是满足完整性约束的,也就是不会存在中间状态的数据,比如你钱包有100,我钱包有100,你给我打50块,此时你钱包的钱应该是50,我钱包的钱应该是150,不会存在我钱加了,你钱没扣的中间状态。隔离性(Isolation)
,指的是多个事务并发执行的时候不会互相干扰,即一个事务内部的数据对于其他事务来说是隔离的。持久性(Durability)
,指的是一个事务完成了之后数据就被永远保存下来,之后的其他操作或故障都不会对事务的结果产生影响。而通俗意义上事务就是为了使得一些更新操作要么都成功,要么都失败
。
分布式事务
顾名思义就是要在分布式系统中实现事务,它其实是由多个本地事务
Ketekalan
boleh difahami kerana data memenuhi kekangan integriti, iaitu, tidak akan ada data dalam keadaan pertengahan. Contohnya, dompet anda ada 100, dompet saya ada 100, anda berikan kepada saya Bayar 50 yuan Pada masa ini, wang dalam dompet anda sepatutnya 50, dan wang dalam dompet saya hendaklah 150. Tidak akan ada keadaan pertengahan di mana wang saya ditambah dan wang anda tidak ditolak. 🎜🎜Pengasingan
merujuk kepada fakta bahawa berbilang transaksi tidak akan mengganggu satu sama lain apabila dilaksanakan serentak, iaitu, data dalam transaksi diasingkan daripada transaksi lain. 🎜🎜Durability (Durability)
bermaksud bahawa selepas transaksi selesai, data disimpan selama-lamanya dan operasi atau kegagalan lain yang berikutnya tidak akan menjejaskan hasil transaksi. Dalam erti kata yang popular, urus niaga adalah untuk membolehkan beberapa operasi kemas kiniSama ada kedua-duanya berjaya atau kedua-duanya gagal
. 🎜
Transaksi teragih
Seperti namanya, ia adalah untuk melaksanakan transaksi dalam sistem yang diedarkan Ia sebenarnya terdiri daripada berbilang Transaksi setempat
digabungkan. 🎜
Sesuatu operasi besar terdiri daripada operasi kecil yang berbeza, yang diedarkan pada pelayan yang berbeza Transaksi yang diedarkan
perlu memastikan bahawa operasi kecil ini sama ada semuanya berjaya atau semuanya gagal. Pada asasnya, Transaksi teragih adalah untuk memastikan bahawa <code style="font-size: 14px;overflow-wrap: break-word;padding: 2px 4px;border-radius: 4px;margin-right: 2px;margin-left: 2px;background -warna: rgba(27, 31, 35, 0.05);font-family: " operator mono consolas monaco menlo monospace break-all rgb><code style="font-size: 14px;overflow-wrap: break-word;padding: 2px 4px;border-radius: 4px;margin-right: 2px;margin- untuk pangkalan data berbeza
left: 2px ;warna latar belakang: rgba(27, 31, 35, 0.05);keluarga fon: " operator mono consolas monaco menlo monospace break-all rgb>Ketekalan data. 分布式事务
需要保证这些小操作要么全部成功,要么全部失败。从本质上来说,分布式事务
就是为了保证不同数据库
的数据一致性
。
常见的分布式事务的解决方案有以下几种:2PC,3PC,TCC,本地消息表、可靠消息最终一致性、尽最大努力通知
等
今天我们就着重讲讲可靠消息最终一致性的解决方案
可靠消息最终一致性方案
是指当事务发起方执行完成本地事务后发出消息到消息中间件
,事务参与方(消息消费者)
一定能够接收到消息并处理事务成功,此方案强调的是只要消息发给事务参与方,则最终事务要达到一致
2PC, 3PC, TCC, jadual mesej setempat, ketekalan akhir mesej yang boleh dipercayai, pemberitahuan usaha terbaik
, dsb.🎜🎜Hari ini kita akan menumpukan pada Penyelesaian untuk konsistensi akhirnya mesej yang boleh dipercayai
🎜 Skim ketekalan akhir mesej yang boleh dipercayai
bermakna apabila pemula transaksi melengkapkan transaksi setempat, ia menghantar mesej ke Mesej middleware
, Peserta transaksi (pengguna mesej)
mesti boleh menerima mesej dan memproses Transaksi Kejayaan, penyelesaian ini menekankan Penyelesaian ini dilaksanakan melalui perisian tengah mesej Pemula transaksi (pengeluar mesej) menghantar mesej kepada perisian tengah mesej, dan peserta urus niaga menerima mesej daripada perisian tengah mesej Disebabkan oleh ketidakpastian komunikasi rangkaian, pengedaran akan berlaku Taip masalah transaksi, seperti yang ditunjukkan di bawah:
Seperti yang ditunjukkan dalam gambar di atas dalam kotak bertitik, terdapat situasi berikut:
2) Urus niaga tempatan berjaya, penghantaran mesej gagal, dan transaksi tempatan ditarik balik.3) Mesej tempatan berjaya, mesej tamat masa, transaksi tempatan digulung semula dan akhirnya mesej gagal.
Ringkasnya, terdapat
4) Mesej tempatan berjaya, mesej tamat tempoh, transaksi tempatan digulung semula dan akhirnya mesej berjaya.Situasi keempat
mengakibatkan transaksi tempatan yang tidak konsisten dengan transaksi peserta mesej.
第四种情况
,造成本地事务,与消息参与方的事务不一致。
消息中间件与事务参与方
要确保能够成功消费
到消息。
注意事务参与方的接口幂等性
Kebolehpercayaan mesej yang diterima oleh peserta transaksi.
Peserta transaksi
mesti memastikan bahawa Berjaya menggunakan
mesej itu. 🎜Idepot antara muka
masalah. Peserta mesej mungkin telah berjaya menggunakannya. Disebabkan masalah rangkaian, middleware mesej percaya bahawa mesej belum digunakan dan masalah itu berlaku selepas memulakan percubaan semula. 🎜Kunci ke Jadual Mesej Tempatan ialah terdapat jadual rekod tempatan yang menyimpan log mesej. rekod log untuk memastikan Mesej boleh dihantar. Proses khusus adalah seperti berikut:
Proses dalam gambar di atas:
1) Transaksi tempatan pemula transaksi berjaya dilaksanakan dan log mesej direkodkan dalam jadual mesej tempatan.
2) Mulakan tugas berjadual dan imbas jadual mesej setempat secara kitaran.
3) Apabila tugas yang dijadualkan mengimbas mesej, ia menghantar mesej ke perisian tengah mesej.
4) Perisian tengah mesej menerima mesej dan berjaya mengembalikan mesej untuk menghantar pemberitahuan yang berjaya kepada pemula transaksi.
5) Pemula transaksi memadamkan mesej log selepas menerima mesej dan menghantarnya dengan jayanya.
6) Peserta transaksi melanggan mesej dan menggunakan mesej.
7) Peserta transaksi mengendalikan hal ehwal tempatan.
8) Transaksi tempatan berjaya diproses dan ack yang berjaya dihantar ke middleware mesej.
Perhatian:Peserta transaksi menjamin mati pucuk antara muka
. 事务参与方保证接口幂等性
。
Apache RocketMQ
4.3之后的版本正式支持事务消息
,为分布式事务实现提供了便利性支持。在RocketMQ 4.3后实现了完整的事务消息,实际上其实是对本地消息表的一个封装
,将本地消息表移动到了MQ内部
,解决 Producer 端的消息发送与本地事务执行的原子性
Penyelesaian mesej transaksi RocketMq
🎜🎜🎜ApacheRocketMQ
Versi selepas 4.3 secara rasmi menyokong Mesej transaksi
menyediakan sokongan mudah untuk pelaksanaan transaksi yang diedarkan. Mesej transaksi lengkap dilaksanakan selepas RocketMQ 4.3, yang sebenarnya Enkapsulasi jadual mesej setempat
, mengalihkan jadual mesej setempat ke MQ internal
, menyelesaikan masalah penghantaran mesej dan pelaksanaan transaksi setempat di sebelah ProducerAtomicity
isu. 🎜🎜🎜🎜Proses pelaksanaan:
1) Pemula transaksi menghantar
Separuh
Mesej transaksiHalf
事务消息
2)RocketMq回复Half
发送成功
3)事务发起方执行本地事务
4)事务发起方执行本地事务成功,发送commit到RocketMq,mq投递消息到事务参与方;事务发起方执行本地事务失败,发送rollback
到RocketMq,mq删除消息。
5)当RocketMq一定时间内未收到来自事务发起方的确认信息,会对事务发起方进行事务回查
。
6)事务发起方查询本地事务状态。
7)事务发起方根据查询到的事务状态发送commint/rollback
到RocketMq。
8)当RocketMq发起commit
后,收到失败或一定时间未收到成功ack,则会发起重试。
优点
:
消息数据独立存储,降低业务系统与消息系统之间的耦合。
吞吐量优于本地消息表方案。
缺点
2) Balas RocketMqSeparuh
berjaya dihantar
4) Pemula transaksi melaksanakan transaksi tempatan dengan jayanya dan menghantar komit kepada RocketMq , penghantaran mq Mesej dihantar kepada peserta transaksi; pemula transaksi gagal melaksanakan transaksi setempat dan menghantar rollback
ke RocketMq, mq memadamkan mesej.
5) Apabila RocketMq tidak menerima maklumat pengesahan daripada pemula transaksi dalam tempoh masa tertentu, ia akan melaksanakan Semakan transaksi
.
7) Pemula transaksi menghantar commin/rollback
ke RocketMq.
komit
, jika kegagalan diterima atau ack yang berjaya tidak diterima untuk tempoh masa tertentu, percubaan semula akan dimulakan. Kelebihan
: 🎜🎜Data mesej disimpan secara berasingan, mengurangkan gandingan antara sistem perniagaan dan sistem mesej. 🎜Penghasilan lebih baik daripada penyelesaian jadual mesej tempatan. 🎜🎜Kelemahan kod>: 🎜🎜Satu penghantaran mesej memerlukan dua permintaan rangkaian (separuh mesej + commit/rollback). 🎜Perlu melaksanakan antara muka semakan mesej. 🎜🎜Malah, setiap penyelesaian transaksi yang diedarkan mempunyai kelebihan dan kekurangan Kita perlu menimbang kebaikan dan keburukan dan memilih yang paling sesuai untuk senario perniagaan. 🎜🎜🎜
Atas ialah kandungan terperinci Urus niaga yang diedarkan: skim ketekalan akhirnya mesej yang boleh dipercayai. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!