Comments (7)
@benbjohnson Actually, raft use a false negative
approach about the command commits. But I agree we should make this a application decision. I can make the change.
from raft.
@xiangli-cmu Thanks. I was adding the issue so I wouldn't forget about it. :)
from raft.
Well I don't think waiting indefinitely is an option. We run into this case when a leader lose leadership while there are uncommited log entries in its logs. The next truncate operation will get rid of the log entry and it will never commit causing the command to timeout, if there were no timeout then the command will hang indefinitely, unless we added some sort of timeout+retry logic.
from raft.
I actually wanted to comment on this issue, because i don't know what's the right way to handle this case and it's not apparent from the paper what's the standard behavior. Although the paper say that the state machine should keep track of commands that were processed in case the client reissued a command. So maybe in this case the retry logic should live in the client. What do you guys think ?
from raft.
@jvshahid Hmmm... the uncommitted logs shouldn't be getting lost just because leadership is lost. They should only get removed if another leader has a different log history. That's a bug that should be fixed.
Removing the timeout should make it hang until either a) the command is committed by that leader, or b) another leader causes the log entry to be removed.
As for retries, I think that should live on the client. If a command fails for some reason, the client is probably the only one with the knowledge to check the current state of the system and optional resubmit the command.
from raft.
@benbjohnson I am going to work on this. I will remove the timeout related stuff and let the application make its own decision.
from raft.
@benbjohnson BTW, can you review https://github.com/goraft/raft/pull/136/files? The only actual changes is making asnycSend
a real one.
from raft.
Related Issues (20)
- Improve test coverage
- Data loss / corruption due to reading partial data from log HOT 2
- Heartbeat lost blocks join requests HOT 2
- Broken initialization after loading from a snapshot HOT 1
- any discussion forum? HOT 1
- server.Start/Stop/Init cannot be called simultaneously
- Windows: log compaction problems HOT 2
- last activity of killed leader is not updated
- Any plan to integrate with different log facilities? HOT 1
- Build broken due to protobuf changes HOT 10
- [question] What is the recommended way to kick unreachable nodes?
- Link in README to 'In Search of an Understandable Consensus Algorithm' is dead HOT 3
- server loads old snapshots HOT 6
- Locking while taking a snapshot HOT 8
- raftd sample cluster reaches un-startable state: panic: assertion failed: leader.elected.at.same.term.345 HOT 2
- chore: use code in github.com instead of code.google.com HOT 4
- panic: assertion failed: leader.elected.at.same.term.283 HOT 2
- Please link to alternative Raft implementations HOT 2
- goraft seems not deal with read consistency problem HOT 3
- Getting package error
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from raft.