You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
This does not affect the correctness of the replication but it does mean a new connection is established each timeout parameter. When there are 1000s of replications defined as in our environment this results in significant activity and size of the http proxy access log. We would like the ability to configure the replication using the heartbeat parameter in the replication document. I have tried using query_params on the replication document but it looks like these parameters are only used if a filter function is configured.
Desired Behaviour
The desired behaviour is that a single persistent connection is opened per continuous replication rather than a new connection is established every 10s (default).
This change appears in the access.log but it looks like there is more to it than this as the connections are still closing (although not after 10s, perhaps on receipt of a heartbeat line?)
Additional context
GBs of log data that is largely irrelevant to the functioning of our environment. I suspect that a heartbeat connection uses fewer bytes to maintain than the repeated connection open/close so perhaps also cheaper when bandwidth usage is metered. We can use SO_KEEPALIVE so dead connections get closed which covers a noted advantage of the 10s timeout. I did find this commit (added for 2.0.0) in the history but I can't find the relevant bug tracking system to see if there is any discussion on the rationale for the change.
commit e13f5b51511f1c8d773c3eb7f8f304a508c8f346
Author: Bob Dionne <[email protected]>
Date: Wed Feb 27 09:16:55 2013 -0500
Replace heartbeat in continuous feed with timeout
BugzID: 17662
The text was updated successfully, but these errors were encountered:
Why don't you use the heartbeat parameter for continous replication anymore to keep the connection open? timeout will hold the connection open for the specified ms and then close the socket. More info in the docs.
Summary
In CouchDB 1.7.2 the internal replicator allowed use of the heartbeat parameter such that query parameters look like:
Since upgrading to CouchDB 3.x.x the replication uses the
timeout
parameter instead:This does not affect the correctness of the replication but it does mean a new connection is established each
timeout
parameter. When there are 1000s of replications defined as in our environment this results in significant activity and size of the http proxy access log. We would like the ability to configure the replication using the heartbeat parameter in the replication document. I have tried usingquery_params
on the replication document but it looks like these parameters are only used if a filter function is configured.Desired Behaviour
The desired behaviour is that a single persistent connection is opened per continuous replication rather than a new connection is established every 10s (default).
Possible Solution
Support a
heartbeat
parameter in the replication settings which will be used in preference totimeout
if it is defined: https://docs.couchdb.org/en/stable/json-structure.html#replication-settingsI have modified
couch_replicator_api_wrap.erl
in the source to provide a heartbeat parameter in changes_since():This change appears in the access.log but it looks like there is more to it than this as the connections are still closing (although not after 10s, perhaps on receipt of a heartbeat line?)
Additional context
GBs of log data that is largely irrelevant to the functioning of our environment. I suspect that a heartbeat connection uses fewer bytes to maintain than the repeated connection open/close so perhaps also cheaper when bandwidth usage is metered. We can use SO_KEEPALIVE so dead connections get closed which covers a noted advantage of the 10s timeout. I did find this commit (added for 2.0.0) in the history but I can't find the relevant bug tracking system to see if there is any discussion on the rationale for the change.
The text was updated successfully, but these errors were encountered: