mirror of https://github.com/hashicorp/consul
Merge pull request #604 from hashicorp/f-log-cache
consul: Use new LogCache to improve write throughputpull/610/head
commit
e9216fa47d
|
@ -49,6 +49,10 @@ const (
|
||||||
|
|
||||||
// Maximum number of cached ACL entries
|
// Maximum number of cached ACL entries
|
||||||
aclCacheSize = 256
|
aclCacheSize = 256
|
||||||
|
|
||||||
|
// raftLogCacheSize is the maximum number of logs to cache in-memory.
|
||||||
|
// This is used to reduce disk I/O for the recently commited entries.
|
||||||
|
raftLogCacheSize = 512
|
||||||
)
|
)
|
||||||
|
|
||||||
// Server is Consul server which manages the service discovery,
|
// Server is Consul server which manages the service discovery,
|
||||||
|
@ -362,6 +366,13 @@ func (s *Server) setupRaft() error {
|
||||||
}
|
}
|
||||||
s.raftStore = store
|
s.raftStore = store
|
||||||
|
|
||||||
|
// Wrap the store in a LogCache to improve performance
|
||||||
|
cacheStore, err := raft.NewLogCache(raftLogCacheSize, store)
|
||||||
|
if err != nil {
|
||||||
|
store.Close()
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
// Create the snapshot store
|
// Create the snapshot store
|
||||||
snapshots, err := raft.NewFileSnapshotStore(path, snapshotsRetained, s.config.LogOutput)
|
snapshots, err := raft.NewFileSnapshotStore(path, snapshotsRetained, s.config.LogOutput)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -392,7 +403,7 @@ func (s *Server) setupRaft() error {
|
||||||
s.config.RaftConfig.LogOutput = s.config.LogOutput
|
s.config.RaftConfig.LogOutput = s.config.LogOutput
|
||||||
|
|
||||||
// Setup the Raft store
|
// Setup the Raft store
|
||||||
s.raft, err = raft.NewRaft(s.config.RaftConfig, s.fsm, store, store,
|
s.raft, err = raft.NewRaft(s.config.RaftConfig, s.fsm, cacheStore, store,
|
||||||
snapshots, s.raftPeers, trans)
|
snapshots, s.raftPeers, trans)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
store.Close()
|
store.Close()
|
||||||
|
|
Loading…
Reference in New Issue