]>
Commit | Line | Data |
---|---|---|
e91b9f68 A |
1 | .Dd September 30, 2004 |
2 | .Dt launchd.plist 5 | |
3 | .Os Darwin | |
4 | .Sh NAME | |
5 | .Nm launchd.plist | |
6 | .Nd System wide and per-user daemon/agent configuration files | |
7 | .Sh DESCRIPTION | |
8 | This document details the parameters that can be given to an XML property list that can be loaded into | |
9 | .Nm launchd | |
10 | with | |
11 | .Nm launchctl . | |
12 | .Sh EXPECTATIONS | |
13 | Daemons or agents managed by | |
14 | .Nm launchd | |
15 | are expected to behave certain ways. | |
16 | .Pp | |
17 | A daemon or agent launched by | |
18 | .Nm launchd | |
19 | MUST NOT do the following in the process directly launched by | |
20 | .Nm launchd : | |
21 | .Pp | |
22 | .Bl -bullet -offset indent -compact | |
23 | .It | |
24 | .Xr fork 2 | |
25 | and have the parent process | |
26 | .Xr exit 3 | |
27 | or | |
28 | .Xr _exit 2 . | |
29 | .It | |
30 | Call | |
31 | .Xr daemon 3 | |
32 | .El | |
33 | .Pp | |
34 | A daemon or agent launched by | |
35 | .Nm launchd | |
36 | SHOULD NOT do the following as a part of their startup initialization: | |
37 | .Pp | |
38 | .Bl -bullet -offset indent -compact | |
39 | .It | |
40 | Setup the user ID or group ID. | |
41 | .It | |
42 | Setup the working directory. | |
43 | .It | |
44 | .Xr chroot 2 | |
45 | .It | |
46 | .Xr setsid 2 | |
47 | .It | |
48 | Close "stray" file descriptors. | |
49 | .It | |
50 | Change | |
51 | .Xr stdio 3 | |
52 | to /dev/null. | |
53 | .It | |
54 | Setup resource limits with | |
55 | .Xr setrusage 2 . | |
56 | .It | |
57 | Setup priority with | |
58 | .Xr setpriority 2 . | |
59 | .It | |
60 | Ignore the SIGTERM signal. | |
61 | .El | |
62 | .Pp | |
63 | A daemon or agent launched by | |
64 | .Nm launchd | |
65 | SHOULD: | |
66 | .Pp | |
67 | .Bl -bullet -offset indent -compact | |
68 | .It | |
69 | Launch on demand given criteria specified in the XML property list. | |
70 | More information can be found in | |
71 | .Xr launch 3 . | |
72 | .It | |
73 | Catch the SIGTERM signal. | |
74 | .El | |
75 | .Sh XML PROPERTY LIST KEYS | |
76 | The follow keys can be used to describe the configuration details of your daemon or agent. | |
77 | Property lists files are expected to have their name end in ".plist" but that is not strictly required. | |
78 | .Pp | |
79 | .Bl -ohang | |
80 | .It Sy Label <string> | |
81 | This required key uniquely identifies the job to | |
82 | .Nm launchd . | |
83 | .It Sy Disabled <boolean> | |
84 | This optional key is used to disable your job. The default is false. | |
85 | .It Sy UserName <string> | |
86 | This optional key specifies the user to run the job as. The default is the user who submitted the job to | |
87 | .Nm launchd . | |
88 | .It Sy GroupName <string> | |
89 | This optional key specifies the user to run the job as. The default is the group of the user who submitted the job to | |
90 | .Nm launchd . | |
91 | .It Sy inetdCompatibility <dictionary> | |
92 | The presence of this key specifies that the daemon expects to be run as if it were launched from | |
93 | .Xr inetd 8 . | |
ab36757d | 94 | This flag is incompatible with the ServiceIPC key. |
e91b9f68 A |
95 | .Bl -ohang -offset indent |
96 | .It Sy Wait <boolean> | |
97 | This flag corresponds to the "wait" or "nowait" option of | |
98 | .Xr inetd 8 . | |
99 | .El | |
100 | .It Sy ProgramArguments <array of strings> | |
101 | This required key maps to the second argument of | |
102 | .Xr execvp 3 . | |
103 | .It Sy Program <string> | |
104 | This optional key maps to the first argument of | |
105 | .Xr execvp 3 . | |
106 | If this key is missing, then the first element of the array of strings provided to the ProgramArguments will be used instead. | |
107 | .It Sy OnDemand <boolean> | |
108 | This optional key is used to control whether your job is launched based on demand or to be kept continuously running. The default is true. | |
109 | .It Sy RunAtLoad <boolean> | |
110 | This optional key is used to control whether your job is launched once at the time the job is loaded. The default is false. | |
111 | .It Sy RootDirectory <string> | |
112 | This optional key is used to specific a directory to | |
113 | .Xr chroot 2 | |
114 | to before running the job. | |
115 | .It Sy WorkingDirectory <string> | |
116 | This optional key is used to specific a directory to | |
117 | .Xr chdir 2 | |
118 | to before running the job. | |
119 | .It Sy ServiceDescription <string> | |
120 | This optional key is used to specify a human readable description of the purpose of the job. | |
121 | .It Sy EnvironmentVariables <dictionary of strings> | |
122 | This optional key is used to specify additional environmental variables to be setup before running the job. | |
123 | .It Sy Umask <integer> | |
124 | This optional key specifies what value should be passed to | |
125 | .Xr umask 2 | |
126 | before running the job. | |
127 | .It Sy ServiceIPC <boolean> | |
128 | This optional key specifies whether the job participates in advanced communication with | |
129 | .Nm launchd . | |
ab36757d | 130 | The default is false. This flag is incompatible with the inetdCompatibility key. |
e91b9f68 A |
131 | .It Sy TimeOut <integer> |
132 | The recommended time out to pass to the job. If no value is specified, a default time out will be supplied by | |
133 | .Nm launchd | |
134 | for use by the job at check in time. | |
135 | .It Sy InitGroups <boolean> | |
136 | This optional key specifies whether the job should have | |
137 | .Xr initgroups 3 | |
ab36757d | 138 | be called before running the job. |
e91b9f68 A |
139 | The default is false. |
140 | .It Sy WatchPaths <array of strings> | |
141 | This optional key causes the job to be started if any one of the listed paths are modified. | |
142 | .It Sy QueueDirectories <array of strings> | |
143 | Much like the WatchPaths option, this key will watch the paths for modifications. The difference being that the job will only be started if the path is a directory and the directory is not empty. | |
144 | .It Sy StartInterval <integer> | |
145 | This optional key causes the job to be started every N seconds. | |
ab36757d A |
146 | If the system is asleep, the job will be started the next time the computer |
147 | wakes up. If multiple intervals transpire before the computer is woken, those | |
148 | events will be coalesced into one event upon wake from sleep. | |
e91b9f68 A |
149 | .It Sy StartCalendarInterval <dictionary of integers> |
150 | This optional key causes the job to be started every calendar interval as specified. Missing arguments are considered to be wildcard. The semantics are much like | |
ab36757d A |
151 | .Xr crontab 5 . |
152 | Unlike cron which skips job invocations when the computer is asleep, launchd | |
153 | will start the job the next time the computer wakes up. If multiple intervals | |
154 | transpire before the computer is woken, those events will be coalesced into one | |
155 | event upon wake from sleep. | |
e91b9f68 A |
156 | .Bl -ohang -offset indent |
157 | .It Sy Minute <integer> | |
158 | The minute on which this job will be run. | |
159 | .It Sy Hour <integer> | |
160 | The hour on which this job will be run. | |
161 | .It Sy Day <integer> | |
162 | The day on which this job will be run. | |
163 | .It Sy Weekday <integer> | |
164 | The weekday on which this job will be run (0 and 7 are Sunday). | |
165 | .It Sy Month <integer> | |
166 | The month on which this job will be run. | |
167 | .El | |
168 | .It Sy StandardOutPath <string> | |
169 | This optional key specifies what file should be used for data being sent to stdout when using | |
170 | .Xr stdio 3 . | |
171 | .It Sy StandardErrorPath <string> | |
172 | This optional key specifies what file should be used for data being sent to stderr when using | |
173 | .Xr stdio 3 . | |
174 | .It Sy Debug <boolean> | |
175 | This optional key specifies that | |
176 | .Nm launchd | |
177 | should adjust its log mask temporarily to LOG_DEBUG while dealing with this job. | |
e91b9f68 A |
178 | .It Sy SoftResourceLimits <dictionary of integers> |
179 | .It Sy HardResourceLimits <dictionary of integers> | |
180 | Resource limits to be imposed on the job. These adjust variables set with | |
181 | .Xr setrlimit 2 . | |
182 | The following keys apply: | |
183 | .Bl -ohang -offset indent | |
184 | .It Sy Core <integer> | |
185 | The largest size (in bytes) core file that may be created. | |
186 | .It Sy CPU <integer> | |
187 | The maximum amount of cpu time (in seconds) to be used by each process. | |
188 | .It Sy Data <integer> | |
189 | The maximum size (in bytes) of the data segment for a process; this defines how far a program may extend its break with the | |
190 | .Xr sbrk 2 | |
191 | system call. | |
192 | .It Sy FileSize <integer> | |
193 | The largest size (in bytes) file that may be created. | |
194 | .It Sy MemoryLock <integer> | |
195 | The maximum size (in bytes) which a process may lock into memory using the | |
196 | .Xr mlock 2 | |
197 | function. | |
198 | .It Sy NumberOfFiles <integer> | |
199 | The maximum number of open files for this process. | |
200 | .It Sy NumberOfProcesses <integer> | |
201 | The maximum number of simultaneous processes for this user id. | |
202 | .It Sy ResidentSetSize <integer> | |
203 | The maximum size (in bytes) to which a process's resident set size may grow. | |
204 | This imposes a limit on the amount of physical memory to be given to a process; | |
205 | if memory is tight, the system will prefer to take memory from processes that | |
206 | are exceeding their declared resident set size. | |
207 | .It Sy Stack <integer> | |
208 | The maximum size (in bytes) of the stack segment for a process; this defines | |
209 | how far a program's stack segment may be extended. Stack extension is | |
210 | performed automatically by the system. | |
211 | .El | |
212 | .It Sy Nice <integer> | |
213 | This optional key specifies what | |
214 | .Xr nice 3 | |
215 | value should be applied to the daemon. | |
216 | .It Sy LowPriorityIO <boolean> | |
217 | This optional key specifies whether the kernel should consider this daemon to be low priority when doing file system I/O. | |
ab36757d | 218 | .It Sy Sockets <dictionary of dictionaries... OR dictionary of array of dictionaries...> |
e91b9f68 A |
219 | This optional key is used to specify launch on demand sockets that can be used to let |
220 | .Nm launchd | |
221 | know when to run the job. The job can check-in and get a copy of the file descriptors using APIs outlined in | |
222 | .Xr launch 3 . | |
ab36757d A |
223 | The keys of the top level Sockets dictionary can be anything. They are meant for the application developer to use to |
224 | differentiate different which descriptors correspond to which application level protocols (e.g. http vs. ftp vs. DNS...). | |
225 | At check in time, the value of each Sockets dictionary key will be an array of descriptors. Daemon/Agent writers should | |
226 | consider all descriptors of a given key to be to be effectively equivalent, even though each file descriptor likely represents | |
227 | a different networking protocol which conforms to the criteria specified in the job configuration file. | |
228 | .Pp | |
e91b9f68 A |
229 | The paramters below are used as inputs to call |
230 | .Xr getaddrinfo 3 . | |
231 | .Bl -ohang -offset indent | |
232 | .It Sy SockType <string> | |
233 | This optional key tells | |
234 | .Nm launchctl | |
235 | what type of socket to create. The default is "stream" and other valid values for this key | |
236 | are "dgram" and "seqpacket" respectively. | |
237 | .It Sy SockPassive <boolean> | |
238 | This optional key specifies whether | |
239 | .Xr listen 2 | |
240 | or | |
241 | .Xr connect 2 | |
242 | should be called on the created file descriptor. The default is true ("to listen"). | |
243 | .It Sy SockNodeName <string> | |
244 | This optional key specifies the node to | |
245 | .Xr connect 2 | |
246 | or | |
247 | .Xr bind 2 | |
248 | to. | |
249 | .It Sy SockServiceName <string> | |
250 | This optional key specifies the service on the node to | |
251 | .Xr connect 2 | |
252 | or | |
253 | .Xr bind 2 | |
254 | to. | |
255 | .It Sy SockFamily <string> | |
256 | This optional key can be used to specifically request that "IPv4" or "IPv6" socket(s) be created. | |
257 | .It Sy SockProtocol <string> | |
258 | This optional key specifies the protocol to be passed to | |
259 | .Xr socket 2 . | |
260 | The only value understood by this key at the moment is "TCP". | |
261 | .It Sy SockPathName <string> | |
262 | This optional key implies SockFamily is set to "Unix". It specifies the path to | |
263 | .Xr connect 2 | |
264 | or | |
265 | .Xr bind 2 | |
266 | to. | |
aa59983a A |
267 | .It Sy SockPathMode <integer> |
268 | This optional key specifies the mode of the socket. Known bug: Property lists don't support octal, so please convert the value to decimal. | |
e91b9f68 A |
269 | .It Sy Bonjour <boolean or string or array of strings> |
270 | This optional key can be used to request that the service be registered with the | |
271 | .Xr mDNSResponder 8 . | |
272 | If the value is boolean, the service name is inferred from the SockServiceName. | |
ab36757d A |
273 | .It Sy MulticastGroup <string> |
274 | This optional key can be used to request that the datagram socket join a multicast group. | |
275 | If the value is a hostname, then | |
276 | .Xr getaddrinfo 3 | |
277 | will be used to join the correct multicast address for a given socket family. | |
278 | If an explicit IPv4 or IPv6 address is given, it is required that the SockFamily family also be set, otherwise the results are undefined. | |
e91b9f68 A |
279 | .El |
280 | .El | |
281 | .Pp | |
282 | .Sh EXAMPLE XML PROPERTY LISTS | |
283 | .Pp | |
284 | The following XML Property List simply keeps "exampled" running continuously: | |
285 | .Pp | |
286 | .Dl <?xml version="1.0" encoding="UTF-8"?> | |
287 | .Dl <!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd"> | |
288 | .Dl <plist version="1.0"> | |
289 | .Dl <dict> | |
290 | .Dl <key>Label</key> | |
291 | .Dl <string>com.example.exampled</string> | |
292 | .Dl <key>ProgramArguments</key> | |
293 | .Dl <array> | |
294 | .Dl <string>exampled</string> | |
295 | .Dl </array> | |
296 | .Dl <key>OnDemand</key> | |
297 | .Dl <false/> | |
298 | .Dl </dict> | |
299 | .Dl </plist> | |
300 | .Pp | |
301 | .Sh FILES | |
302 | .Bl -tag -width "/System/Library/LaunchDaemons" -compact | |
303 | .It Pa ~/Library/LaunchAgents | |
304 | Per-user agents provided by the user. | |
305 | .It Pa /Library/LaunchAgents | |
306 | Per-user agents provided by the administrator. | |
307 | .It Pa /Library/LaunchDaemons | |
308 | System wide daemons provided by the administrator. | |
309 | .It Pa /System/Library/LaunchAgents | |
310 | Mac OS X Per-user agents. | |
311 | .It Pa /System/Library/LaunchDaemons | |
312 | Mac OS X System wide daemons. | |
313 | .El | |
314 | .Sh SEE ALSO | |
315 | .Xr launchctl 1 , | |
316 | .Xr launch 3 , | |
317 | .Xr launchd 8 |