1PMDISCOVERSERVICES(3) Library Functions Manual PMDISCOVERSERVICES(3)
2
3
4
6 pmDiscoverServices, __pmDiscoverServicesWithOptions - discover PCP ser‐
7 vices on the network
8
10 #include <pcp/pmapi.h>
11
12 int pmDiscoverServices(const char *service, const char *mechanism, char ***urls);
13
14 #include <pcp/libpcp.h>
15
16 int __pmDiscoverServicesWithOptions(const char *service, const char *mechanism, const char *optionsString, const volatile unsigned *flags, char ***urls);
17
18 cc ... -lpcp
19
21 This documentation is intended for internal Performance Co-Pilot (PCP)
22 developer use.
23
24 These interfaces are not part of the PCP APIs that are guaranteed to
25 remain fixed across releases, and they may not work, or may provide
26 different semantics at some point in the future.
27
29 Given a PCP service name, as identified by service, and using the type
30 of discovery optionally specified in mechanism, pmDiscoverServices re‐
31 turns, via urls, a list of URLs representing the services discovered on
32 the network.
33
34 The internal function __pmDiscoverServicesWithOptions performs the same
35 function and adds arguments for global options and a mechanism for in‐
36 terrupting the discovery process.
37
38 The pmfind(1) utility provides command line access to both of these in‐
39 terfaces.
40
41 Calling
42
43 pmDiscoverServices(service, mechanism, urls)
44
45 is equivalent to calling
46
47 __pmDiscoverServicesWithOptions(service, mechanism, NULL, NULL, urls);
48
49 service specifies the PCP service to be discovered. Currently sup‐
50 ported services are PM_SERVER_SERVICE_SPEC and PM_PROXY_SERVICE_SPEC
51 which search for pmcd(1), and pmproxy(1) servers respectively.
52
53 mechanism specifies the style of discovery to be used.
54
55 The currently supported mechanisms are:
56
57 avahi This searches for services which are broadcasting using mDNS via
58 avahi-daemon(8). An optional suffix ",timeout=N" may be added
59 to specify the discovery timeout in floating-point multiples of
60 one second. The default timeout is 0.5 seconds, which may be
61 overridden by the AVAHI_DISCOVERY_TIMEOUT environment variable,
62 also specified in floating-point multiples of one second. If
63 both are specified, then the value specified in the environment
64 variable takes precedence.
65
66 probe=<net-address>/<mask-bits>
67 Actively probes the given subnet for the requested PCP ser‐
68 vice(s). <net-address> is an inet or ipv6 network address and
69 <mask-bits> is the number of bits used to define the subnet.
70 For example, 192.168.1.0/24 defines an 8 bit subnet consisting
71 of the addresses 192.168.1.0 through 192.168.1.255. An optional
72 suffix ",maxThreads=N" may be added to limit the number of
73 threads used while probing. The default is the value of FD_SET‐
74 SIZE (which is typically 1024) or the number of addresses in the
75 subnet, whichever is less. An optional suffix ",timeout=N" may
76 be added to specify the timeout for each connection attempt in
77 floating-point multiples of one second. The default is 0.02
78 seconds (20 milliseconds).
79
80 shell Probes the list of addresses provided by scripts for requested
81 PCP service(s). Several optional, comma-separated parameters
82 can also be provided. Firstly, the "path=DIR" option specifies
83 the directory where commands like pcp-kube-pods(1) are located
84 (defaults to $PCP_BINADM_DIR/discover/). This setting can be
85 further restricted to an individual command using the com‐
86 mand=CMD option, but the default is to use all available com‐
87 mands from the path. The "maxThreads=N" option limits the num‐
88 ber of threads used while probing. The default is the value of
89 FD_SETSIZE (which is typically 1024) or the number of addresses
90 returned by the scripts, whichever is less. The "timeout=N" op‐
91 tion may be added to limit the amount of time spent waiting for
92 each connection attempt. N is a floating point number specify‐
93 ing the number of seconds to wait. The default is 0.02 seconds
94 (20 milliseconds).
95
96 mechanism may also be NULL, which means to use all available discovery
97 mechanisms.
98
99 For __pmDiscoverServicesWithOptions, optionsString specifies global op‐
100 tions to be applied to the discovery process. Options are comma-sepa‐
101 rated and may be one or more of the following:
102
103 resolve
104 This requests that DNS name resolution be attempted for the ad‐
105 dresses of any discovered services.
106
107 timeout=N
108 This specifies a timeout period after which the discovery
109 process will be interrupted. N is a floating point number rep‐
110 resenting the number of seconds before timing out.
111
112 optionsString may also be NULL, which means that no global options are
113 specified.
114
115 For __pmDiscoverServicesWithOptions, flags specifies a pointer to an
116 object of type unsigned which is a bit mask of options/status flags for
117 the discovery process. The supported flags are:
118
119 PM_SERVICE_DISCOVERY_RESOLVE
120 Specifying this flag is equivalent to specifying resolve in the
121 optionsString
122
123 PM_SERVICE_DISCOVERY_INTERRUPTED
124 This flag must be unset when calling __pmDiscoverServicesWithOp‐
125 tions but may be set asynchronously (by an interrupt handler,
126 for example) in order to interrupt the service discovery
127 process.
128
129 flags may also be NULL, which indicates that no flags are set.
130
131 pmDiscoverServices and __pmDiscoverServicesWithOptions will return the
132 number of services discovered, else a value less than zero for an er‐
133 ror. The value zero indicates that no services were discovered.
134
135 The resulting list of pointers, urls, and the values (the URLs) that
136 the pointers reference will have been allocated by pmDiscoverServices
137 or __pmDiscoverServicesWithOptions with a single call to malloc(3), and
138 it is the responsibility of the pmDiscoverServices or __pmDiscoverSer‐
139 vicesWithOptions caller to free(urls) to release the space when it is
140 no longer required.
141
142 When an error occurs, or no services are discovered, urls is undefined
143 (no space will have been allocated, and so calling free(3) is a singu‐
144 larly bad idea).
145
147 Environment variables with the prefix PCP_ are used to parameterize the
148 file and directory names used by PCP. On each installation, the file
149 /etc/pcp.conf contains the local values for these variables. The
150 $PCP_CONF variable may be used to specify an alternative configuration
151 file, as described in pcp.conf(5). Values for these variables may be
152 obtained programmatically using the pmGetConfig(3) function.
153
155 -EINVAL
156 An invalid argument has been specified.
157
158 -ENOMEM
159 Unable to allocate memory required to process the request.
160
161 -EOPNOTSUPP
162 The specified mechanism is not supported.
163
165 pmcd(1), pmfind(1), pmproxy(1), pcp-kube-pods(1), PMAPI(3), pmGetCon‐
166 fig(3), pcp.conf(5), pcp.env(5) and avahi-daemon(8).
167
168
169
170Performance Co-Pilot PCP PMDISCOVERSERVICES(3)