mirror of
https://github.com/GOSTSec/sgminer
synced 2025-01-09 22:38:01 +00:00
core: allow changing TCP keepalive packet idle time using tcp-keepalive
command-line option or config-file option.
This may be useful in certain scenarios. However, server load from keepalive
is increased 6-fold if code is hard-changed from 30 to 5. So, provide it as
an option instead, and use the previous value as a default (30).
Explanation from
015c064396
Kevin's middlecoin fix, CURL TCP keepalive constants lowered:
CURLOPT_TCP_KEEPIDLE from 45 to 5 and CURLOPT_TCP_KEEPINTVL from 30 to
5. Before it'd trigger a keepalive packet after 45 seconds of connection
idle time and then again every 30 seconds. Now it triggers a keepalive
packet after 5 seconds of connection idle time and then again every 5
seconds.
It makes the client more resilient against coin switching pools or just
pools with connection issues in general. It will however add a tiny bit
pressure to the pool server; but a TCP keepalive probe is only about
60-80 bytes, so I don't think it is an issue.
This commit is contained in:
parent
bb5065b601
commit
e4680ab627
13
cgminer.c
13
cgminer.c
@ -135,6 +135,11 @@ bool opt_delaynet;
|
|||||||
bool opt_disable_pool;
|
bool opt_disable_pool;
|
||||||
static bool no_work;
|
static bool no_work;
|
||||||
bool opt_worktime;
|
bool opt_worktime;
|
||||||
|
#if defined(HAVE_LIBCURL) && defined(CURL_HAS_KEEPALIVE)
|
||||||
|
int opt_tcp_keepalive = 30;
|
||||||
|
#else
|
||||||
|
int opt_tcp_keepalive;
|
||||||
|
#endif
|
||||||
|
|
||||||
char *opt_kernel_path;
|
char *opt_kernel_path;
|
||||||
char *cgminer_path;
|
char *cgminer_path;
|
||||||
@ -1176,6 +1181,14 @@ static struct opt_table opt_config_table[] = {
|
|||||||
opt_set_bool, &use_syslog,
|
opt_set_bool, &use_syslog,
|
||||||
"Use system log for output messages (default: standard error)"),
|
"Use system log for output messages (default: standard error)"),
|
||||||
#endif
|
#endif
|
||||||
|
OPT_WITH_ARG("--tcp-keepalive",
|
||||||
|
set_int_0_to_9999, opt_show_intval, &opt_tcp_keepalive,
|
||||||
|
#if defined(HAVE_LIBCURL) && defined(CURL_HAS_KEEPALIVE)
|
||||||
|
"TCP keepalive packet idle time"
|
||||||
|
#else
|
||||||
|
opt_hidden
|
||||||
|
#endif
|
||||||
|
),
|
||||||
#ifdef HAVE_ADL
|
#ifdef HAVE_ADL
|
||||||
OPT_WITH_ARG("--temp-cutoff",
|
OPT_WITH_ARG("--temp-cutoff",
|
||||||
set_temp_cutoff, opt_show_intval, &opt_cutofftemp,
|
set_temp_cutoff, opt_show_intval, &opt_cutofftemp,
|
||||||
|
1
miner.h
1
miner.h
@ -971,6 +971,7 @@ extern bool opt_delaynet;
|
|||||||
extern bool opt_restart;
|
extern bool opt_restart;
|
||||||
extern bool opt_worktime;
|
extern bool opt_worktime;
|
||||||
extern int swork_id;
|
extern int swork_id;
|
||||||
|
extern int opt_tcp_keepalive;
|
||||||
|
|
||||||
#if LOCK_TRACKING
|
#if LOCK_TRACKING
|
||||||
extern pthread_mutex_t lockstat_lock;
|
extern pthread_mutex_t lockstat_lock;
|
||||||
|
6
util.c
6
util.c
@ -255,13 +255,11 @@ static void set_nettime(void)
|
|||||||
#if CURL_HAS_KEEPALIVE
|
#if CURL_HAS_KEEPALIVE
|
||||||
static void keep_curlalive(CURL *curl)
|
static void keep_curlalive(CURL *curl)
|
||||||
{
|
{
|
||||||
const int tcp_keepidle = 45;
|
|
||||||
const int tcp_keepintvl = 30;
|
|
||||||
const long int keepalive = 1;
|
const long int keepalive = 1;
|
||||||
|
|
||||||
curl_easy_setopt(curl, CURLOPT_TCP_KEEPALIVE, keepalive);
|
curl_easy_setopt(curl, CURLOPT_TCP_KEEPALIVE, keepalive);
|
||||||
curl_easy_setopt(curl, CURLOPT_TCP_KEEPIDLE, tcp_keepidle);
|
curl_easy_setopt(curl, CURLOPT_TCP_KEEPIDLE, opt_tcp_keepalive);
|
||||||
curl_easy_setopt(curl, CURLOPT_TCP_KEEPINTVL, tcp_keepintvl);
|
curl_easy_setopt(curl, CURLOPT_TCP_KEEPINTVL, opt_tcp_keepalive);
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
static void keep_curlalive(CURL *curl)
|
static void keep_curlalive(CURL *curl)
|
||||||
|
Loading…
Reference in New Issue
Block a user