server_maint 0.0.1 → 0.0.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (55) hide show
  1. data/.gitmodules +12 -0
  2. data/lib/cookbooks/bluepill/.gitignore +4 -0
  3. data/lib/cookbooks/bluepill/CHANGELOG.md +31 -0
  4. data/lib/cookbooks/bluepill/CONTRIBUTING +29 -0
  5. data/lib/cookbooks/bluepill/Gemfile +5 -0
  6. data/lib/cookbooks/bluepill/Gemfile.lock +115 -0
  7. data/lib/cookbooks/bluepill/LICENSE +201 -0
  8. data/lib/cookbooks/bluepill/README.md +80 -0
  9. data/lib/cookbooks/bluepill/attributes/default.rb +34 -0
  10. data/lib/cookbooks/bluepill/metadata.rb +7 -0
  11. data/lib/cookbooks/bluepill/providers/service.rb +155 -0
  12. data/lib/cookbooks/bluepill/recipes/default.rb +33 -0
  13. data/lib/cookbooks/bluepill/resources/service.rb +27 -0
  14. data/lib/cookbooks/bluepill/templates/centos/bluepill_init.erb +32 -0
  15. data/lib/cookbooks/bluepill/templates/freebsd/bluepill_init.erb +31 -0
  16. data/lib/cookbooks/bluepill/test/kitchen/Kitchenfile +3 -0
  17. data/lib/cookbooks/bluepill/test/kitchen/cookbooks/bluepill_test/README.md +12 -0
  18. data/lib/cookbooks/bluepill/test/kitchen/cookbooks/bluepill_test/attributes/default.rb +5 -0
  19. data/lib/cookbooks/bluepill/test/kitchen/cookbooks/bluepill_test/files/default/tests/minitest/default_test.rb +38 -0
  20. data/lib/cookbooks/bluepill/test/kitchen/cookbooks/bluepill_test/files/default/tests/minitest/support/helpers.rb +13 -0
  21. data/lib/cookbooks/bluepill/test/kitchen/cookbooks/bluepill_test/metadata.rb +8 -0
  22. data/lib/cookbooks/bluepill/test/kitchen/cookbooks/bluepill_test/recipes/default.rb +20 -0
  23. data/lib/cookbooks/bluepill/test/kitchen/cookbooks/bluepill_test/templates/default/test_app.pill.erb +8 -0
  24. data/lib/cookbooks/build-essential/CHANGELOG.md +15 -0
  25. data/lib/cookbooks/build-essential/CONTRIBUTING +29 -0
  26. data/lib/cookbooks/build-essential/LICENSE +201 -0
  27. data/lib/cookbooks/build-essential/README.md +124 -0
  28. data/lib/cookbooks/build-essential/attributes/default.rb +33 -0
  29. data/lib/cookbooks/build-essential/metadata.rb +12 -0
  30. data/lib/cookbooks/build-essential/recipes/default.rb +81 -0
  31. data/lib/cookbooks/ohai/CHANGELOG.md +12 -0
  32. data/lib/cookbooks/ohai/CONTRIBUTING +29 -0
  33. data/lib/cookbooks/ohai/LICENSE +201 -0
  34. data/lib/cookbooks/ohai/README.md +49 -0
  35. data/lib/cookbooks/ohai/attributes/default.rb +24 -0
  36. data/lib/cookbooks/ohai/files/default/plugins/README +1 -0
  37. data/lib/cookbooks/ohai/metadata.rb +22 -0
  38. data/lib/cookbooks/ohai/recipes/default.rb +52 -0
  39. data/lib/cookbooks/runit/CHANGELOG.md +3 -0
  40. data/lib/cookbooks/runit/CONTRIBUTING +29 -0
  41. data/lib/cookbooks/runit/LICENSE +201 -0
  42. data/lib/cookbooks/runit/README.md +226 -0
  43. data/lib/cookbooks/runit/attributes/default.rb +31 -0
  44. data/lib/cookbooks/runit/definitions/runit_service.rb +164 -0
  45. data/lib/cookbooks/runit/files/default/runit.seed +1 -0
  46. data/lib/cookbooks/runit/files/default/runsvdir +0 -0
  47. data/lib/cookbooks/runit/files/ubuntu-6.10/runsvdir +6 -0
  48. data/lib/cookbooks/runit/files/ubuntu-7.04/runsvdir +7 -0
  49. data/lib/cookbooks/runit/files/ubuntu-7.10/runsvdir +7 -0
  50. data/lib/cookbooks/runit/files/ubuntu-8.04/runsvdir +7 -0
  51. data/lib/cookbooks/runit/metadata.rb +37 -0
  52. data/lib/cookbooks/runit/recipes/default.rb +72 -0
  53. data/lib/cookbooks/runit/templates/gentoo/runit-start.sh.erb +32 -0
  54. data/lib/server_maint/version.rb +1 -1
  55. metadata +57 -5
@@ -0,0 +1,201 @@
1
+ Apache License
2
+ Version 2.0, January 2004
3
+ http://www.apache.org/licenses/
4
+
5
+ TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
6
+
7
+ 1. Definitions.
8
+
9
+ "License" shall mean the terms and conditions for use, reproduction,
10
+ and distribution as defined by Sections 1 through 9 of this document.
11
+
12
+ "Licensor" shall mean the copyright owner or entity authorized by
13
+ the copyright owner that is granting the License.
14
+
15
+ "Legal Entity" shall mean the union of the acting entity and all
16
+ other entities that control, are controlled by, or are under common
17
+ control with that entity. For the purposes of this definition,
18
+ "control" means (i) the power, direct or indirect, to cause the
19
+ direction or management of such entity, whether by contract or
20
+ otherwise, or (ii) ownership of fifty percent (50%) or more of the
21
+ outstanding shares, or (iii) beneficial ownership of such entity.
22
+
23
+ "You" (or "Your") shall mean an individual or Legal Entity
24
+ exercising permissions granted by this License.
25
+
26
+ "Source" form shall mean the preferred form for making modifications,
27
+ including but not limited to software source code, documentation
28
+ source, and configuration files.
29
+
30
+ "Object" form shall mean any form resulting from mechanical
31
+ transformation or translation of a Source form, including but
32
+ not limited to compiled object code, generated documentation,
33
+ and conversions to other media types.
34
+
35
+ "Work" shall mean the work of authorship, whether in Source or
36
+ Object form, made available under the License, as indicated by a
37
+ copyright notice that is included in or attached to the work
38
+ (an example is provided in the Appendix below).
39
+
40
+ "Derivative Works" shall mean any work, whether in Source or Object
41
+ form, that is based on (or derived from) the Work and for which the
42
+ editorial revisions, annotations, elaborations, or other modifications
43
+ represent, as a whole, an original work of authorship. For the purposes
44
+ of this License, Derivative Works shall not include works that remain
45
+ separable from, or merely link (or bind by name) to the interfaces of,
46
+ the Work and Derivative Works thereof.
47
+
48
+ "Contribution" shall mean any work of authorship, including
49
+ the original version of the Work and any modifications or additions
50
+ to that Work or Derivative Works thereof, that is intentionally
51
+ submitted to Licensor for inclusion in the Work by the copyright owner
52
+ or by an individual or Legal Entity authorized to submit on behalf of
53
+ the copyright owner. For the purposes of this definition, "submitted"
54
+ means any form of electronic, verbal, or written communication sent
55
+ to the Licensor or its representatives, including but not limited to
56
+ communication on electronic mailing lists, source code control systems,
57
+ and issue tracking systems that are managed by, or on behalf of, the
58
+ Licensor for the purpose of discussing and improving the Work, but
59
+ excluding communication that is conspicuously marked or otherwise
60
+ designated in writing by the copyright owner as "Not a Contribution."
61
+
62
+ "Contributor" shall mean Licensor and any individual or Legal Entity
63
+ on behalf of whom a Contribution has been received by Licensor and
64
+ subsequently incorporated within the Work.
65
+
66
+ 2. Grant of Copyright License. Subject to the terms and conditions of
67
+ this License, each Contributor hereby grants to You a perpetual,
68
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
69
+ copyright license to reproduce, prepare Derivative Works of,
70
+ publicly display, publicly perform, sublicense, and distribute the
71
+ Work and such Derivative Works in Source or Object form.
72
+
73
+ 3. Grant of Patent License. Subject to the terms and conditions of
74
+ this License, each Contributor hereby grants to You a perpetual,
75
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
76
+ (except as stated in this section) patent license to make, have made,
77
+ use, offer to sell, sell, import, and otherwise transfer the Work,
78
+ where such license applies only to those patent claims licensable
79
+ by such Contributor that are necessarily infringed by their
80
+ Contribution(s) alone or by combination of their Contribution(s)
81
+ with the Work to which such Contribution(s) was submitted. If You
82
+ institute patent litigation against any entity (including a
83
+ cross-claim or counterclaim in a lawsuit) alleging that the Work
84
+ or a Contribution incorporated within the Work constitutes direct
85
+ or contributory patent infringement, then any patent licenses
86
+ granted to You under this License for that Work shall terminate
87
+ as of the date such litigation is filed.
88
+
89
+ 4. Redistribution. You may reproduce and distribute copies of the
90
+ Work or Derivative Works thereof in any medium, with or without
91
+ modifications, and in Source or Object form, provided that You
92
+ meet the following conditions:
93
+
94
+ (a) You must give any other recipients of the Work or
95
+ Derivative Works a copy of this License; and
96
+
97
+ (b) You must cause any modified files to carry prominent notices
98
+ stating that You changed the files; and
99
+
100
+ (c) You must retain, in the Source form of any Derivative Works
101
+ that You distribute, all copyright, patent, trademark, and
102
+ attribution notices from the Source form of the Work,
103
+ excluding those notices that do not pertain to any part of
104
+ the Derivative Works; and
105
+
106
+ (d) If the Work includes a "NOTICE" text file as part of its
107
+ distribution, then any Derivative Works that You distribute must
108
+ include a readable copy of the attribution notices contained
109
+ within such NOTICE file, excluding those notices that do not
110
+ pertain to any part of the Derivative Works, in at least one
111
+ of the following places: within a NOTICE text file distributed
112
+ as part of the Derivative Works; within the Source form or
113
+ documentation, if provided along with the Derivative Works; or,
114
+ within a display generated by the Derivative Works, if and
115
+ wherever such third-party notices normally appear. The contents
116
+ of the NOTICE file are for informational purposes only and
117
+ do not modify the License. You may add Your own attribution
118
+ notices within Derivative Works that You distribute, alongside
119
+ or as an addendum to the NOTICE text from the Work, provided
120
+ that such additional attribution notices cannot be construed
121
+ as modifying the License.
122
+
123
+ You may add Your own copyright statement to Your modifications and
124
+ may provide additional or different license terms and conditions
125
+ for use, reproduction, or distribution of Your modifications, or
126
+ for any such Derivative Works as a whole, provided Your use,
127
+ reproduction, and distribution of the Work otherwise complies with
128
+ the conditions stated in this License.
129
+
130
+ 5. Submission of Contributions. Unless You explicitly state otherwise,
131
+ any Contribution intentionally submitted for inclusion in the Work
132
+ by You to the Licensor shall be under the terms and conditions of
133
+ this License, without any additional terms or conditions.
134
+ Notwithstanding the above, nothing herein shall supersede or modify
135
+ the terms of any separate license agreement you may have executed
136
+ with Licensor regarding such Contributions.
137
+
138
+ 6. Trademarks. This License does not grant permission to use the trade
139
+ names, trademarks, service marks, or product names of the Licensor,
140
+ except as required for reasonable and customary use in describing the
141
+ origin of the Work and reproducing the content of the NOTICE file.
142
+
143
+ 7. Disclaimer of Warranty. Unless required by applicable law or
144
+ agreed to in writing, Licensor provides the Work (and each
145
+ Contributor provides its Contributions) on an "AS IS" BASIS,
146
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
147
+ implied, including, without limitation, any warranties or conditions
148
+ of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
149
+ PARTICULAR PURPOSE. You are solely responsible for determining the
150
+ appropriateness of using or redistributing the Work and assume any
151
+ risks associated with Your exercise of permissions under this License.
152
+
153
+ 8. Limitation of Liability. In no event and under no legal theory,
154
+ whether in tort (including negligence), contract, or otherwise,
155
+ unless required by applicable law (such as deliberate and grossly
156
+ negligent acts) or agreed to in writing, shall any Contributor be
157
+ liable to You for damages, including any direct, indirect, special,
158
+ incidental, or consequential damages of any character arising as a
159
+ result of this License or out of the use or inability to use the
160
+ Work (including but not limited to damages for loss of goodwill,
161
+ work stoppage, computer failure or malfunction, or any and all
162
+ other commercial damages or losses), even if such Contributor
163
+ has been advised of the possibility of such damages.
164
+
165
+ 9. Accepting Warranty or Additional Liability. While redistributing
166
+ the Work or Derivative Works thereof, You may choose to offer,
167
+ and charge a fee for, acceptance of support, warranty, indemnity,
168
+ or other liability obligations and/or rights consistent with this
169
+ License. However, in accepting such obligations, You may act only
170
+ on Your own behalf and on Your sole responsibility, not on behalf
171
+ of any other Contributor, and only if You agree to indemnify,
172
+ defend, and hold each Contributor harmless for any liability
173
+ incurred by, or claims asserted against, such Contributor by reason
174
+ of your accepting any such warranty or additional liability.
175
+
176
+ END OF TERMS AND CONDITIONS
177
+
178
+ APPENDIX: How to apply the Apache License to your work.
179
+
180
+ To apply the Apache License to your work, attach the following
181
+ boilerplate notice, with the fields enclosed by brackets "[]"
182
+ replaced with your own identifying information. (Don't include
183
+ the brackets!) The text should be enclosed in the appropriate
184
+ comment syntax for the file format. We also recommend that a
185
+ file or class name and description of purpose be included on the
186
+ same "printed page" as the copyright notice for easier
187
+ identification within third-party archives.
188
+
189
+ Copyright [yyyy] [name of copyright owner]
190
+
191
+ Licensed under the Apache License, Version 2.0 (the "License");
192
+ you may not use this file except in compliance with the License.
193
+ You may obtain a copy of the License at
194
+
195
+ http://www.apache.org/licenses/LICENSE-2.0
196
+
197
+ Unless required by applicable law or agreed to in writing, software
198
+ distributed under the License is distributed on an "AS IS" BASIS,
199
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
200
+ See the License for the specific language governing permissions and
201
+ limitations under the License.
@@ -0,0 +1,226 @@
1
+ Description
2
+ ===========
3
+
4
+ Installs runit and provides `runit_service` definition for managing new
5
+ services under runit.
6
+
7
+ This cookbook does not use runit to replace system init, nor are there
8
+ plans to do so.
9
+
10
+ For more information about runit:
11
+
12
+ * http://smarden.org/runit/
13
+
14
+ Requirements
15
+ ============
16
+
17
+ ## Platform:
18
+
19
+ * Debian/Ubuntu
20
+ * Gentoo
21
+
22
+ Attributes
23
+ ==========
24
+
25
+ See `attributes/default.rb` for defaults.
26
+
27
+ * `node['runit']['sv_bin']` - Full path to the `sv` binary.
28
+ * `node['runit']['chpst_bin']` - Full path to the `chpst` binary.
29
+ * `node['runit']['service_dir']` - Full path to the default "services"
30
+ directory where enabled services are linked.
31
+ * `node['runit']['sv_dir']` - Full path to the directory where the
32
+ service lives, which gets linked to `service_dir`.
33
+
34
+ Recipes
35
+ =======
36
+
37
+ default
38
+ -------
39
+
40
+ Installs and sets up runit on the system. Assumes a package
41
+ installation, so native package must exist. This recipe will make sure
42
+ that the runsvdir process gets started, ensures that inittab is
43
+ updated with the SV entry. The package will be preseeded on
44
+ ubuntu/debian signal init, otherwise the appropriate action is chosen
45
+ to notify the runsvdir command.
46
+
47
+ Older versions of Ubuntu (<= 10.04) are supported, but support may be
48
+ removed in a future version.
49
+
50
+ Definitions
51
+ ===========
52
+
53
+ The definition in this cookbook will be deprecated by an LWRP in a
54
+ future version. See __Roadmap__.
55
+
56
+ runit\_service
57
+ --------------
58
+
59
+ This definition includes `recipe[runit]` to ensure it is installed
60
+ first. As LWRPs cannot use `include_recipe`, this will not be
61
+ available in future versions, so runit will need to be in a role or
62
+ node run list.
63
+
64
+ Sets up a new service to be managed and supervised by runit. It will
65
+ be created in the `node['runit']['sv_dir']` unless otherwise specified
66
+ in the `directory` parameter (see below).
67
+
68
+ ### Parameters:
69
+
70
+ * `name` - Name of the service. This will be used in the template file
71
+ names (see __Usage__), as well as the name of the service resource
72
+ created in the definition.
73
+ * `directory` - the directory where the service's configuration and
74
+ scripts should be located. Default is `node['runit']['sv_dir']`.
75
+ * `only_if` - unused, will be removed in a future version (won't be
76
+ present in lwrp). Default is false.
77
+ * `finish_script` - if true, a finish script should be created.
78
+ Default is false. For more information see: [Description of runsv](http://smarden.org/runit/runsv.8.html).
79
+ * `control` - Array of signals to create a control directory with
80
+ control scripts (e.g., `sv-SERVICE-control-SIGNAL.erb`, where
81
+ SERVICE is the name parameter for the service name, and SIGNAL is
82
+ the Unix signal to send. Default is an empty array. For more
83
+ information see:
84
+ [Customize Control](http://smarden.org/runit/runsv.8.html)
85
+ * `run_restart` - if true, the service resource will subscribe to
86
+ changes to the run script and restart itself when it is modified.
87
+ Default is true.
88
+ * `active_directory` - used for user-specific services. Default is
89
+ `node['runit']['service_dir']`.
90
+ * `owner` - userid of the owner for the service's files, and should be
91
+ used in the run template with chpst to ensure the service runs as
92
+ that user. Default is root.
93
+ * `group` - groupid of the group for the service's files, and should
94
+ be used in the run template with chpst to ensure the service runs as
95
+ that group. Default is root.
96
+ * `template_name` - specify an alternate name for the templates
97
+ instead of basing them on the name parameter. Default is the name parameter.
98
+ * `log_template_name` - specify an alternate name for the runit log template
99
+ instead of basing them on the template_name parameter. Default is the
100
+ template_name parameter.
101
+ * `control_template_names` - specify alternate names for runit control signal
102
+ templates instead of basing them on the template_name parameter. Default
103
+ is the template_name parameter.
104
+ * `finish_script_template_name` - specify an altername for the finish script
105
+ template. Default is the template_name parameter
106
+ * `start_command` - The command used to start the service in
107
+ conjunction with the `sv` command and the `service_dir` name.
108
+ Default is `start`.
109
+ * `stop_command` - The command used to stop the service in conjunction
110
+ with the `sv` command and the `service_dir` name. Default is `stop`.
111
+ * `restart_command` - The command used to restart the service in
112
+ conjunction with the `sv` command and the `service_dir` name. You
113
+ may need to modify this to send an alternate signal to restart the
114
+ service depending on the nature of the process. Default is `restart`
115
+ * `status_command` - The command used to check status for the service in
116
+ conjunction with the `sv` command and the `service_dir` name. This
117
+ is used by chef when checking the current resource state in managing
118
+ the service. Default is `status`.
119
+ * `options` - a Hash of variables to pass into the run and log/run
120
+ templates with the template resource `variables` parameter.
121
+ Available inside the template(s) as `@options`. Default is an empty Hash.
122
+ * `env` -
123
+
124
+ ### Examples:
125
+
126
+ Create templates for `sv-myservice-run.erb` and
127
+ `sv-myservice-log-run.erb` that have the commands for starting
128
+ myservice and its logger.
129
+
130
+ runit_service "myservice"
131
+
132
+ See __Usage__ for expanded examples.
133
+
134
+ Resources/Providers
135
+ ===================
136
+
137
+ None yet. See __Roadmap__.
138
+
139
+ Usage
140
+ =====
141
+
142
+ To get runit installed on supported platforms, use `recipe[runit]`.
143
+ Once it is installed, use the `runit_service` definition to set up
144
+ services to be managed by runit. Do note that once
145
+ [CHEF-154](http://tickets.opscode.com/browse/CHEF-154) is implemented,
146
+ some of the usage/implementation here will change. In order to use the
147
+ `runit_service` definition, two templates must be created for the
148
+ service, `cookbook_name/templates/default/sv-SERVICE-run.erb` and
149
+ `cookbook_name/templates/default/sv-SERVICE-log-run.erb`. Replace
150
+ `SERVICE` with the name of the service you're managing. For more usage,
151
+ see __Examples__.
152
+
153
+ Examples
154
+ --------
155
+
156
+ We'll set up `chef-client` to run as a service under runit, such as is
157
+ done in the `chef-client` cookbook. This example will be more simple
158
+ than in that cookbook. First, create the required run template,
159
+ `chef-client/templates/default/sv-chef-client-run.erb`.
160
+
161
+ #!/bin/sh
162
+ exec 2>&1
163
+ exec /usr/bin/env chef-client -i 1800 -s 30
164
+
165
+ Then create the required log/run template,
166
+ `chef-client/templates/default/sv-chef-client-run.erb`.
167
+
168
+ #!/bin/sh
169
+ exec svlogd -tt ./main
170
+
171
+ __Note__ This will cause output of the running process to go to
172
+ `/etc/sv/chef-client/log/main/current`.
173
+
174
+ Finally, set up the service in the `chef-client` recipe with:
175
+
176
+ runit_service "chef-client"
177
+
178
+ Next, let's set up memcached with some additional options. First, the
179
+ `memcached/templates/default/sv-memcached-run.erb` template:
180
+
181
+ #!/bin/sh
182
+ exec 2>&1
183
+ exec chpst -u <%= @options[:user] %> /usr/bin/memcached -v -m <%= @options[:memory] %> -p <%= @options[:port] %>
184
+
185
+ Note that the script uses chpst (which comes with runit) to set the
186
+ user option, then starts memcached on the specified memory and port
187
+ (see below).
188
+
189
+ The log/run template,
190
+ `memcached/templates/default/sv-memcached-log-run.erb`:
191
+
192
+ #!/bin/sh
193
+ exec svlogd -tt ./main
194
+
195
+ Finally, the `runit_service` in our recipe:
196
+
197
+ runit_service "memcached" do
198
+ options({
199
+ :memory => node[:memcached][:memory],
200
+ :port => node[:memcached][:port],
201
+ :user => node[:memcached][:user]}.merge(params)
202
+ )
203
+ end
204
+
205
+ This is where the user, port and memory options used in the run
206
+ template are used.
207
+
208
+ License and Author
209
+ ==================
210
+
211
+ Author:: Adam Jacob <adam@opscode.com>
212
+ Author:: Joshua Timberman <joshua@opscode.com>
213
+
214
+ Copyright:: 2008-2011, Opscode, Inc
215
+
216
+ Licensed under the Apache License, Version 2.0 (the "License");
217
+ you may not use this file except in compliance with the License.
218
+ You may obtain a copy of the License at
219
+
220
+ http://www.apache.org/licenses/LICENSE-2.0
221
+
222
+ Unless required by applicable law or agreed to in writing, software
223
+ distributed under the License is distributed on an "AS IS" BASIS,
224
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
225
+ See the License for the specific language governing permissions and
226
+ limitations under the License.
@@ -0,0 +1,31 @@
1
+ #
2
+ # Cookbook Name:: runit
3
+ # Attribute File:: sv_bin
4
+ #
5
+ # Copyright 2008-2009, Opscode, Inc.
6
+ #
7
+ # Licensed under the Apache License, Version 2.0 (the "License");
8
+ # you may not use this file except in compliance with the License.
9
+ # You may obtain a copy of the License at
10
+ #
11
+ # http://www.apache.org/licenses/LICENSE-2.0
12
+ #
13
+ # Unless required by applicable law or agreed to in writing, software
14
+ # distributed under the License is distributed on an "AS IS" BASIS,
15
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16
+ # See the License for the specific language governing permissions and
17
+ # limitations under the License.
18
+ #
19
+
20
+ case platform
21
+ when "ubuntu","debian"
22
+ set[:runit][:sv_bin] = "/usr/bin/sv"
23
+ set[:runit][:chpst_bin] = "/usr/bin/chpst"
24
+ set[:runit][:service_dir] = "/etc/service"
25
+ set[:runit][:sv_dir] = "/etc/sv"
26
+ when "gentoo"
27
+ set[:runit][:sv_bin] = "/usr/bin/sv"
28
+ set[:runit][:chpst_bin] = "/usr/bin/chpst"
29
+ set[:runit][:service_dir] = "/etc/service"
30
+ set[:runit][:sv_dir] = "/var/service"
31
+ end
@@ -0,0 +1,164 @@
1
+ #
2
+ # Cookbook Name:: runit
3
+ # Definition:: runit_service
4
+ #
5
+ # Copyright 2008-2009, Opscode, Inc.
6
+ #
7
+ # Licensed under the Apache License, Version 2.0 (the "License");
8
+ # you may not use this file except in compliance with the License.
9
+ # You may obtain a copy of the License at
10
+ #
11
+ # http://www.apache.org/licenses/LICENSE-2.0
12
+ #
13
+ # Unless required by applicable law or agreed to in writing, software
14
+ # distributed under the License is distributed on an "AS IS" BASIS,
15
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16
+ # See the License for the specific language governing permissions and
17
+ # limitations under the License.
18
+ #
19
+
20
+ define :runit_service, :directory => nil, :only_if => false, :finish_script => false, :control => [], :run_restart => true, :active_directory => nil, :owner => "root", :group => "root", :template_name => nil, :log_template_name => nil, :control_template_names => {}, :finish_script_template_name => nil, :start_command => "start", :stop_command => "stop", :restart_command => "restart", :status_command => "status", :options => Hash.new, :env => Hash.new do
21
+ include_recipe "runit"
22
+
23
+ params[:directory] ||= node[:runit][:sv_dir]
24
+ params[:active_directory] ||= node[:runit][:service_dir]
25
+ params[:template_name] ||= params[:name]
26
+ params[:log_template_name] ||= params[:template_name]
27
+ params[:control].each do |signal|
28
+ params[:control_template_names][signal] ||= params[:template_name]
29
+ end
30
+ params[:finish_script_template_name] ||= params[:template_name]
31
+
32
+ sv_dir_name = "#{params[:directory]}/#{params[:name]}"
33
+ service_dir_name = "#{params[:active_directory]}/#{params[:name]}"
34
+ params[:options].merge!(:env_dir => "#{sv_dir_name}/env") unless params[:env].empty?
35
+
36
+ directory sv_dir_name do
37
+ owner params[:owner]
38
+ group params[:group]
39
+ mode 0755
40
+ action :create
41
+ end
42
+
43
+ directory "#{sv_dir_name}/log" do
44
+ owner params[:owner]
45
+ group params[:group]
46
+ mode 0755
47
+ action :create
48
+ end
49
+
50
+ directory "#{sv_dir_name}/log/main" do
51
+ owner params[:owner]
52
+ group params[:group]
53
+ mode 0755
54
+ action :create
55
+ end
56
+
57
+ template "#{sv_dir_name}/run" do
58
+ owner params[:owner]
59
+ group params[:group]
60
+ mode 0755
61
+ source "sv-#{params[:template_name]}-run.erb"
62
+ cookbook params[:cookbook] if params[:cookbook]
63
+ if params[:options].respond_to?(:has_key?)
64
+ variables :options => params[:options]
65
+ end
66
+ end
67
+
68
+ template "#{sv_dir_name}/log/run" do
69
+ owner params[:owner]
70
+ group params[:group]
71
+ mode 0755
72
+ source "sv-#{params[:log_template_name]}-log-run.erb"
73
+ cookbook params[:cookbook] if params[:cookbook]
74
+ if params[:options].respond_to?(:has_key?)
75
+ variables :options => params[:options]
76
+ end
77
+ end
78
+
79
+ unless params[:env].empty?
80
+ directory "#{sv_dir_name}/env" do
81
+ mode 0755
82
+ action :create
83
+ end
84
+
85
+ params[:env].each do |var, value|
86
+ file "#{sv_dir_name}/env/#{var}" do
87
+ content value
88
+ end
89
+ end
90
+ end
91
+
92
+ if params[:finish_script]
93
+ template "#{sv_dir_name}/finish" do
94
+ owner params[:owner]
95
+ group params[:group]
96
+ mode 0755
97
+ source "sv-#{params[:finish_script_template_name]}-finish.erb"
98
+ cookbook params[:cookbook] if params[:cookbook]
99
+ if params[:options].respond_to?(:has_key?)
100
+ variables :options => params[:options]
101
+ end
102
+ end
103
+ end
104
+
105
+ unless params[:control].empty?
106
+ directory "#{sv_dir_name}/control" do
107
+ owner params[:owner]
108
+ group params[:group]
109
+ mode 0755
110
+ action :create
111
+ end
112
+
113
+ params[:control].each do |signal|
114
+ template "#{sv_dir_name}/control/#{signal}" do
115
+ owner params[:owner]
116
+ group params[:group]
117
+ mode 0755
118
+ source "sv-#{params[:control_template_names][signal]}-control-#{signal}.erb"
119
+ cookbook params[:cookbook] if params[:cookbook]
120
+ if params[:options].respond_to?(:has_key?)
121
+ variables :options => params[:options]
122
+ end
123
+ end
124
+ end
125
+ end
126
+
127
+ if params[:active_directory] == node[:runit][:service_dir]
128
+ link "/etc/init.d/#{params[:name]}" do
129
+ to node[:runit][:sv_bin]
130
+ end
131
+ end
132
+
133
+ unless node[:platform] == "gentoo"
134
+ link service_dir_name do
135
+ to sv_dir_name
136
+ end
137
+ end
138
+
139
+ ruby_block "supervise_#{params[:name]}_sleep" do
140
+ block do
141
+ Chef::Log.debug("Waiting until named pipe #{sv_dir_name}/supervise/ok exists.")
142
+ (1..10).each {|i| sleep 1 unless ::FileTest.pipe?("#{sv_dir_name}/supervise/ok") }
143
+ end
144
+ not_if { FileTest.pipe?("#{sv_dir_name}/supervise/ok") }
145
+ end
146
+
147
+ service params[:name] do
148
+ control_cmd = node[:runit][:sv_bin]
149
+ if params[:owner]
150
+ control_cmd = "#{node[:runit][:chpst_bin]} -u #{params[:owner]} #{control_cmd}"
151
+ end
152
+ provider Chef::Provider::Service::Init
153
+ supports :restart => true, :status => true
154
+ start_command "#{control_cmd} #{params[:start_command]} #{service_dir_name}"
155
+ stop_command "#{control_cmd} #{params[:stop_command]} #{service_dir_name}"
156
+ restart_command "#{control_cmd} #{params[:restart_command]} #{service_dir_name}"
157
+ status_command "#{control_cmd} #{params[:status_command]} #{service_dir_name}"
158
+ if params[:run_restart]
159
+ subscribes :restart, resources(:template => "#{sv_dir_name}/run"), :delayed
160
+ end
161
+ action :nothing
162
+ end
163
+
164
+ end
@@ -0,0 +1 @@
1
+ runit runit/signalinit boolean true
File without changes
@@ -0,0 +1,6 @@
1
+ start on runlevel-2
2
+ start on runlevel-3
3
+ start on runlevel-4
4
+ start on runlevel-5
5
+ stop on shutdown
6
+ respawn /usr/sbin/runsvdir-start
@@ -0,0 +1,7 @@
1
+ start on runlevel 2
2
+ start on runlevel 3
3
+ start on runlevel 4
4
+ start on runlevel 5
5
+ stop on shutdown
6
+ respawn
7
+ exec /usr/sbin/runsvdir-start
@@ -0,0 +1,7 @@
1
+ start on runlevel 2
2
+ start on runlevel 3
3
+ start on runlevel 4
4
+ start on runlevel 5
5
+ stop on shutdown
6
+ respawn
7
+ exec /usr/sbin/runsvdir-start
@@ -0,0 +1,7 @@
1
+ start on runlevel 2
2
+ start on runlevel 3
3
+ start on runlevel 4
4
+ start on runlevel 5
5
+ stop on shutdown
6
+ respawn
7
+ exec /usr/sbin/runsvdir-start