andyh-deprec 1.99.26

Sign up to get free protection for your applications and to get access to all the features.
Files changed (139) hide show
  1. data/CHANGELOG +187 -0
  2. data/COPYING +19 -0
  3. data/LICENSE +339 -0
  4. data/README +138 -0
  5. data/THANKS +5 -0
  6. data/bin/depify +133 -0
  7. data/docs/ANNOUNCE.deprec2 +47 -0
  8. data/docs/README.install +88 -0
  9. data/docs/README.nagios +22 -0
  10. data/docs/README.rails +20 -0
  11. data/docs/README.svn +31 -0
  12. data/docs/ROADMAP.txt +74 -0
  13. data/docs/deprec-1.x/deprec-1.x.quickstart +50 -0
  14. data/docs/deprec-1.x/notes.txt +12 -0
  15. data/docs/deprec_banner.gif +0 -0
  16. data/docs/windows_linux.txt +350 -0
  17. data/docs/xen/plan.txt +5 -0
  18. data/docs/xen/traffic_monitoring_with_vnstat.txt +95 -0
  19. data/docs/xen/xen-tools-notes.txt +31 -0
  20. data/docs/xen/xen_on_hardy.txt +39 -0
  21. data/lib/deprec/capistrano_extensions.rb +391 -0
  22. data/lib/deprec/recipes/aoe.rb +80 -0
  23. data/lib/deprec/recipes/apache.rb +179 -0
  24. data/lib/deprec/recipes/ar_sendmail.rb +65 -0
  25. data/lib/deprec/recipes/canonical.rb +57 -0
  26. data/lib/deprec/recipes/deprec.rb +188 -0
  27. data/lib/deprec/recipes/deprecated.rb +71 -0
  28. data/lib/deprec/recipes/example.rb +115 -0
  29. data/lib/deprec/recipes/git.rb +97 -0
  30. data/lib/deprec/recipes/gitosis.rb +48 -0
  31. data/lib/deprec/recipes/heartbeat.rb +138 -0
  32. data/lib/deprec/recipes/logrotate.rb +54 -0
  33. data/lib/deprec/recipes/lvm.rb +20 -0
  34. data/lib/deprec/recipes/memcache.rb +49 -0
  35. data/lib/deprec/recipes/mongrel.rb +219 -0
  36. data/lib/deprec/recipes/monit.rb +135 -0
  37. data/lib/deprec/recipes/mysql.rb +115 -0
  38. data/lib/deprec/recipes/nagios.rb +305 -0
  39. data/lib/deprec/recipes/network.rb +81 -0
  40. data/lib/deprec/recipes/nginx.rb +144 -0
  41. data/lib/deprec/recipes/ntp.rb +103 -0
  42. data/lib/deprec/recipes/php.rb +99 -0
  43. data/lib/deprec/recipes/postfix.rb +105 -0
  44. data/lib/deprec/recipes/rails.rb +288 -0
  45. data/lib/deprec/recipes/ruby.rb +66 -0
  46. data/lib/deprec/recipes/sphinx.rb +83 -0
  47. data/lib/deprec/recipes/ssh.rb +93 -0
  48. data/lib/deprec/recipes/svn.rb +171 -0
  49. data/lib/deprec/recipes/trac.rb +277 -0
  50. data/lib/deprec/recipes/ubuntu.rb +20 -0
  51. data/lib/deprec/recipes/users.rb +90 -0
  52. data/lib/deprec/recipes/utils.rb +39 -0
  53. data/lib/deprec/recipes/vnstat.rb +85 -0
  54. data/lib/deprec/recipes/xen.rb +262 -0
  55. data/lib/deprec/recipes.rb +37 -0
  56. data/lib/deprec/templates/aoe/aoe-init +55 -0
  57. data/lib/deprec/templates/aoe/fence_aoemask +351 -0
  58. data/lib/deprec/templates/apache/httpd-vhost-app.conf.erb +144 -0
  59. data/lib/deprec/templates/apache/httpd.conf +465 -0
  60. data/lib/deprec/templates/apache/index.html.erb +37 -0
  61. data/lib/deprec/templates/apache/master.css +72 -0
  62. data/lib/deprec/templates/ar_sendmail/logrotate.conf.erb +9 -0
  63. data/lib/deprec/templates/ar_sendmail/monit.conf.erb +5 -0
  64. data/lib/deprec/templates/deprec/caprc.erb +14 -0
  65. data/lib/deprec/templates/heartbeat/authkeys.erb +2 -0
  66. data/lib/deprec/templates/heartbeat/ha.cf.erb +15 -0
  67. data/lib/deprec/templates/heartbeat/haresources.erb +1 -0
  68. data/lib/deprec/templates/logrotate/logrotate.conf.erb +32 -0
  69. data/lib/deprec/templates/mongrel/logrotate.conf.erb +11 -0
  70. data/lib/deprec/templates/mongrel/mongrel_cluster-init-script +54 -0
  71. data/lib/deprec/templates/mongrel/mongrel_cluster.logrotate.d +14 -0
  72. data/lib/deprec/templates/mongrel/mongrel_cluster.yml.erb +10 -0
  73. data/lib/deprec/templates/mongrel/monit.conf.erb +17 -0
  74. data/lib/deprec/templates/monit/monit-init-script +104 -0
  75. data/lib/deprec/templates/monit/monitrc.erb +227 -0
  76. data/lib/deprec/templates/monit/nothing +0 -0
  77. data/lib/deprec/templates/mysql/create_databases.sql +20 -0
  78. data/lib/deprec/templates/mysql/database.yml.prod +6 -0
  79. data/lib/deprec/templates/mysql/database.yml.stage +6 -0
  80. data/lib/deprec/templates/mysql/my.cnf.erb +140 -0
  81. data/lib/deprec/templates/mysql/sphinx.conf.prod +542 -0
  82. data/lib/deprec/templates/mysql/sphinx.conf.stage +542 -0
  83. data/lib/deprec/templates/nagios/cgi.cfg.erb +321 -0
  84. data/lib/deprec/templates/nagios/check_linux_free_memory.pl +118 -0
  85. data/lib/deprec/templates/nagios/check_mongrel_cluster.rb +82 -0
  86. data/lib/deprec/templates/nagios/commands.cfg.erb +240 -0
  87. data/lib/deprec/templates/nagios/contacts.cfg.erb +57 -0
  88. data/lib/deprec/templates/nagios/hosts.cfg.erb +143 -0
  89. data/lib/deprec/templates/nagios/htpasswd.users +1 -0
  90. data/lib/deprec/templates/nagios/localhost.cfg.erb +157 -0
  91. data/lib/deprec/templates/nagios/nagios.cfg.erb +1274 -0
  92. data/lib/deprec/templates/nagios/nagios_apache_vhost.conf.erb +45 -0
  93. data/lib/deprec/templates/nagios/nrpe.cfg.erb +210 -0
  94. data/lib/deprec/templates/nagios/nrpe.xinetd.erb +16 -0
  95. data/lib/deprec/templates/nagios/resource.cfg.erb +34 -0
  96. data/lib/deprec/templates/nagios/services.cfg.erb +79 -0
  97. data/lib/deprec/templates/nagios/templates.cfg.erb +9 -0
  98. data/lib/deprec/templates/nagios/timeperiods.cfg.erb +94 -0
  99. data/lib/deprec/templates/network/hostname.erb +1 -0
  100. data/lib/deprec/templates/network/hosts.erb +2 -0
  101. data/lib/deprec/templates/network/interfaces.erb +18 -0
  102. data/lib/deprec/templates/nginx/logrotate.conf.erb +13 -0
  103. data/lib/deprec/templates/nginx/mime.types.erb +70 -0
  104. data/lib/deprec/templates/nginx/nginx-init-script +62 -0
  105. data/lib/deprec/templates/nginx/nginx.conf.erb +125 -0
  106. data/lib/deprec/templates/nginx/nginx.logrotate.d +12 -0
  107. data/lib/deprec/templates/nginx/nothing.conf +1 -0
  108. data/lib/deprec/templates/nginx/rails_nginx_vhost.conf.erb +41 -0
  109. data/lib/deprec/templates/ntp/ntp.conf.erb +42 -0
  110. data/lib/deprec/templates/postfix/aliases.erb +3 -0
  111. data/lib/deprec/templates/postfix/dynamicmaps.cf.erb +8 -0
  112. data/lib/deprec/templates/postfix/main.cf.erb +41 -0
  113. data/lib/deprec/templates/postfix/master.cf.erb +77 -0
  114. data/lib/deprec/templates/sphinx/monit.conf.erb +5 -0
  115. data/lib/deprec/templates/ssh/ssh_config.erb +50 -0
  116. data/lib/deprec/templates/ssh/sshd_config.erb +78 -0
  117. data/lib/deprec/templates/subversion/svn.apache.vhost.erb +43 -0
  118. data/lib/deprec/templates/trac/apache_vhost.conf.erb +24 -0
  119. data/lib/deprec/templates/trac/nginx_vhost.conf.erb +26 -0
  120. data/lib/deprec/templates/trac/trac.ini.erb +169 -0
  121. data/lib/deprec/templates/trac/trac_deprec.png +0 -0
  122. data/lib/deprec/templates/trac/tracd-init.erb +43 -0
  123. data/lib/deprec/templates/trac/users.htdigest.erb +0 -0
  124. data/lib/deprec/templates/vnstat/config.php +57 -0
  125. data/lib/deprec/templates/xen/15-disable-hwclock +40 -0
  126. data/lib/deprec/templates/xen/network-bridge-wrapper +3 -0
  127. data/lib/deprec/templates/xen/xen-tools.conf.erb +220 -0
  128. data/lib/deprec/templates/xen/xend-config.sxp.erb +195 -0
  129. data/lib/deprec/templates/xen/xend-init.erb +69 -0
  130. data/lib/deprec/templates/xen/xendomains.erb +137 -0
  131. data/lib/deprec/templates/xen/xm.tmpl.erb +85 -0
  132. data/lib/deprec.rb +8 -0
  133. data/lib/deprec_cmd_completion.sh +26 -0
  134. data/lib/vmbuilder_plugins/all.rb +20 -0
  135. data/lib/vmbuilder_plugins/apt.rb +93 -0
  136. data/lib/vmbuilder_plugins/emerge.rb +76 -0
  137. data/lib/vmbuilder_plugins/gem.rb +90 -0
  138. data/lib/vmbuilder_plugins/std.rb +203 -0
  139. metadata +224 -0
@@ -0,0 +1,115 @@
1
+ # Copyright 2006-2008 by Mike Bailey. All rights reserved.
2
+ Capistrano::Configuration.instance(:must_exist).load do
3
+ namespace :deprec do
4
+ namespace :mysql do
5
+
6
+ # Installation
7
+
8
+ desc "Install mysql"
9
+ task :install do
10
+ install_deps
11
+ symlink_mysql_sockfile # XXX still needed?
12
+ end
13
+
14
+ # Install dependencies for Mysql
15
+ task :install_deps do
16
+ apt.install( {:base => %w(mysql-server mysql-client)}, :stable )
17
+ end
18
+
19
+ task :symlink_mysql_sockfile, :roles => :db do
20
+ # rails puts "socket: /tmp/mysql.sock" into config/database.yml
21
+ # this is not the location for our ubuntu's mysql socket file
22
+ # so we create this link to make deployment using rails defaults simpler
23
+ sudo "ln -sf /var/run/mysqld/mysqld.sock /tmp/mysql.sock"
24
+ end
25
+
26
+ # Configuration
27
+
28
+ SYSTEM_CONFIG_FILES[:mysql] = [
29
+
30
+ {:template => "my.cnf.erb",
31
+ :path => '/etc/mysql/my.cnf',
32
+ :mode => 0644,
33
+ :owner => 'root:root'}
34
+ ]
35
+
36
+ desc "Generate configuration file(s) for mysql from template(s)"
37
+ task :config_gen do
38
+ SYSTEM_CONFIG_FILES[:mysql].each do |file|
39
+ deprec2.render_template(:mysql, file)
40
+ end
41
+ end
42
+
43
+ desc "Push mysql config files to server"
44
+ task :config, :roles => :db do
45
+ deprec2.push_configs(:mysql, SYSTEM_CONFIG_FILES[:mysql])
46
+ end
47
+
48
+ task :activate, :roles => :db do
49
+ send(run_method, "update-rc.d mysql defaults")
50
+ end
51
+
52
+ task :deactivate, :roles => :db do
53
+ send(run_method, "update-rc.d -f mysql remove")
54
+ end
55
+
56
+ # Control
57
+
58
+ desc "Start Mysql"
59
+ task :start, :roles => :db do
60
+ send(run_method, "/etc/init.d/mysql start")
61
+ end
62
+
63
+ desc "Stop Mysql"
64
+ task :stop, :roles => :db do
65
+ send(run_method, "/etc/init.d/mysql stop")
66
+ end
67
+
68
+ desc "Restart Mysql"
69
+ task :restart, :roles => :db do
70
+ send(run_method, "/etc/init.d/mysql restart")
71
+ end
72
+
73
+ desc "Reload Mysql"
74
+ task :reload, :roles => :db do
75
+ send(run_method, "/etc/init.d/mysql reload")
76
+ end
77
+
78
+
79
+ task :backup, :roles => :db do
80
+ end
81
+
82
+ task :restore, :roles => :db do
83
+ end
84
+
85
+ end
86
+ end
87
+ end
88
+
89
+ #
90
+ # Setup replication
91
+ #
92
+
93
+ # setup user for repl
94
+ # GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%.yourdomain.com' IDENTIFIED BY 'slavepass';
95
+
96
+ # get current position of binlog
97
+ # mysql> FLUSH TABLES WITH READ LOCK;
98
+ # Query OK, 0 rows affected (0.00 sec)
99
+ #
100
+ # mysql> SHOW MASTER STATUS;
101
+ # +------------------+----------+--------------+------------------+
102
+ # | File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
103
+ # +------------------+----------+--------------+------------------+
104
+ # | mysql-bin.000012 | 296 | | |
105
+ # +------------------+----------+--------------+------------------+
106
+ # 1 row in set (0.00 sec)
107
+ #
108
+ # # get current data
109
+ # mysqldump --all-databases --master-data >dbdump.db
110
+ #
111
+ # UNLOCK TABLES;
112
+
113
+
114
+ # Replication Features and Issues
115
+ # http://dev.mysql.com/doc/refman/5.0/en/replication-features.html
@@ -0,0 +1,305 @@
1
+ # Copyright 2006-2008 by Mike Bailey. All rights reserved.
2
+ Capistrano::Configuration.instance(:must_exist).load do
3
+ namespace :deprec do
4
+ namespace :nagios do
5
+
6
+ set :nagios_user, 'nagios'
7
+ set :nagios_group, 'nagios'
8
+ set(:nagios_host) { Capistrano::CLI.ui.ask "Enter hostname of nagios server" }
9
+ set :nagios_cmd_group, 'nagcmd' # Allow external commands to be submitted through the web interface
10
+ default :application, 'nagios'
11
+
12
+ SRC_PACKAGES[:nagios] = {
13
+ :url => "http://internap.dl.sourceforge.net/sourceforge/nagios/nagios-3.0.2.tar.gz",
14
+ :md5sum => "008d71aac08660bc007f7130ea82ab80 nagios-3.0.2.tar.gz",
15
+ :configure => %w(
16
+ ./configure
17
+ --with-command-group=nagcmd
18
+ ;
19
+ ).reject{|arg| arg.match '#'}.join(' '),
20
+ :make => 'make all;',
21
+ :install => 'make install install-init install-commandmode'
22
+ }
23
+
24
+ desc "Install nagios"
25
+ task :install do
26
+ install_deps
27
+ create_nagios_user
28
+ deprec2.add_user_to_group(nagios_user, apache_user)
29
+ deprec2.mkdir('/usr/local/nagios/etc', :owner => "#{nagios_user}.#{nagios_group}", :via => :sudo)
30
+ deprec2.mkdir('/usr/local/nagios/objects', :owner => "#{nagios_user}.#{nagios_group}", :via => :sudo)
31
+ deprec2.download_src(SRC_PACKAGES[:nagios], src_dir)
32
+ deprec2.install_from_src(SRC_PACKAGES[:nagios], src_dir)
33
+ activate
34
+ end
35
+
36
+ task :create_nagios_user do
37
+ deprec2.groupadd(nagios_group)
38
+ deprec2.useradd(nagios_user, :group => nagios_group, :homedir => false)
39
+ deprec2.groupadd(nagios_cmd_group)
40
+ deprec2.add_user_to_group(nagios_user, nagios_cmd_group)
41
+ # Add apache user to nagios group to permit commands via web interface
42
+ deprec2.add_user_to_group(apache_user, nagios_cmd_group)
43
+ end
44
+
45
+ # Install dependencies for nagios
46
+ task :install_deps do
47
+ apt.install( {:base => %w(mailx)}, :stable )
48
+ end
49
+
50
+ SYSTEM_CONFIG_FILES[:nagios] = [
51
+
52
+ {:template => 'nagios.cfg.erb',
53
+ :path => '/usr/local/nagios/etc/nagios.cfg',
54
+ :mode => 0664,
55
+ :owner => 'nagios:nagios'},
56
+
57
+ {:template => 'resource.cfg.erb',
58
+ :path => '/usr/local/nagios/etc/resource.cfg',
59
+ :mode => 0660,
60
+ :owner => 'nagios:nagios'},
61
+
62
+ {:template => 'cgi.cfg.erb',
63
+ :path => '/usr/local/nagios/etc/cgi.cfg',
64
+ :mode => 0664,
65
+ :owner => 'nagios:nagios'},
66
+
67
+ {:template => 'htpasswd.users',
68
+ :path => '/usr/local/nagios/etc/htpasswd.users',
69
+ :mode => 0664,
70
+ :owner => 'nagios:nagios'},
71
+
72
+ {:template => 'templates.cfg.erb',
73
+ :path => '/usr/local/nagios/etc/objects/templates.cfg',
74
+ :mode => 0664,
75
+ :owner => 'nagios:nagios'},
76
+
77
+ {:template => 'commands.cfg.erb',
78
+ :path => '/usr/local/nagios/etc/objects/commands.cfg',
79
+ :mode => 0664,
80
+ :owner => 'nagios:nagios'},
81
+
82
+ {:template => 'timeperiods.cfg.erb',
83
+ :path => '/usr/local/nagios/etc/objects/timeperiods.cfg',
84
+ :mode => 0664,
85
+ :owner => 'nagios:nagios'},
86
+
87
+ {:template => 'localhost.cfg.erb',
88
+ :path => '/usr/local/nagios/etc/objects/localhost.cfg',
89
+ :mode => 0664,
90
+ :owner => 'nagios:nagios'},
91
+
92
+ {:template => 'contacts.cfg.erb',
93
+ :path => '/usr/local/nagios/etc/objects/contacts.cfg',
94
+ :mode => 0664,
95
+ :owner => 'nagios:nagios'},
96
+
97
+ {:template => 'hosts.cfg.erb',
98
+ :path => '/usr/local/nagios/etc/objects/hosts.cfg',
99
+ :mode => 0664,
100
+ :owner => 'nagios:nagios'},
101
+
102
+ {:template => 'services.cfg.erb',
103
+ :path => '/usr/local/nagios/etc/objects/services.cfg',
104
+ :mode => 0664,
105
+ :owner => 'nagios:nagios'},
106
+
107
+ {:template => 'localhost.cfg.erb',
108
+ :path => '/usr/local/nagios/etc/objects/localhost.cfg',
109
+ :mode => 0664,
110
+ :owner => 'nagios:nagios'},
111
+
112
+ {:template => 'nagios_apache_vhost.conf.erb',
113
+ :path => "conf/nagios_apache_vhost.conf",
114
+ :mode => 0644,
115
+ :owner => 'root:root'}
116
+
117
+ ]
118
+
119
+ desc "Generate configuration file(s) for nagios from template(s)"
120
+ task :config_gen do
121
+ SYSTEM_CONFIG_FILES[:nagios].each do |file|
122
+ deprec2.render_template(:nagios, file)
123
+ end
124
+ end
125
+
126
+ desc "Push nagios config files to server"
127
+ task :config, :roles => :nagios do
128
+ set :application, 'nagios'
129
+ deprec2.push_configs(:nagios, SYSTEM_CONFIG_FILES[:nagios])
130
+ sudo "ln -sf #{deploy_to}/nagios/conf/nagios_apache_vhost.conf /usr/local/apache2/conf/apps"
131
+ config_check
132
+ restart
133
+ end
134
+
135
+ desc "Run Nagios config check"
136
+ task :config_check, :roles => :nagios do
137
+ send(run_method, "/usr/local/nagios/bin/nagios -v /usr/local/nagios/etc/nagios.cfg")
138
+ end
139
+
140
+ desc "Set Nagios to start on boot"
141
+ task :activate, :roles => :nagios do
142
+ send(run_method, "update-rc.d nagios defaults")
143
+ sudo "ln -sf #{deploy_to}/nagios/conf/nagios_apache_vhost.conf /usr/local/apache2/conf/apps"
144
+ end
145
+
146
+ desc "Set Nagios to not start on boot"
147
+ task :deactivate, :roles => :nagios do
148
+ send(run_method, "update-rc.d -f nagios remove")
149
+ link = "#{apache_vhost_dir}/nagios_#{application}.conf"
150
+ sudo "test -h #{link} && sudo unlink #{link} || true"
151
+ end
152
+
153
+ # Control
154
+
155
+ desc "Start Nagios"
156
+ task :start, :roles => :nagios do
157
+ send(run_method, "/etc/init.d/nagios start")
158
+ end
159
+
160
+ desc "Stop Nagios"
161
+ task :stop, :roles => :nagios do
162
+ send(run_method, "/etc/init.d/nagios stop")
163
+ end
164
+
165
+ desc "Restart Nagios"
166
+ task :restart, :roles => :nagios do
167
+ send(run_method, "/etc/init.d/nagios restart")
168
+ end
169
+
170
+ desc "Reload Nagios"
171
+ task :reload, :roles => :nagios do
172
+ send(run_method, "/etc/init.d/nagios reload")
173
+ end
174
+
175
+ task :backup, :roles => :web do
176
+ # not yet implemented
177
+ end
178
+
179
+ task :restore, :roles => :web do
180
+ # not yet implemented
181
+ end
182
+
183
+ #
184
+ # Service specific tasks
185
+ #
186
+
187
+ # XXX quick and dirty - clean up later
188
+ desc "Grant a user access to the web interface"
189
+ task :htpass, :roles => :nagios do
190
+ target_user = Capistrano::CLI.ui.ask "Userid" do |q|
191
+ q.default = 'nagiosadmin'
192
+ end
193
+ system "htpasswd config/nagios/usr/local/nagios/etc/htpasswd.users #{target_user}"
194
+ end
195
+
196
+ end
197
+
198
+ SRC_PACKAGES[:nagios_plugins] = {
199
+ :url => "http://downloads.sourceforge.net/nagiosplug/nagios-plugins-1.4.12.tar.gz",
200
+ :md5sum => "af68d00bbe2c39de02803d23e5eecca3 nagios-plugins-1.4.12.tar.gz",
201
+ :configure => "./configure --with-nagios-user=#{nagios_user} --with-nagios-group=#{nagios_group};",
202
+ }
203
+
204
+ namespace :nagios_plugins do
205
+
206
+ desc "Install nagios plugins"
207
+ task :install do
208
+ install_deps
209
+ top.deprec.nagios.create_nagios_user
210
+ deprec2.download_src(SRC_PACKAGES[:nagios_plugins], src_dir)
211
+ deprec2.install_from_src(SRC_PACKAGES[:nagios_plugins], src_dir)
212
+ end
213
+
214
+ # Install dependencies for nagios plugins
215
+ task :install_deps do
216
+ apt.install( {:base => %w(libmysqlclient15-dev)}, :stable )
217
+ end
218
+
219
+
220
+ end
221
+
222
+
223
+ namespace :nrpe do
224
+
225
+ default :nrpe_enable_command_args, false # set to true to compile nrpe to accept arguments
226
+ # note that you'll need to set it before these recipes are loaded (e.g. in .caprc)
227
+
228
+ SRC_PACKAGES[:nrpe] = {
229
+ :url => "http://downloads.sourceforge.net/nagios/nrpe-2.12.tar.gz",
230
+ :md5sum => "b2d75e2962f1e3151ef58794d60c9e97 nrpe-2.12.tar.gz",
231
+ :configure => "./configure --with-nagios-user=#{nagios_user} --with-nagios-group=#{nagios_group} #{ '--enable-command-args' if nrpe_enable_command_args};",
232
+ :make => 'make all;',
233
+ :install => 'make install-plugin; make install-daemon; make install-daemon-config;'
234
+ }
235
+
236
+ desc 'Install NRPE'
237
+ task :install do
238
+ install_deps
239
+ top.deprec.nagios.create_nagios_user
240
+ deprec2.download_src(SRC_PACKAGES[:nrpe], src_dir)
241
+ deprec2.install_from_src(SRC_PACKAGES[:nrpe], src_dir)
242
+ # XXX this should only be run on the nrpe clients
243
+ # XXX currently it's run on the nagios server too
244
+ # XXX shouldn't do any harm but we should split them up later
245
+ deprec2.append_to_file_if_missing('/etc/services', 'nrpe 5666/tcp # NRPE')
246
+ end
247
+
248
+ task :install_deps do
249
+ apt.install( {:base => %w(xinetd libssl-dev openssl)}, :stable )
250
+ end
251
+
252
+ SYSTEM_CONFIG_FILES[:nrpe] = [
253
+
254
+ {:template => 'nrpe.xinetd.erb',
255
+ :path => "/etc/xinetd.d/nrpe",
256
+ :mode => 0644,
257
+ :owner => 'root:root'},
258
+
259
+ {:template => 'nrpe.cfg.erb',
260
+ :path => "/usr/local/nagios/etc/nrpe.cfg",
261
+ :mode => 0644,
262
+ :owner => 'nagios:nagios'}, # XXX hard coded file owner is bad...
263
+ # It's done here because we aren't using
264
+ # lazy eval in hash constant.
265
+ {:template => "check_mongrel_cluster.rb",
266
+ :path => '/usr/local/nagios/libexec/check_mongrel_cluster.rb',
267
+ :mode => 0755,
268
+ :owner => 'root:root'},
269
+
270
+ {:template => "check_linux_free_memory.pl",
271
+ :path => '/usr/local/nagios/libexec/check_linux_free_memory.pl',
272
+ :mode => 0755,
273
+ :owner => 'root:root'}
274
+
275
+ ]
276
+
277
+ desc "Generate configuration file(s) for nrpe from template(s)"
278
+ task :config_gen do
279
+ SYSTEM_CONFIG_FILES[:nrpe].each do |file|
280
+ deprec2.render_template(:nagios, file)
281
+ end
282
+ end
283
+
284
+ desc "Push nrpe config files to server"
285
+ task :config do
286
+ deprec2.push_configs(:nagios, SYSTEM_CONFIG_FILES[:nrpe])
287
+ # XXX should really only do this on targets
288
+ sudo "/etc/init.d/xinetd stop"
289
+ sudo "/etc/init.d/xinetd start"
290
+ end
291
+
292
+ task :test_local do
293
+ run "/usr/local/nagios/libexec/check_nrpe -H localhost"
294
+ end
295
+
296
+ task :test_remote, :roles => :nagios do
297
+ target_host = Capistrano::CLI.ui.ask "target hostname"
298
+ run "/usr/local/nagios/libexec/check_nrpe -H #{target_host}"
299
+ end
300
+
301
+ end
302
+
303
+
304
+ end
305
+ end
@@ -0,0 +1,81 @@
1
+ # Copyright 2006-2008 by Mike Bailey. All rights reserved.
2
+ Capistrano::Configuration.instance(:must_exist).load do
3
+ namespace :deprec do
4
+ namespace :network do
5
+
6
+ set(:network_number_of_ports) {
7
+ Capistrano::CLI.ui.ask "Number of network ports" do |q|
8
+ q.default = 1
9
+ end
10
+ }
11
+
12
+ set(:network_interfaces) {
13
+ foo = {}
14
+ network_number_of_ports.to_i.times do |port|
15
+ foo[port] = {}
16
+ foo[port][:address] = Capistrano::CLI.ui.ask "address" do |q|
17
+ q.default = "192.168.#{port+1}.10"
18
+ end
19
+ foo[port][:netmask] = Capistrano::CLI.ui.ask "netmask" do |q|
20
+ q.default = '255.255.255.0'
21
+ end
22
+ foo[port][:broadcast] = Capistrano::CLI.ui.ask "broadcast" do |q|
23
+ q.default = "192.168.#{port+1}.255"
24
+ end
25
+
26
+ end
27
+ foo
28
+ }
29
+ set(:network_hostname) {
30
+ Capistrano::CLI.ui.ask "hostname" do |q|
31
+ # q.validate = /add hostname validation here/
32
+ end
33
+ }
34
+ set(:network_gateway) {
35
+ Capistrano::CLI.ui.ask "default gateway" do |q|
36
+ q.default = '192.168.1.1'
37
+ end
38
+ }
39
+ set(:network_dns_nameservers) {
40
+ Capistrano::CLI.ui.ask "dns nameservers (separated by spaces)" do |q|
41
+ q.default = '203.8.183.1 4.2.2.1'
42
+ end
43
+ }
44
+
45
+ SYSTEM_CONFIG_FILES[:network] = [
46
+
47
+ {:template => "interfaces.erb",
48
+ :path => '/etc/network/interfaces',
49
+ :mode => 0644,
50
+ :owner => 'root:root'},
51
+
52
+ {:template => "hosts.erb",
53
+ :path => '/etc/hosts',
54
+ :mode => 0644,
55
+ :owner => 'root:root'},
56
+
57
+ {:template => "hostname.erb",
58
+ :path => '/etc/hostname',
59
+ :mode => 0644,
60
+ :owner => 'root:root'}
61
+
62
+ ]
63
+
64
+ # XXX need to set the order for these as it breaks sudo currently
65
+ desc "Update system networking configuration"
66
+ task :config do
67
+ SYSTEM_CONFIG_FILES[:network].each do |file|
68
+ deprec2.render_template(:network, file.merge(:remote=>true))
69
+ end
70
+ end
71
+
72
+ desc "Restart network interface"
73
+ task :restart do
74
+ sudo '/etc/init.d/networking restart'
75
+ end
76
+
77
+
78
+ end
79
+ end
80
+
81
+ end
@@ -0,0 +1,144 @@
1
+ # Copyright 2006-2008 by Mike Bailey. All rights reserved.
2
+ Capistrano::Configuration.instance(:must_exist).load do
3
+ namespace :deprec do
4
+ namespace :nginx do
5
+
6
+ set :nginx_server_name, nil
7
+ set :nginx_user, 'nginx'
8
+ set :nginx_group, 'nginx'
9
+ set :nginx_vhost_dir, '/usr/local/nginx/conf/vhosts'
10
+ set :nginx_client_max_body_size, '100M'
11
+ set :nginx_worker_processes, 4
12
+
13
+ SRC_PACKAGES[:nginx] = {
14
+ :url => "http://sysoev.ru/nginx/nginx-0.5.34.tar.gz",
15
+ :md5sum => "8f7d3efcd7caaf1f06e4d95dfaeac238 nginx-0.5.34.tar.gz",
16
+ :configure => './configure --sbin-path=/usr/local/sbin --with-http_ssl_module;'
17
+ }
18
+
19
+ desc "Install nginx"
20
+ task :install do
21
+ install_deps
22
+ deprec2.download_src(SRC_PACKAGES[:nginx], src_dir)
23
+ deprec2.install_from_src(SRC_PACKAGES[:nginx], src_dir)
24
+ create_nginx_user
25
+ # install_index_page # XXX not done yet
26
+ SYSTEM_CONFIG_FILES[:nginx].each do |file|
27
+ deprec2.render_template(:nginx, file.merge(:remote => true))
28
+ end
29
+ activate
30
+ end
31
+
32
+ # install dependencies for nginx
33
+ task :install_deps do
34
+ apt.install( {:base => %w(libpcre3 libpcre3-dev libpcrecpp0 libssl-dev zlib1g-dev)}, :stable )
35
+ # do we need libgcrypt11-dev?
36
+ end
37
+
38
+ task :create_nginx_user do
39
+ deprec2.groupadd(nginx_group)
40
+ deprec2.useradd(nginx_user, :group => nginx_group, :homedir => false)
41
+ end
42
+
43
+ task :rename_index_page, :roles => :web do
44
+ index_file = '/usr/local/nginx/html/index.html'
45
+ sudo "test -f #{index_file} && sudo mv #{index_file} #{index_file}.orig || exit 0"
46
+ end
47
+
48
+ SYSTEM_CONFIG_FILES[:nginx] = [
49
+
50
+ {:template => 'nginx-init-script',
51
+ :path => '/etc/init.d/nginx',
52
+ :mode => 0755,
53
+ :owner => 'root:root'},
54
+
55
+ {:template => 'nginx.conf.erb',
56
+ :path => "/usr/local/nginx/conf/nginx.conf",
57
+ :mode => 0644,
58
+ :owner => 'root:root'},
59
+
60
+ {:template => 'mime.types.erb',
61
+ :path => "/usr/local/nginx/conf/mime.types",
62
+ :mode => 0644,
63
+ :owner => 'root:root'},
64
+
65
+ {:template => 'nothing.conf',
66
+ :path => "/usr/local/nginx/conf/vhosts/nothing.conf",
67
+ :mode => 0644,
68
+ :owner => 'root:root'}
69
+ ]
70
+
71
+ desc <<-DESC
72
+ Generate nginx config from template. Note that this does not
73
+ push the config to the server, it merely generates required
74
+ configuration files. These should be kept under source control.
75
+ The can be pushed to the server with the :config task.
76
+ DESC
77
+ task :config_gen do
78
+ SYSTEM_CONFIG_FILES[:nginx].each do |file|
79
+ deprec2.render_template(:nginx, file)
80
+ end
81
+ end
82
+
83
+ desc "Push nginx config files to server"
84
+ task :config, :roles => :web do
85
+ deprec2.push_configs(:nginx, SYSTEM_CONFIG_FILES[:nginx])
86
+ end
87
+
88
+ desc <<-DESC
89
+ Activate nginx start scripts on server.
90
+ Setup server to start nginx on boot.
91
+ DESC
92
+ task :activate do
93
+ activate_system
94
+ end
95
+
96
+ task :activate_system do
97
+ send(run_method, "update-rc.d nginx defaults")
98
+ end
99
+
100
+ desc <<-DESC
101
+ Dectivate nginx start scripts on server.
102
+ Setup server to start nginx on boot.
103
+ DESC
104
+ task :deactivate do
105
+ send(run_method, "update-rc.d -f nginx remove")
106
+ end
107
+
108
+
109
+ # Control
110
+
111
+ desc "Start Nginx"
112
+ task :start, :roles => :web do
113
+ send(run_method, "/etc/init.d/nginx start")
114
+ end
115
+
116
+ desc "Stop Nginx"
117
+ task :stop, :roles => :web do
118
+ send(run_method, "/etc/init.d/nginx stop")
119
+ end
120
+
121
+ desc "Restart Nginx"
122
+ task :restart, :roles => :web do
123
+ # So that restart will work even if nginx is not running
124
+ # we call stop and ignore the return code. We then start it.
125
+ send(run_method, "/etc/init.d/nginx stop; exit 0")
126
+ send(run_method, "/etc/init.d/nginx start")
127
+ end
128
+
129
+ desc "Reload Nginx"
130
+ task :reload, :roles => :web do
131
+ send(run_method, "/etc/init.d/nginx reload")
132
+ end
133
+
134
+ task :backup, :roles => :web do
135
+ # there's nothing to backup for nginx
136
+ end
137
+
138
+ task :restore, :roles => :web do
139
+ # there's nothing to store for nginx
140
+ end
141
+
142
+ end
143
+ end
144
+ end