123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215 |
- .\" **************************************************************************
- .\" * _ _ ____ _
- .\" * Project ___| | | | _ \| |
- .\" * / __| | | | |_) | |
- .\" * | (__| |_| | _ <| |___
- .\" * \___|\___/|_| \_\_____|
- .\" *
- .\" * Copyright (C) 1998 - 2014, Daniel Stenberg, <daniel@haxx.se>, 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 http://curl.haxx.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.
- .\" *
- .\" **************************************************************************
- .TH curl_multi_setopt 3 "10 Oct 2006" "libcurl 7.16.0" "libcurl Manual"
- .SH NAME
- curl_multi_setopt \- set options for a curl multi handle
- .SH SYNOPSIS
- #include <curl/curl.h>
- CURLMcode curl_multi_setopt(CURLM * multi_handle, CURLMoption option, param);
- .SH DESCRIPTION
- curl_multi_setopt() is used to tell a libcurl multi handle how to behave. By
- using the appropriate options to \fIcurl_multi_setopt(3)\fP, you can change
- libcurl's behaviour when using that multi handle. All options are set with
- the \fIoption\fP followed by the parameter \fIparam\fP. That parameter can be
- a \fBlong\fP, a \fBfunction pointer\fP, an \fBobject pointer\fP or a
- \fBcurl_off_t\fP type, depending on what the specific option expects. Read
- this manual carefully as bad input values may cause libcurl to behave badly!
- You can only set one option in each function call.
- .SH OPTIONS
- .IP CURLMOPT_SOCKETFUNCTION
- Pass a pointer to a function matching the \fBcurl_socket_callback\fP
- prototype. The \fIcurl_multi_socket_action(3)\fP function informs the
- application about updates in the socket (file descriptor) status by doing
- none, one, or multiple calls to the curl_socket_callback given in the
- \fBparam\fP argument. They update the status with changes since the previous
- time a \fIcurl_multi_socket(3)\fP function was called. If the given callback
- pointer is NULL, no callback will be called. Set the callback's \fBuserp\fP
- argument with \fICURLMOPT_SOCKETDATA\fP. See \fIcurl_multi_socket(3)\fP for
- more callback details.
- .IP CURLMOPT_SOCKETDATA
- Pass a pointer to whatever you want passed to the \fBcurl_socket_callback\fP's
- fourth argument, the userp pointer. This is not used by libcurl but only
- passed-thru as-is. Set the callback pointer with
- \fICURLMOPT_SOCKETFUNCTION\fP.
- .IP CURLMOPT_PIPELINING
- Pass a long set to 1 to enable or 0 to disable. Enabling pipelining on a multi
- handle will make it attempt to perform HTTP Pipelining as far as possible for
- transfers using this handle. This means that if you add a second request that
- can use an already existing connection, the second request will be \&"piped"
- on the same connection rather than being executed in parallel. (Added in
- 7.16.0)
- .IP CURLMOPT_TIMERFUNCTION
- Pass a pointer to a function matching the \fBcurl_multi_timer_callback\fP
- prototype: int curl_multi_timer_callback(CURLM *multi /* multi handle */,
- long timeout_ms /* timeout in milliseconds */, void *userp /* TIMERDATA */).
- This function will then be called when the timeout value
- changes. The timeout value is at what latest time the application should call
- one of the \&"performing" functions of the multi interface
- (\fIcurl_multi_socket_action(3)\fP and \fIcurl_multi_perform(3)\fP) - to allow
- libcurl to keep timeouts and retries etc to work. A timeout value of -1 means
- that there is no timeout at all, and 0 means that the timeout is already
- reached. Libcurl attempts to limit calling this only when the fixed future
- timeout time actually changes. See also \fICURLMOPT_TIMERDATA\fP. The callback
- should return 0 on success, and -1 on error. This
- callback can be used instead of, or in addition to,
- \fIcurl_multi_timeout(3)\fP. (Added in 7.16.0)
- .IP CURLMOPT_TIMERDATA
- Pass a pointer to whatever you want passed to the
- \fBcurl_multi_timer_callback\fP's third argument, the userp pointer. This is
- not used by libcurl but only passed-thru as-is. Set the callback pointer with
- \fICURLMOPT_TIMERFUNCTION\fP. (Added in 7.16.0)
- .IP CURLMOPT_MAXCONNECTS
- Pass a long. The set number will be used as the maximum amount of
- simultaneously open connections that libcurl may keep in its connection cache
- after completed use. By default libcurl will enlarge the size for each added
- easy handle to make it fit 4 times the number of added easy handles.
- By setting this option, you can prevent the cache size from growing beyond the
- limit set by you.
- When the cache is full, curl closes the oldest one in the cache to prevent the
- number of open connections from increasing.
- This option is for the multi handle's use only, when using the easy interface
- you should instead use the \fICURLOPT_MAXCONNECTS(3)\fP option.
- See \fICURLMOPT_MAX_TOTAL_CONNECTIONS\fP for limiting the number of active
- connections.
- (Added in 7.16.3)
- .IP CURLMOPT_MAX_HOST_CONNECTIONS
- Pass a long. The set number will be used as the maximum amount of
- simultaneously open connections to a single host. For each new session to
- a host, libcurl will open a new connection up to the limit set by
- CURLMOPT_MAX_HOST_CONNECTIONS. When the limit is reached, the sessions will
- be pending until there are available connections. If CURLMOPT_PIPELINING is
- 1, libcurl will try to pipeline if the host is capable of it.
- The default value is 0, which means that there is no limit.
- However, for backwards compatibility, setting it to 0 when CURLMOPT_PIPELINING
- is 1 will not be treated as unlimited. Instead it will open only 1 connection
- and try to pipeline on it.
- (Added in 7.30.0)
- .IP CURLMOPT_MAX_PIPELINE_LENGTH
- Pass a long. The set number will be used as the maximum amount of requests
- in a pipelined connection. When this limit is reached, libcurl will use another
- connection to the same host (see CURLMOPT_MAX_HOST_CONNECTIONS), or queue the
- requests until one of the pipelines to the host is ready to accept a request.
- Thus, the total number of requests in-flight is CURLMOPT_MAX_HOST_CONNECTIONS *
- CURLMOPT_MAX_PIPELINE_LENGTH.
- The default value is 5.
- (Added in 7.30.0)
- .IP CURLMOPT_CONTENT_LENGTH_PENALTY_SIZE
- Pass a long. If a pipelined connection is currently processing a request
- with a Content-Length larger than CURLMOPT_CONTENT_LENGTH_PENALTY_SIZE, that
- connection will not be considered for additional requests, even if it is
- shorter than CURLMOPT_MAX_PIPELINE_LENGTH.
- The default value is 0, which means that the penalization is inactive.
- (Added in 7.30.0)
- .IP CURLMOPT_CHUNK_LENGTH_PENALTY_SIZE
- Pass a long. If a pipelined connection is currently processing a
- chunked (Transfer-encoding: chunked) request with a current chunk length
- larger than CURLMOPT_CHUNK_LENGTH_PENALTY_SIZE, that connection will not be
- considered for additional requests, even if it is shorter than
- CURLMOPT_MAX_PIPELINE_LENGTH.
- The default value is 0, which means that the penalization is inactive.
- (Added in 7.30.0)
- .IP CURLMOPT_PIPELINING_SITE_BL
- Pass an array of char *, ending with NULL. This is a list of sites that are
- blacklisted from pipelining, i.e sites that are known to not support HTTP
- pipelining. The array is copied by libcurl.
- The default value is NULL, which means that there is no blacklist.
- Pass a NULL pointer to clear the blacklist.
- Example:
- .nf
- site_blacklist[] =
- {
- "www.haxx.se",
- "www.example.com:1234",
- NULL
- };
- curl_multi_setopt(m, CURLMOPT_PIPELINE_SITE_BL, site_blacklist);
- .fi
- (Added in 7.30.0)
- .IP CURLMOPT_PIPELINING_SERVER_BL
- Pass an array of char *, ending with NULL. This is a list of server types
- prefixes (in the Server: HTTP header) that are blacklisted from pipelining,
- i.e server types that are known to not support HTTP pipelining. The array is
- copied by libcurl.
- Note that the comparison matches if the Server: header begins with the string
- in the blacklist, i.e "Server: Ninja 1.2.3" and "Server: Ninja 1.4.0" can
- both be blacklisted by having "Ninja" in the backlist.
- The default value is NULL, which means that there is no blacklist.
- Pass a NULL pointer to clear the blacklist.
- Example:
- .nf
- server_blacklist[] =
- {
- "Microsoft-IIS/6.0",
- "nginx/0.8.54",
- NULL
- };
- curl_multi_setopt(m, CURLMOPT_PIPELINE_SERVER_BL, server_blacklist);
- .fi
- (Added in 7.30.0)
- .IP CURLMOPT_MAX_TOTAL_CONNECTIONS
- Pass a long. The set number will be used as the maximum amount of
- simultaneously open connections in total. For each new session, libcurl
- will open a new connection up to the limit set by
- CURLMOPT_MAX_TOTAL_CONNECTIONS. When the limit is reached, the sessions will
- be pending until there are available connections. If CURLMOPT_PIPELINING is
- 1, libcurl will try to pipeline if the host is capable of it.
- The default value is 0, which means that there is no limit.
- However, for backwards compatibility, setting it to 0 when CURLMOPT_PIPELINING
- is 1 will not be treated as unlimited. Instead it will open only 1 connection
- and try to pipeline on it.
- (Added in 7.30.0)
- .SH RETURNS
- The standard CURLMcode for multi interface error codes. Note that it returns a
- CURLM_UNKNOWN_OPTION if you try setting an option that this version of libcurl
- doesn't know of.
- .SH AVAILABILITY
- This function was added in libcurl 7.15.4.
- .SH "SEE ALSO"
- .BR curl_multi_cleanup "(3), " curl_multi_init "(3), "
- .BR curl_multi_socket "(3), " curl_multi_info_read "(3)"
|