From 41b9fd538462628000d1f95c0b3e012c686dec9e Mon Sep 17 00:00:00 2001 From: Daniel Stenberg Date: Wed, 1 Nov 2023 10:36:45 +0100 Subject: [PATCH] docs/example/keepalive.c: show TCP keep-alive options Closes #12242 --- docs/examples/Makefile.inc | 1 + docs/examples/keepalive.c | 55 ++++++++++++++++++++++++++++++++++++++ 2 files changed, 56 insertions(+) create mode 100644 docs/examples/keepalive.c diff --git a/docs/examples/Makefile.inc b/docs/examples/Makefile.inc index 42f13a66f..f0e073cf5 100644 --- a/docs/examples/Makefile.inc +++ b/docs/examples/Makefile.inc @@ -78,6 +78,7 @@ check_PROGRAMS = \ imap-tls \ interface \ ipv6 \ + keepalive \ localport \ maxconnects \ multi-app \ diff --git a/docs/examples/keepalive.c b/docs/examples/keepalive.c new file mode 100644 index 000000000..1c876bb1f --- /dev/null +++ b/docs/examples/keepalive.c @@ -0,0 +1,55 @@ +/*************************************************************************** + * _ _ ____ _ + * Project ___| | | | _ \| | + * / __| | | | |_) | | + * | (__| |_| | _ <| |___ + * \___|\___/|_| \_\_____| + * + * Copyright (C) Daniel Stenberg, , et al. + * + * This software is licensed as described in the file COPYING, which + * you should have received as part of this distribution. The terms + * are also available at https://curl.se/docs/copyright.html. + * + * You may opt to use, copy, modify, merge, publish, distribute and/or sell + * copies of the Software, and permit persons to whom the Software is + * furnished to do so, under the terms of the COPYING file. + * + * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY + * KIND, either express or implied. + * + * SPDX-License-Identifier: curl + * + ***************************************************************************/ +/* + * Use the TCP keep-alive options + * + */ +#include +#include + +int main(void) +{ + CURL *curl; + CURLcode res = CURLE_OK; + + curl = curl_easy_init(); + if(curl) { + /* enable TCP keep-alive for this transfer */ + curl_easy_setopt(curl, CURLOPT_TCP_KEEPALIVE, 1L); + + /* keep-alive idle time to 120 seconds */ + curl_easy_setopt(curl, CURLOPT_TCP_KEEPIDLE, 120L); + + /* interval time between keep-alive probes: 60 seconds */ + curl_easy_setopt(curl, CURLOPT_TCP_KEEPINTVL, 60L); + + curl_easy_setopt(curl, CURLOPT_URL, "https://curl.se/"); + + res = curl_easy_perform(curl); + + curl_easy_cleanup(curl); + } + + return (int)res; +}