This is the single best 2PC and 3PC video I've come across! Really helpful for my exam tomorrow
@Deepz0079 ай бұрын
consistency in ACID essentially means that the data should be a in a consistent state before and after the transaction i.e., it should satisfy all DB constraints.
@AtharvaRao01048 ай бұрын
DB helps in some cases with things like constraints.. but DB is not responsible for consistency. It is the application developer who specifies what is a consistent state and then in a transaction makes sure those notion of consistency is maintained. Like a debit row will have a corresponding credit row.
@aartikelkar397 Жыл бұрын
Thank you for the informative videos. I have a doubt at 35:00. You said that all participants know about each other. So in 2 PC, suppose TC sends commit msg to one participant and then fails, meaning only 1 out of two participants got the commit msg. Then in this case, 2PC should not be blocking the transaction as the Participants are aware of each other's status. Thanks
@rishabhagarwal934910 ай бұрын
@aarti in this scenario, there can still be issues with 2PC. For example, if the coordinator fails after sending the commit message to one participant but before the first participant can inform the second participant, the second participant might not know whether to commit or abort, potentially leading to inconsistencies.
@valentinussofa4135 Жыл бұрын
I need more videos that talk about distributed systems like this. Thank you so much. 🙏
@ConceptandCoding Жыл бұрын
I have added many in the playlist and more are coming soon
@valentinussofa4135 Жыл бұрын
@@ConceptandCoding: Many thanks from Indonesia. 🙏
@ConceptandCoding Жыл бұрын
@@valentinussofa4135 you are always welcome from India 🙏
@doingsneakypeakylike10 ай бұрын
Great explanation like always. Thanks!
@saurabhtiwari9614 Жыл бұрын
Got best gift on my birthday. Thank u bhaiya a ton. 🎉🎉🎉
@ConceptandCoding Жыл бұрын
Thanks a lot and happy birthday buddy, aj k day bhi padai
@saurabhtiwari9614 Жыл бұрын
@@ConceptandCoding thanks bhayiya. Jb teacher aapke jese itne aache se concepts clear kre. Toh fir working day bhi holiday lgta h.
@akshaymahajan962611 ай бұрын
very well explained!
@DurgaShiva7574 Жыл бұрын
Finally the wait is over.. GOAT of HLD is back,, thankyou for such content, u rock !!
@ConceptandCoding Жыл бұрын
Thanks a lot buddy
@shubhamkumar-gw4vb Жыл бұрын
Much needed...thanks
@ConceptandCoding Жыл бұрын
Thank you
@sipwhitemocha3 ай бұрын
Thanks man and great video.
@KulbirMalik-px8nf Жыл бұрын
Hi Shreyansh , just a small doubt . How does pre-commit solve the problem in 3 phase , it can be done the same way in 2 phase only . If participants have information of each other and in 2 phase algorithm only they didn't got any COMMIT message ( coordinator went down before 2nd phase only ) , they can abort there only right ?
@doingsneakypeakylike10 ай бұрын
From what I understand, if in 2-phase commit, lets say the Commit message is received by first participant and the first participant commits, then both coordinator and first participant fail, the other participants will be on-hold/blocking since they haven't received commit messages yet(as coordinator failed after sending to first participant) and cannot even query the first participant to know if it committed or not, since the first participant also failed along with the coordinator. The 3-phase commit solves exactly this problem by the addition of an in-between prepared-to-commit step.
@arishtajain83727 ай бұрын
@@doingsneakypeakylike This same problem can arise in 3 phase protocol as well - what if TC sends the pre commit message to first participant and then TC fails along with the first participant. Now none of the participants know what to do - they will remain blocked.
@adityaxmittal Жыл бұрын
if participants can communicate with each other, then why is there a blocking phase in 2PC? Since a participant can check with others regarding the final decision and act accordingly
@aartikelkar397 Жыл бұрын
did you find the answer to the query? I have the similar doubt
@yashporwal68269 ай бұрын
I think it is useful if coordinator does not fail, if the coordinator itself fails before pre commit, it's same as 2PC. Corect me if its wrong!
@prasenjitsutradhar3368 Жыл бұрын
Waiting for long fine!....Thanks
@ConceptandCoding Жыл бұрын
Hope you will find the content useful
@shubhamagarwal14343 ай бұрын
very well explained.......awsome!!!
@Akashdeepkashyap Жыл бұрын
Hi Shreyansh, Great video. One doubt, in 2pc if the commit msg is lost, since services can talk to each other it can ask other services if they have received the commit msgs if yes than continue with commit or abort. Why go for 3PC?
@rohitkumarratnesh47809 ай бұрын
+1 bro. I need answer to this as well @ConceptandCoding
@rishabhgupta41337 ай бұрын
exactly! same question I have. @ConceptandCoding
@timefly68049 ай бұрын
One doubt in SAGA desing pattern @Shrayansh Since each local transaction does commit and move on next service and then complete its transaction and do commit. Suppose last microservice get failed, you said it generate some sort of event which let all the previous transaction to be rolled back. But how come it happen since for all the previous transaction we have done commit. so those are already persisted to the db memory.
@ConceptandCoding9 ай бұрын
correct, so its kind of reversing the txn, understand with this, 1st service has persisted the txn but with Pending status, only with Success event msg from service B it will change the status to Completed else any Fail event, it will lead to change the status to Failed or something. Hope that clarifies
@rohitkumarratnesh47809 ай бұрын
What if pre-commit msg sent from co-ordinator fails? Isn't this same as commit msg from co-ordinator fails in 2PC and participant is waiting for what to do ? If participants can talk to each other whether other participants received commit msg or not in both 2PC and 3PC, how 3 PC solves the problem of 2PC(commit msg lost)?
@fetkamausam51328 ай бұрын
consider in 2pc if it sents a commit msg to one microservice and the msg has lost in other microservice even though the particpants can talk to each othere due to this inconsitency the particpant will unable to make the decision which will cause deadlock in case of 3pc even if they msg has lost as it is sharing the log(non blocking one) the particpant can still make the decision hope this is helpful
@crazeeealgorithms32367 ай бұрын
I too have the same question.
@RitikAggarwal-d3o7 ай бұрын
@@fetkamausam5132 in 2 PC if any microservice didnt get the commit it should abort if one get pre commit then its problem for both 2PC and 3 PC.
@lakshyabansal2542 Жыл бұрын
Very well explained
@Mmmmmkoogfssdvbhvggg11 ай бұрын
I have a small doubt regarding the Three-Phase Commit (3PC) protocol: If the coordinator fails after sending the 'CanCommit' requests in 3PC, how is this scenario effectively managed differently from the Two-Phase Commit (2PC) protocol, where a similar failure leads to a blocking issue?
@SantoshGupta-jl5cj8 ай бұрын
Your explanation is not precise...mixed up and confused to me with 2ph and 3ph
@shubhamsoni60137 ай бұрын
5:36 One transaction should not be locking another transaction. Ideally, only row-level locks should be used to maximize concurrency. If both transactions are accessing the same row, an Exclusive lock should be applied to ensure data integrity. However, if the isolation level is set to Serializable, transactions might still lock each other to maintain consistency and prevent issues like phantom reads.
@arishtajain83727 ай бұрын
Hi, great video overall, though I find a gap in the explanation. In the traditional Two-Phase Commit (2PC) protocol, participants do not communicate directly with each other; they only communicate with the Transaction Coordinator (TC). This is why, 3 PC introduces additional complexity (coordinating between participants). If participant start communicating between each other in both, then 2PC and 3 PC are not much different.
@ConceptandCoding7 ай бұрын
hi, i am in-line with you and i mentioned the same in the video. I double the video and 27:29 i explicitly mentioned, participants can not take their own decision (the blocked state).
@harvendrasinghrathore284811 күн бұрын
I am little bit confused when my DB will aquire the lock, when I will send ask for prepare or before that ? You are sent one more request before the prepare also.
@SriramNagaraj Жыл бұрын
2 phase commit is a blocking protocol because the 'commit' phase keeps waiting forever for some signal from co-originator right ? instead of introducing three phase commit to solve this problem, one simple work around was to introduce 'timeout' for participants in 'commit' phase as well (just like 'timeout' in 'prepare' phase). correct ?
@ConceptandCoding Жыл бұрын
Timeout logic would be risky during decision phase. Because as I mentioned what if one Participant got the commit msg from coordinator but other participant haven't received any msg, so it can not just abort after time out. Bcoz possible that some participant already got the msg and done the commit
@SriramNagaraj Жыл бұрын
@@ConceptandCoding got it thanks. Just a feedback, since many people got this doubt, it would have been good if you would have included this point in the video itself . Again thanks for video. Much appreciated. Have a good day
@ConceptandCoding Жыл бұрын
Not sure if you missed that point but I have added that i double checked
@dragonhot6951 Жыл бұрын
Suggestion: please try laser pen and more pictorial reprresentation and will be great if used tab to write down things properly or just keep a slide of it
@parthatara10442 ай бұрын
One thing I am confused about is in 3 PC you said it's nonblocking because systems can communicate with each other and take decisions in case a pre-commit message is not received. Then why can't they do the same thing on 2 PC if the commit message is not received?
@ambrishtiwari8705 Жыл бұрын
Could you please also help on how to secure Microservices.
@manish.adhikari Жыл бұрын
Thankyou for the nice explanation. Could you please elaborate more on how the participating MSs enquire each other about decision taken by TC? Furthermore, if participating MSs can enquire each other if they have received decision from TC then isn't it a good idea in 2PC that the MSs can abort the transaction and release the lock on the corresponding rows, thus reducing the blocking behaviour? And when the TC comes up again it can check the incompleted transactions (like the above scenario where even before taking decision the TC went down) and discard them.
@manish.adhikari Жыл бұрын
Hi Shrayansh, Did you get a chance to see my question and would like to answer?
@manish.adhikari Жыл бұрын
@ConceptandCoding Would you mind answering my question? I'm not sure if you are getting email notification when a question is asked.
@ak-yo4wo Жыл бұрын
MS can do timed waiting and then abort
@ShashikantPawar-g5u Жыл бұрын
Can you please complete this series as per the roadmap in the first videos
@nikhilstephen1935 Жыл бұрын
Can you make a video on optimistic and pessimistic locking
@ConceptandCoding Жыл бұрын
Yes next video on LLD
@TheUserGuide-h4m16 күн бұрын
Hello Sir, What if it got failed before publishing an event? May be server got down or something else?
@pawansaggu5787 Жыл бұрын
Consider this scenario -> Coordinator sent a commit message to all the participants but didn't get commit success from 1 participant. Now it tries to send the abort to all the participants and just before sending the, it goes down. 1. Failed participant will keep the lock on that row or number of rows until the coordinator goes up and send the abort message to release the lock. Right? 2. Are the rest of the participants going to wait? (a) -> If yes, then why? (b)-> If not, say a new transaction starts on the same row in any of the participants and the co-ordinator sends an abort message now. What sort of handling would be there now for the ongoing transaction and the previous transaction?
@ConceptandCoding Жыл бұрын
Once Coordinator sent the Commit msg, there is no way back. No abort msg it can send. (Even it don't get the done msg from Participant). It's participant responsibility that once it's up, ask coordinator what it should do for the txn. But there is no abort after the commit msg sent.
@pawansaggu5787 Жыл бұрын
@@ConceptandCoding Yes got it. Thanks. Awesome video. Got a lot from the failure cases.
@sidforreal Жыл бұрын
Hey why some of the old LLD videos which were free for everyone are now members only?
@zahidkhan-ln3jv Жыл бұрын
In saga pattern let's say we have 2 microservices and we have committed on the 1st microservice and now the commit on 2nd microservice fails. But since they are asynchronous what happens if we get a read call on the 1st microservice before the transaction is reverted?
@ConceptandCoding Жыл бұрын
Generally SAGA pattern is used where Rollback is not possible, we do revert of previous txn. Let's say, if DR txn got completed, it's status could be PENDING. When let's say Credit operation failed, it will publish an event and the previous component will do revert of Debit txn, like it will change the status from PENDING to FAILED. So one thing you should notice here is SAGA is Async in nature, so till the complete flow is not done, we have to keep some status or flag which denotes it. When txn is successful, again the components listen to the events and change the status to SUCCESS. There are 2 types of SAGA pattern, i have explained in SAGA pattern video, kindly have a look.
@LeoLeo-nx5gi Жыл бұрын
@@ConceptandCoding in Sagas can there not be staleness in the final data? If two concurrent transactions start at the same time they both will read the same initial value but at the end if both are successful both would override each other's value (without knowing there was another Saga transaction going on in parallel). Any idea how should we deal with that, thanks for the video btw!!
@brahm_and_coding Жыл бұрын
when are the other videos coming?
@ConceptandCoding Жыл бұрын
i will add more HLD videos in Nov.
@Sainath-y8d2 ай бұрын
in 2pc also, once one participant gets a message in decision phase, (say commit) and other participant fails to receive a message from coordinator due to failure. P1 and P2 can talk to each other, and since P1 got the message to commit, P2 also can safely commit right? In this case 2pc will also become a non blocking protocol. Likewise, if both p1 and p2 didnt receive anything, we can safely abort.
@sujayghosh51289 ай бұрын
Sir, How to implement transaction coordinator?
@ΑντρέαςΣωτηρίου-π8γ Жыл бұрын
i dont undestand the difference between 2pc and 3pc ?
@DurgaShiva7574 Жыл бұрын
amazing video , some doubt though :- 1. Why cant we have the timeout at the decision phase during the 2 phase commit (like we have in the voting phase, where if the participant doesn't receive the prepared message form coordinator within the given amount of time, it goes for timeout, and thus abort) if the same would had been applied to the decision phase of 2PhaseLocking, then there was no need of 3 Phase commit procedure) 2. In SAGA pattern, we are committing at every service, and not waiting for all other dependent services to complete, what if the child transaction fails, then it will publish the failure message in queue, but we had already committed, then how will the microservices which comiited long time back , will rollback now?......wouldn't it create an issue ?
@ConceptandCoding Жыл бұрын
1. Timeout logic would be risky during decision phase. Because as I mentioned what if one Participant got the commit msg from coordinator but other participant haven't received any msg, so it can not just abort after time out. Bcoz possible that some participant already got the msg and done the commit. 2. In SAGA no txn rollback happen. But revert of what you have done before that happens. For example: DR. of money happens and commited also and let's say Credit Fails later point, so it will do revert of Debit operation on previous account on which debit happened.
@DurgaShiva7574 Жыл бұрын
@@ConceptandCoding thankyou Sir ji, all doubts resolved, as I mentioned u r a Boon for this community
@VijayKumar-q2q3v21 күн бұрын
Time-out would not help because participant nodes cannot simply abort the transaction after certain period because it promised to follow the final decision from the coordinator.
@priyankasetiya13585 ай бұрын
Can u pls make video on Kafka partitions working?
@darliy64710 ай бұрын
can u please share notes of this this and previous lecture
@anoopamz10 ай бұрын
That participants inter communication can be done in 2 phase itself ?
@amiransari19749 ай бұрын
great stuff , Can you make a video to do it practically if it is possible, thanks
@nitishgoyal9910 Жыл бұрын
Hi @Shreyansh , can you please explain about the kafka resiliency and is it same as Saga Pattern ?
@panmenia Жыл бұрын
Hi Shreyansh, great videos. Can you tell me what further videos you plan to bring in the hld playlist, as these 21 videos seem to be more setting up basics. Would you have subsequent videos with real hld questions?
@ConceptandCoding Жыл бұрын
Yes, i have shared in the first roadmap video.
@fetkamausam51328 ай бұрын
supppose in 2pc a commit msg has been sen to one microservice and Transaction coordinator fails to send the msg to another microservice as the transaction is already performed at one microservice what would happend or how can he revert back
@shreyashosur95789 ай бұрын
Hi Shreyansh, You have explained it very well. I have few doubts here. I browsed these doubts all over the internet and I did not get proper answer in GPT as well. 1. What if the paricipants have multiple replicas ? How co-ordinator will make sure the prepare and commit request will always hit the same replica ? 2. I am thinking out this doubt in Java/Spring Implementation. I know transactions can be created using Transaction Annotation and a same thread will work until the transaction is committed. Once participant creates local transaction, it must be in a new transaction thread. So how this transaction thread is stopped from committing and how it commits after receiving the external request(http thread) from co-ordinator since both threads are different. In simple terms, how the two different threads are communicated ? one is new http thread(prepare or commit) and already created transaction thread ? I hope the understanding of doubt is clear. Please let me know if there is a problem. I will elaborate maybe. I am badly searching for the doubts.
@shilpadolai42283 ай бұрын
These are not 2 different databases right. I mean order and inventory at the end are in the same DB right. Just that we are trying to update into the same database from two different microservices as we are talking about having different transaction mgr handeling these transactions. Follow up ques: Also if these two tables were in different databases, this solution will still work righy?
@harvendrasinghrathore28489 күн бұрын
No, this both are different table and in different DB as well.
@jeetdinesh10 ай бұрын
Hi Which tool are you using to record and type the session?
@ConceptandCoding10 ай бұрын
wacom tab
@DevanshChiluka9 ай бұрын
Cover JUnit and architecture patterns if possible
@subhamtripathi1997 Жыл бұрын
Hey Shrayansh, can you please also make a video explaining how we handle thread safety while using saga for transactions on a multicore machine?
@ConceptandCoding Жыл бұрын
Noted
@tejasshaha6629 Жыл бұрын
In Springboot all these can be done with the help of only 1 annotation - @Transactional on a class or method , right ? Very nice video, crystal clear !!
@ConceptandCoding Жыл бұрын
Nope, @Trandactional annotation just provide transaction property buddy, it do not provide Distributed transaction property
@tejasshaha6629 Жыл бұрын
@@ConceptandCoding ohk thank you sir for the confirmation .
@jeremysilwoman2 ай бұрын
Hi Shrayansh, What will happen in 2PL if a participant node fails after receiving the commit message and does not ever recovers. Will we wait indefinitely or rollback transaction on other participant nodes ?
@justlc78 ай бұрын
Sorry for the noob question, which video do we have cache eviction in? I cant find it.
@girishanker37967 ай бұрын
I don't think it's uploaded yet.
@mintu591 Жыл бұрын
Thanks Sir, Is it the second part of 19th video ?
@ConceptandCoding Жыл бұрын
Cache eviction is LLD concept, i will put in LLD playlist.
@mintu591 Жыл бұрын
@@ConceptandCoding Thanks, I want to know one thing there are many videos is locked, if join the community and paid then I can only access that video or can access all locked videos. Also please let me know the some platform name where I can ask such type of question and videos replated ques, Thanks
@abhinavpandey33564 ай бұрын
Shreyansh one thing like can u please pin some of the common doubts asked so that u also need not to answer every time and we also need not to see every chat. Just a suggestion. Also good content 🎉
@harshittrivedi1 Жыл бұрын
Sir, what happens in case of SAGA pattern, if service 1 commited transaction then service 2(Async call) Transaction got failed? we have to write custom rollback logic for that or manually delete/update?
@Deepz0079 ай бұрын
compensating transaction has to be done to reverse what service 1 did.
@ANSHULGUPTA880 Жыл бұрын
If there is a coordinator for 2 microservice, will it not be orchestrator pattern, which is type of SAGA pattern?
@ANSHULGUPTA880 Жыл бұрын
Also, is gateway pattern also type of orchestrator pattern? since gateway takes decision where request will go?
@futhedude4848 Жыл бұрын
for your first question, i believe the answer is no. the reason is mentioned in 37:45 2pc and 3pc is synchronous and they block db while processing, but the SAGA is opposite of it.
@kumarashutosh229 Жыл бұрын
Wondering if you could throw some light on modules of a cloud native apps. When can you say, now my app is fully cloud native.
@ConceptandCoding Жыл бұрын
Could you please elaborate what do you mean by module of cloud native buddy
@kumarashutosh229 Жыл бұрын
@@ConceptandCoding I mean, just by having few microservices, a gateway, a redis would qualify my ecosystem to be cloud native or are there some specifications for it or is it simply a buzzword. What exactly makes an app cloud native.
@kumarashutosh229 Жыл бұрын
We have seen cloud-enabled apps that have one of their services deployed over cloud, but cloud-native one, it's somewhat related to cloud computing architecture. So if you have got bandwidth you can teach us this stuff
@ConceptandCoding Жыл бұрын
@@kumarashutosh229 understood thanks for the details, i get your point now. I will add the complete overview which i understand. And share the short video of it.
@r4ravi4u Жыл бұрын
In 2 PC .. Suppose, in phase 2, commit done is replied by 1 participant, but another participant failed to commit, then ?
@ConceptandCoding Жыл бұрын
After TC has sent the COMMIT msg, then all the participants have to commit. If one participant failed while commit, it has to retry. There is no way back after this
@r4ravi4u Жыл бұрын
@@ConceptandCoding I believe, SAGA seems more stable and preferred solution then. But yes multiple MQs can increase the costing as compared to single TC service. Otherwise everything seems more simplistic and fault tolerant in Saga pattern.
@ConceptandCoding Жыл бұрын
@@r4ravi4u yes, but it can not be applied in all usecase, where real time in ongoing txn you need the transactional property
@omnamahshivaya20549 ай бұрын
Hi Sir, first of all, thank you for the nice content it really helps me to learn something new. I have one doubt may you or anyone can help to understand it? As in Phase 1 if any message ('Prepare', 'OK', 'NO') is lost then both coordinator and participant have a timeout mechanism. please correct me if my understanding is wrong? Then 2nd phase when the commit message is lost, why was it blocked, and why is Transaction Coordinator not timeout as it did in phase 1? Please help to clarify this doubt.
@StrategicInsights-ci8bg8 ай бұрын
I didnt understand the need of 3PC over 2PC and what its actually solving when in case of 2PC also they can communicate with each other and eventually they can abort the process just as in 3PC case
@girishanker37967 ай бұрын
The difference is actually between the pre-phase: commit message and commit phase : commit message.
@krishraj1942 Жыл бұрын
can you please provide notes also of these topics??
@logicalrisi11 ай бұрын
Members hoke bhi reply nhi deta hai Aur notes bhi nhi😢
@shagunmaurya7634 Жыл бұрын
Hi shreyansh sir Completing your hld series one suggestion can you please put your onenotes so that it will be easier to revise this thing again in a lot faster ways. Thanks for great series 🙏
@ConceptandCoding Жыл бұрын
Hi Shagun, believe me it would be very helpful, if you make your notes in your own way after understanding. That's why i do not believe in notes sharing. It would be helpful in long run buddy.
@abhishekkashyap6136 Жыл бұрын
what if done message failed?
@ConceptandCoding Жыл бұрын
Doesn't matter, after sometime, coordinator will close the txn.
@harshitagarwal26826 ай бұрын
👍👍
@ankitgupta-ph4nk Жыл бұрын
Thanks for this video.. But to be honest didn't get much clarity when any of the MS or Coordinator goes down in 2 phase commit.. How it read from logs file considering logs file had tons of records in real world application... and if any of these MS let say fail to responded.. how to get a response from Coordinator log files which Coordinator already send a abort request to another instance of that same MS.
@ConceptandCoding Жыл бұрын
That's depends on each application how they want to maintain the log file. For example: - i can use DB to store it and keep on cleaning it. Or - i can create txn I'd wise log file and same i can delete it once txn is completed. So it's upto each and every application how they want to log the data.
@ankitgupta-ph4nk Жыл бұрын
@@ConceptandCoding I got this..Thanks !!
@DurgaShiva7574 Жыл бұрын
i think the answer to the 2nd part of your query would be that, as the MS didn't responded, after some timeout, coordinator will publish abort to all MS, when the MS which was down, will see this, and rollback too.
@ankitgupta-ph4nk Жыл бұрын
@@DurgaShiva7574 Ok so you are saying in failed state this MS receive that message from coordinator, That message let say queued somewhere and when this MS goes up then can use this queued message for further Rollback ?
@DurgaShiva7574 Жыл бұрын
@@ankitgupta-ph4nk Great approach, but it all depends on how the infra is made, it can also be the case that, no failure message is queued, but , when the MS which was down, when it comes up, it will poll for the transaction status from the coordinator, and thus, will roll-back
@DevanshChiluka9 ай бұрын
❤
@dharmaraosalana6418 ай бұрын
Better to have blogs to be written
@subhamshaw77556 ай бұрын
Please provide the pdf
@vishalkaushik7413 Жыл бұрын
Hi Shreyansh, Thanks for the great video. I have a query in 3 phase commit, Totally understood, it helps to tackle the blocking issue likewise in 2 phase commit, what if blocking happens before the pre-commit(or right after the prepare TC get fails) in 3 phase commit, that will be same condition as blocking in 2 phase commit. Could you please help me with this confusion. Thanks in advance!!
@ConceptandCoding Жыл бұрын
Ack of the question
@kumarashish2607Ай бұрын
Redo this. this is quite confusing. You should have discussed message exchange between participants earlier itself. Also, felt 3-PC was not explained well.
@futhedude4848 Жыл бұрын
there's unclear about the explaination of "pre-commit phase" of 3PC.