isaac-deprec 1.99.30

Sign up to get free protection for your applications and to get access to all the features.
Files changed (152) hide show
  1. data/CHANGELOG +226 -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/offline_installation.txt +16 -0
  17. data/docs/windows_linux.txt +350 -0
  18. data/docs/xen/plan.txt +5 -0
  19. data/docs/xen/traffic_monitoring_with_vnstat.txt +95 -0
  20. data/docs/xen/xen-tools-notes.txt +31 -0
  21. data/docs/xen/xen_on_hardy.txt +39 -0
  22. data/lib/deprec/capistrano_extensions.rb +435 -0
  23. data/lib/deprec/recipes/aoe.rb +79 -0
  24. data/lib/deprec/recipes/apache.rb +179 -0
  25. data/lib/deprec/recipes/apt_mirror.rb +99 -0
  26. data/lib/deprec/recipes/ar_sendmail.rb +67 -0
  27. data/lib/deprec/recipes/canonical.rb +57 -0
  28. data/lib/deprec/recipes/deprec.rb +188 -0
  29. data/lib/deprec/recipes/deprecated.rb +71 -0
  30. data/lib/deprec/recipes/example.rb +115 -0
  31. data/lib/deprec/recipes/git.rb +97 -0
  32. data/lib/deprec/recipes/gitosis.rb +48 -0
  33. data/lib/deprec/recipes/heartbeat.rb +138 -0
  34. data/lib/deprec/recipes/logrotate.rb +54 -0
  35. data/lib/deprec/recipes/lvm.rb +20 -0
  36. data/lib/deprec/recipes/memcache.rb +49 -0
  37. data/lib/deprec/recipes/mongrel.rb +219 -0
  38. data/lib/deprec/recipes/monit.rb +135 -0
  39. data/lib/deprec/recipes/mysql.rb +115 -0
  40. data/lib/deprec/recipes/nagios.rb +305 -0
  41. data/lib/deprec/recipes/network.rb +93 -0
  42. data/lib/deprec/recipes/nginx.rb +144 -0
  43. data/lib/deprec/recipes/ntp.rb +103 -0
  44. data/lib/deprec/recipes/passenger.rb +114 -0
  45. data/lib/deprec/recipes/php.rb +91 -0
  46. data/lib/deprec/recipes/postfix.rb +115 -0
  47. data/lib/deprec/recipes/rails.rb +282 -0
  48. data/lib/deprec/recipes/ree.rb +33 -0
  49. data/lib/deprec/recipes/ruby.rb +65 -0
  50. data/lib/deprec/recipes/sphinx.rb +86 -0
  51. data/lib/deprec/recipes/ssh.rb +93 -0
  52. data/lib/deprec/recipes/svn.rb +171 -0
  53. data/lib/deprec/recipes/trac.rb +277 -0
  54. data/lib/deprec/recipes/ubuntu.rb +20 -0
  55. data/lib/deprec/recipes/users.rb +90 -0
  56. data/lib/deprec/recipes/utils.rb +39 -0
  57. data/lib/deprec/recipes/vnstat.rb +85 -0
  58. data/lib/deprec/recipes/wordpress.rb +99 -0
  59. data/lib/deprec/recipes/xen.rb +269 -0
  60. data/lib/deprec/recipes.rb +40 -0
  61. data/lib/deprec/templates/aoe/aoe-init +55 -0
  62. data/lib/deprec/templates/aoe/fence_aoemask +351 -0
  63. data/lib/deprec/templates/apache/httpd-vhost-app.conf.erb +144 -0
  64. data/lib/deprec/templates/apache/httpd.conf +465 -0
  65. data/lib/deprec/templates/apache/index.html.erb +37 -0
  66. data/lib/deprec/templates/apache/master.css +72 -0
  67. data/lib/deprec/templates/apt/sources.list +18 -0
  68. data/lib/deprec/templates/apt_mirror/apt-mirror-cron +4 -0
  69. data/lib/deprec/templates/apt_mirror/mirror.list +33 -0
  70. data/lib/deprec/templates/ar_sendmail/logrotate.conf.erb +9 -0
  71. data/lib/deprec/templates/ar_sendmail/monit.conf.erb +5 -0
  72. data/lib/deprec/templates/deprec/caprc.erb +14 -0
  73. data/lib/deprec/templates/heartbeat/authkeys.erb +2 -0
  74. data/lib/deprec/templates/heartbeat/ha.cf.erb +15 -0
  75. data/lib/deprec/templates/heartbeat/haresources.erb +1 -0
  76. data/lib/deprec/templates/logrotate/logrotate.conf.erb +32 -0
  77. data/lib/deprec/templates/mongrel/logrotate.conf.erb +11 -0
  78. data/lib/deprec/templates/mongrel/mongrel_cluster-init-script +54 -0
  79. data/lib/deprec/templates/mongrel/mongrel_cluster.yml.erb +10 -0
  80. data/lib/deprec/templates/mongrel/monit.conf.erb +17 -0
  81. data/lib/deprec/templates/monit/monit-init-script +104 -0
  82. data/lib/deprec/templates/monit/monitrc.erb +227 -0
  83. data/lib/deprec/templates/monit/nothing +0 -0
  84. data/lib/deprec/templates/mysql/create_databases.sql +20 -0
  85. data/lib/deprec/templates/mysql/database.yml.prod +6 -0
  86. data/lib/deprec/templates/mysql/database.yml.stage +6 -0
  87. data/lib/deprec/templates/mysql/my.cnf.erb +140 -0
  88. data/lib/deprec/templates/mysql/sphinx.conf.prod +542 -0
  89. data/lib/deprec/templates/mysql/sphinx.conf.stage +542 -0
  90. data/lib/deprec/templates/nagios/cgi.cfg.erb +321 -0
  91. data/lib/deprec/templates/nagios/check_linux_free_memory.pl +118 -0
  92. data/lib/deprec/templates/nagios/check_mongrel_cluster.rb +82 -0
  93. data/lib/deprec/templates/nagios/commands.cfg.erb +240 -0
  94. data/lib/deprec/templates/nagios/contacts.cfg.erb +57 -0
  95. data/lib/deprec/templates/nagios/hosts.cfg.erb +143 -0
  96. data/lib/deprec/templates/nagios/htpasswd.users +1 -0
  97. data/lib/deprec/templates/nagios/localhost.cfg.erb +157 -0
  98. data/lib/deprec/templates/nagios/nagios.cfg.erb +1274 -0
  99. data/lib/deprec/templates/nagios/nagios_apache_vhost.conf.erb +45 -0
  100. data/lib/deprec/templates/nagios/nrpe.cfg.erb +210 -0
  101. data/lib/deprec/templates/nagios/nrpe.xinetd.erb +16 -0
  102. data/lib/deprec/templates/nagios/resource.cfg.erb +34 -0
  103. data/lib/deprec/templates/nagios/services.cfg.erb +79 -0
  104. data/lib/deprec/templates/nagios/templates.cfg.erb +9 -0
  105. data/lib/deprec/templates/nagios/timeperiods.cfg.erb +94 -0
  106. data/lib/deprec/templates/network/hostname.erb +1 -0
  107. data/lib/deprec/templates/network/hosts.erb +2 -0
  108. data/lib/deprec/templates/network/interfaces.erb +18 -0
  109. data/lib/deprec/templates/network/resolv.conf.erb +6 -0
  110. data/lib/deprec/templates/nginx/logrotate.conf.erb +13 -0
  111. data/lib/deprec/templates/nginx/mime.types.erb +70 -0
  112. data/lib/deprec/templates/nginx/nginx-init-script +62 -0
  113. data/lib/deprec/templates/nginx/nginx.conf.erb +125 -0
  114. data/lib/deprec/templates/nginx/nginx.logrotate.d +12 -0
  115. data/lib/deprec/templates/nginx/nothing.conf +1 -0
  116. data/lib/deprec/templates/nginx/rails_nginx_vhost.conf.erb +41 -0
  117. data/lib/deprec/templates/ntp/ntp.conf.erb +42 -0
  118. data/lib/deprec/templates/passenger/apache_vhost.erb +10 -0
  119. data/lib/deprec/templates/passenger/passenger.erb +20 -0
  120. data/lib/deprec/templates/postfix/aliases.erb +3 -0
  121. data/lib/deprec/templates/postfix/dynamicmaps.cf.erb +8 -0
  122. data/lib/deprec/templates/postfix/main.cf.erb +36 -0
  123. data/lib/deprec/templates/postfix/master.cf.erb +77 -0
  124. data/lib/deprec/templates/sphinx/monit.conf.erb +5 -0
  125. data/lib/deprec/templates/ssh/ssh_config.erb +50 -0
  126. data/lib/deprec/templates/ssh/sshd_config.erb +78 -0
  127. data/lib/deprec/templates/subversion/svn.apache.vhost.erb +43 -0
  128. data/lib/deprec/templates/trac/apache_vhost.conf.erb +24 -0
  129. data/lib/deprec/templates/trac/nginx_vhost.conf.erb +26 -0
  130. data/lib/deprec/templates/trac/trac.ini.erb +169 -0
  131. data/lib/deprec/templates/trac/trac_deprec.png +0 -0
  132. data/lib/deprec/templates/trac/tracd-init.erb +43 -0
  133. data/lib/deprec/templates/trac/users.htdigest.erb +0 -0
  134. data/lib/deprec/templates/vnstat/config.php +57 -0
  135. data/lib/deprec/templates/wordpress/apache2_wordpress_vhost.conf.erb +31 -0
  136. data/lib/deprec/templates/wordpress/wp-config.php.erb +31 -0
  137. data/lib/deprec/templates/xen/15-disable-hwclock +40 -0
  138. data/lib/deprec/templates/xen/40-setup-networking +145 -0
  139. data/lib/deprec/templates/xen/network-bridge-wrapper +3 -0
  140. data/lib/deprec/templates/xen/xen-tools.conf.erb +220 -0
  141. data/lib/deprec/templates/xen/xend-config.sxp.erb +195 -0
  142. data/lib/deprec/templates/xen/xend-init.erb +57 -0
  143. data/lib/deprec/templates/xen/xendomains.erb +137 -0
  144. data/lib/deprec/templates/xen/xm.tmpl.erb +85 -0
  145. data/lib/deprec.rb +8 -0
  146. data/lib/deprec_cmd_completion.sh +26 -0
  147. data/lib/vmbuilder_plugins/all.rb +20 -0
  148. data/lib/vmbuilder_plugins/apt.rb +93 -0
  149. data/lib/vmbuilder_plugins/emerge.rb +76 -0
  150. data/lib/vmbuilder_plugins/gem.rb +90 -0
  151. data/lib/vmbuilder_plugins/std.rb +203 -0
  152. metadata +241 -0
@@ -0,0 +1,48 @@
1
+ # Copyright 2006-2008 by Mike Bailey. All rights reserved.
2
+ Capistrano::Configuration.instance(:must_exist).load do
3
+ namespace :deprec do
4
+ namespace :gitosis do
5
+
6
+ # ref: http://scie.nti.st/2007/11/14/hosting-git-repositories-the-easy-and-secure-way
7
+
8
+ set :gitosis_user, 'git'
9
+
10
+ desc "Install git"
11
+ task :install do
12
+ deprec2.create_src_dir
13
+ install_deps
14
+ run <<-SUDO
15
+ cd #{src_dir} && test -d gitosis || #{sudo} git clone git://eagain.net/gitosis.git; exit 0
16
+ SUDO
17
+ run "cd #{src_dir}/gitosis && #{sudo} python setup.py install"
18
+ create_user
19
+ init
20
+ end
21
+
22
+ # install dependencies for nginx
23
+ task :install_deps do
24
+ apt.install( {:base => %w(python-setuptools)}, :stable )
25
+ end
26
+
27
+ # Create user for gitosis to run as
28
+ # This will also be the account you use for ssh access to git
29
+ task :create_user do
30
+ run "grep '^#{gitosis_user}:' /etc/passwd || #{sudo} adduser --system --shell /bin/sh --gecos 'git version control' --group --disabled-password --home /home/#{gitosis_user} #{gitosis_user}"
31
+ sudo "passwd --unlock #{gitosis_user}"
32
+ end
33
+
34
+ task :init do
35
+ sudo "sudo -H -u #{git_user} gitosis-init < ~/.ssh/authorized_keys"
36
+ sudo "chmod 0755 /home/git/repositories/gitosis-admin.git/hooks/post-update"
37
+ puts
38
+ puts "Now check out the gitosis-admin repos, edit configs and push changes back"
39
+ puts "Your changes with update gitosis as soon as they are checked in."
40
+ puts
41
+ puts "git clone git@YOUR_SERVER_HOSTNAME:gitosis-admin.git"
42
+ puts "cd gitosis-admin"
43
+ puts ""
44
+ end
45
+
46
+ end
47
+ end
48
+ end
@@ -0,0 +1,138 @@
1
+ # Copyright 2006-2008 by Mike Bailey. All rights reserved.
2
+ Capistrano::Configuration.instance(:must_exist).load do
3
+ namespace :deprec do
4
+ namespace :heartbeat do
5
+ set(:heartbeat_nodes) { find_servers_for_task(current_task) }
6
+ set(:heartbeat_preferred_node) {
7
+ Capistrano::CLI.ui.choose do |menu|
8
+ heartbeat_nodes.each {|c| menu.choice(c)}
9
+ menu.header = "select preferred node"
10
+ end
11
+ }
12
+ set(:heartbeat_resources) {Capistrano::CLI.ui.ask 'Enter resource to share. e.g. an ip address'}
13
+ set(:heartbeat_auth_key) { Capistrano::CLI.ui.ask 'Enter auth key for heartbeat to use' }
14
+ set(:heartbeat_ping) { Capistrano::CLI.ui.ask 'Enter IP address nodes will ping to test connectivity. e.g. gateway address' }
15
+ set(:heartbeat_bcast) {
16
+ Capistrano::CLI.ui.ask 'Enter ethernet interface(s) Heartbeat sends UDP broadcast traffic on. e.g. eth0' do |q|
17
+ q.default = 'eth0'
18
+ end
19
+ }
20
+ set(:heartbeat_auto_failback) {
21
+ Capistrano::CLI.ui.ask 'Should resource(s) automatically fail back to its "primary" node ' do |q|
22
+ q.default = 'yes'
23
+ end
24
+ }
25
+
26
+ desc "Install Heartbeat"
27
+ task :install do
28
+ install_deps
29
+ end
30
+
31
+ # Install dependencies for heartbeat
32
+ task :install_deps do
33
+ apt.install( {:base => %w(heartbeat-2)}, :stable )
34
+ end
35
+
36
+ SYSTEM_CONFIG_FILES[:heartbeat] = [
37
+
38
+ {:template => 'ha.cf.erb',
39
+ :path => '/etc/ha.d/ha.cf',
40
+ :mode => 0644,
41
+ :owner => 'root:root'},
42
+
43
+ {:template => 'haresources.erb',
44
+ :path => '/etc/ha.d/haresources',
45
+ :mode => 0644,
46
+ :owner => 'root:root'},
47
+
48
+ {:template => 'authkeys.erb',
49
+ :path => '/etc/ha.d/authkeys',
50
+ :mode => 0600,
51
+ :owner => 'root:root'}
52
+
53
+ ]
54
+
55
+ desc "Generate configuration file(s) for heartbeat from template(s)"
56
+ task :config_gen do
57
+ if ENV['ROLES']
58
+ SYSTEM_CONFIG_FILES[:heartbeat].each do |file|
59
+ file.merge!({:path => "#{file[:path]}-#{ENV['ROLES']}"})
60
+ deprec2.render_template(:heartbeat, file)
61
+ end
62
+ else
63
+ puts
64
+ puts "Whoops!"
65
+ puts
66
+ puts "You need to specify the cluster to work on by defining ROLES env variable."
67
+ puts "e.g. cap deprec:heartbeat:config ROLES=cluster_web"
68
+ puts
69
+ end
70
+ end
71
+
72
+ desc "Push heartbeat config files to server"
73
+ task :config do
74
+ if ENV['ROLES']
75
+ config_files = SYSTEM_CONFIG_FILES[:heartbeat].collect{|file| file.merge({:path => "#{file[:path]}-#{ENV['ROLES']}"})}
76
+ deprec2.push_configs(:heartbeat, config_files)
77
+ SYSTEM_CONFIG_FILES[:heartbeat].each {|file|
78
+ sudo "mv #{file[:path]}-#{ENV['ROLES']} #{file[:path]}"
79
+ }
80
+ # puts config_files
81
+ else
82
+ puts
83
+ puts "Whoops!"
84
+ puts
85
+ puts "You need to specify the cluster to work on by defining ROLES env variable."
86
+ puts "e.g. cap deprec:heartbeat:config ROLES=cluster_web"
87
+ puts
88
+ end
89
+ end
90
+
91
+ desc "Set Heartbeat to start on boot"
92
+ task :activate, :roles => :heartbeat do
93
+ send(run_method, "update-rc.d heartbeat defaults")
94
+ end
95
+
96
+ desc "Set Heartbeat to not start on boot"
97
+ task :deactivate, :roles => :heartbeat do
98
+ send(run_method, "update-rc.d -f heartbeat remove")
99
+ end
100
+
101
+
102
+ # Control
103
+
104
+ # XXX perhaps define a cluster to work with
105
+ # XXX e.g. set :cluster, 'rolename'
106
+ # XXX and then target that rolename with these tasks
107
+
108
+ desc "Start Heartbeat"
109
+ task :start, :roles => :heartbeat do
110
+ send(run_method, "/etc/init.d/heartbeat start")
111
+ end
112
+
113
+ desc "Stop Heartbeat"
114
+ task :stop, :roles => :heartbeat do
115
+ send(run_method, "/etc/init.d/heartbeat stop")
116
+ end
117
+
118
+ desc "Restart Heartbeat"
119
+ task :restart, :roles => :heartbeat do
120
+ send(run_method, "/etc/init.d/heartbeat restart")
121
+ end
122
+
123
+ desc "Reload Heartbeat"
124
+ task :reload, :roles => :heartbeat do
125
+ send(run_method, "/etc/init.d/heartbeat reload")
126
+ end
127
+
128
+ task :backup, :roles => :web do
129
+ # not yet implemented
130
+ end
131
+
132
+ task :restore, :roles => :web do
133
+ # not yet implemented
134
+ end
135
+
136
+ end
137
+ end
138
+ end
@@ -0,0 +1,54 @@
1
+ # Copyright 2006-2008 by Mike Bailey. All rights reserved.
2
+ Capistrano::Configuration.instance(:must_exist).load do
3
+ namespace :deprec do
4
+ namespace :logrotate do
5
+
6
+ # Install
7
+
8
+ desc "Install logrotate"
9
+ task :install do
10
+ install_deps
11
+ SYSTEM_CONFIG_FILES[:logrotate].each do |file|
12
+ deprec2.render_template(:logrotate, file.merge(:remote => true))
13
+ end
14
+ end
15
+
16
+ # install dependencies for nginx
17
+ task :install_deps do
18
+ apt.install( {:base => %w(logrotate)}, :stable )
19
+ end
20
+
21
+ # Configure
22
+
23
+ SYSTEM_CONFIG_FILES[:logrotate] = [
24
+
25
+ {:template => 'logrotate.conf.erb',
26
+ :path => '/etc/logrotate.conf',
27
+ :mode => 0755,
28
+ :owner => 'root:root'}
29
+ ]
30
+
31
+ desc "Generate logrotate config from template."
32
+ task :config_gen do
33
+ SYSTEM_CONFIG_FILES[:logrotate].each do |file|
34
+ deprec2.render_template(:logrotate, file)
35
+ end
36
+ end
37
+
38
+ desc "Push logrotate config files to server"
39
+ task :config do
40
+ deprec2.push_configs(:logrotate, SYSTEM_CONFIG_FILES[:logrotate])
41
+ end
42
+
43
+ # Control
44
+ #
45
+ # logrotate is run via cron with a script in /etc/cron.daily/logrotate
46
+
47
+ desc "Force logrotate to run"
48
+ task :force do
49
+ sudo "logrotate -f /etc/logrotate.conf"
50
+ end
51
+
52
+ end
53
+ end
54
+ end
@@ -0,0 +1,20 @@
1
+ # Copyright 2006-2008 by Mike Bailey. All rights reserved.
2
+ Capistrano::Configuration.instance(:must_exist).load do
3
+ namespace :deprec do
4
+ namespace :lvm do
5
+
6
+ task :pvdisplay do
7
+ sudo "pvdisplay"
8
+ end
9
+
10
+ task :vgdisplay do
11
+ sudo "vgdisplay"
12
+ end
13
+
14
+ task :lvdisplay do
15
+ sudo "lvdisplay"
16
+ end
17
+
18
+ end
19
+ end
20
+ end
@@ -0,0 +1,49 @@
1
+ # Copyright 2006-2008 by Mike Bailey. All rights reserved.
2
+ Capistrano::Configuration.instance(:must_exist).load do
3
+ namespace :deprec do
4
+ namespace :memcache do
5
+
6
+ set :memcache_ip, '127.0.0.1'
7
+ set :memcache_port, 11211
8
+ set :memcache_memory, 256
9
+
10
+ # XXX needs thought/work
11
+ task :memcached_start do
12
+ run "memcached -d -m #{memcache_memory} -l #{memcache_ip} -p #{memcache_port}"
13
+ end
14
+
15
+ # XXX needs thought/work
16
+ task :memcached_stop do
17
+ run "killall memcached"
18
+ end
19
+
20
+ # XXX needs thought/work
21
+ task :memcached_restart do
22
+ memcached_stop
23
+ memcached_start
24
+ end
25
+
26
+ task :install_memcached do
27
+ version = 'memcached-1.2.2'
28
+ set :src_package, {
29
+ :file => version + '.tar.gz',
30
+ :md5sum => 'a08851f7fa7b15e92ee6320b7a79c321 memcached-1.2.2.tar.gz',
31
+ :dir => version,
32
+ :url => "http://www.danga.com/memcached/dist/#{version}.tar.gz",
33
+ :unpack => "tar zxf #{version}.tar.gz;",
34
+ :configure => %w{
35
+ ./configure
36
+ --prefix=/usr/local
37
+ ;
38
+ }.reject{|arg| arg.match '#'}.join(' '),
39
+ :make => 'make;',
40
+ :install => 'make install;',
41
+ :post_install => 'install -b scripts/memcached-init /etc/init.d/memcached;'
42
+ }
43
+ apt.install( {:base => %w(libevent-dev)}, :stable )
44
+ deprec.download_src(src_package, src_dir)
45
+ deprec.install_from_src(src_package, src_dir)
46
+ end
47
+ end end
48
+
49
+ end
@@ -0,0 +1,219 @@
1
+ # Copyright 2006-2008 by Mike Bailey. All rights reserved.
2
+ Capistrano::Configuration.instance(:must_exist).load do
3
+
4
+ namespace :deprec do
5
+ namespace :mongrel do
6
+
7
+ set :mongrel_servers, 2
8
+ set :mongrel_port, 8000
9
+ set :mongrel_address, "127.0.0.1"
10
+ set(:mongrel_environment) { rails_env }
11
+ set(:mongrel_log_dir) { "#{deploy_to}/shared/log" }
12
+ set(:mongrel_pid_dir) { "#{deploy_to}/shared/pids" }
13
+ set :mongrel_conf_dir, '/etc/mongrel_cluster'
14
+ set(:mongrel_conf) { "/etc/mongrel_cluster/#{application}.yml" }
15
+ set :mongrel_user_prefix, 'mongrel_'
16
+ set(:mongrel_user) { mongrel_user_prefix + application }
17
+ set :mongrel_group_prefix, 'app_'
18
+ set(:mongrel_group) { mongrel_group_prefix + application }
19
+
20
+
21
+ # Install
22
+
23
+ desc "Install mongrel"
24
+ task :install, :roles => :app do
25
+ gem2.install 'mongrel'
26
+ gem2.install 'mongrel_cluster'
27
+ gem2.install 'swiftiply'
28
+ symlink_mongrel_rails
29
+ SYSTEM_CONFIG_FILES[:mongrel].each do |file|
30
+ deprec2.render_template(:mongrel, file.merge(:remote=>true))
31
+ end
32
+ activate_system
33
+ end
34
+
35
+ task :symlink_mongrel_rails, :roles => :app do
36
+ sudo "ln -sf /usr/local/bin/mongrel_rails /usr/bin/mongrel_rails"
37
+ end
38
+
39
+ task :symlink_logrotate_config, :roles => :app do
40
+ sudo "ln -sf #{deploy_to}/mongrel/logrotate.conf /etc/logrotate.d/mongrel-#{application}"
41
+ end
42
+
43
+ # Configure
44
+
45
+ SYSTEM_CONFIG_FILES[:mongrel] = [
46
+
47
+ {:template => 'mongrel_cluster-init-script',
48
+ :path => '/etc/init.d/mongrel_cluster',
49
+ :mode => 0755,
50
+ :owner => 'root:root'}
51
+
52
+ ]
53
+
54
+ PROJECT_CONFIG_FILES[:mongrel] = [
55
+
56
+ {:template => 'mongrel_cluster.yml.erb',
57
+ :path => 'cluster.yml',
58
+ :mode => 0644,
59
+ :owner => 'root:root'},
60
+
61
+ {:template => 'monit.conf.erb',
62
+ :path => "monit.conf",
63
+ :mode => 0600,
64
+ :owner => 'root:root'},
65
+
66
+ {:template => 'logrotate.conf.erb',
67
+ :path => "logrotate.conf",
68
+ :mode => 0644,
69
+ :owner => 'root:root'}
70
+
71
+ ]
72
+
73
+ desc "Generate configuration file(s) for mongrel from template(s)"
74
+ task :config_gen do
75
+ config_gen_system
76
+ config_gen_project
77
+ end
78
+
79
+ task :config_gen_system do
80
+ SYSTEM_CONFIG_FILES[:mongrel].each do |file|
81
+ deprec2.render_template(:mongrel, file)
82
+ end
83
+ end
84
+
85
+ task :config_gen_project do
86
+ PROJECT_CONFIG_FILES[:mongrel].each do |file|
87
+ deprec2.render_template(:mongrel, file)
88
+ end
89
+ end
90
+
91
+ desc 'Deploy configuration files(s) for mongrel'
92
+ task :config, :roles => :app do
93
+ config_system
94
+ config_project
95
+ end
96
+
97
+ task :config_system, :roles => :app do
98
+ deprec2.push_configs(:mongrel, SYSTEM_CONFIG_FILES[:mongrel])
99
+ end
100
+
101
+ task :config_project, :roles => :app do
102
+ create_mongrel_user_and_group
103
+ deprec2.push_configs(:mongrel, PROJECT_CONFIG_FILES[:mongrel])
104
+ symlink_mongrel_cluster
105
+ symlink_monit_config
106
+ symlink_logrotate_config
107
+ end
108
+
109
+ task :symlink_monit_config, :roles => :app do
110
+ deprec2.mkdir(monit_confd_dir, :via => :sudo)
111
+ sudo "ln -sf #{deploy_to}/mongrel/monit.conf #{monit_confd_dir}/mongrel_#{application}.conf"
112
+ end
113
+
114
+ task :unlink_monit_config, :roles => :app do
115
+ sudo "test -L #{monit_confd_dir}/mongrel_#{application}.conf && unlink #{monit_confd_dir}/mongrel_#{application}.conf"
116
+ end
117
+
118
+ task :symlink_mongrel_cluster, :roles => :app do
119
+ deprec2.mkdir(mongrel_conf_dir, :via => :sudo)
120
+ sudo "ln -sf #{deploy_to}/mongrel/cluster.yml #{mongrel_conf}"
121
+ end
122
+
123
+ task :unlink_mongrel_cluster, :roles => :app do
124
+ sudo "test -L #{mongrel_conf} && unlink #{mongrel_conf}"
125
+ end
126
+
127
+
128
+ # Control
129
+
130
+ desc "Start application server."
131
+ task :start, :roles => :app do
132
+ send(run_method, "mongrel_rails cluster::start --clean -C #{mongrel_conf}")
133
+ end
134
+
135
+ desc "Stop application server."
136
+ task :stop, :roles => :app do
137
+ send(run_method, "mongrel_rails cluster::stop -C #{mongrel_conf}")
138
+ end
139
+
140
+ desc "Restart application server."
141
+ task :restart, :roles => :app do
142
+ send(run_method, "mongrel_rails cluster::restart --clean -C #{mongrel_conf}")
143
+ end
144
+
145
+ task :activate do
146
+ activate_system
147
+ activate_project
148
+ end
149
+
150
+ task :activate_system do
151
+ send(run_method, "update-rc.d mongrel_cluster defaults")
152
+ end
153
+
154
+ task :activate_project do
155
+ symlink_mongrel_cluster
156
+ symlink_monit_config
157
+ end
158
+
159
+ task :deactivate, :roles => :app do
160
+ puts
161
+ puts "******************************************************************"
162
+ puts
163
+ puts "Danger!"
164
+ puts
165
+ puts "Do you want to deactivate just this project or all mongrel"
166
+ puts "clusters on this server? Try a more granular command:"
167
+ puts
168
+ puts "cap deprec:mongrel:deactivate_system # disable all clusters"
169
+ puts "cap deprec:mongrel:deactivate_project # disable only this project"
170
+ puts
171
+ puts "******************************************************************"
172
+ puts
173
+ end
174
+
175
+ task :deactivate_system, :roles => :app do
176
+ send(run_method, "update-rc.d -f mongrel_cluster remove")
177
+ end
178
+
179
+ task :deactivate_project, :roles => :app do
180
+ unlink_mongrel_cluster
181
+ unlink_monit_config
182
+ restart
183
+ end
184
+
185
+ task :backup, :roles => :app do
186
+ end
187
+
188
+ task :restore, :roles => :app do
189
+ end
190
+
191
+ desc "create user and group for mongel to run as"
192
+ task :create_mongrel_user_and_group, :roles => :app do
193
+ deprec2.groupadd(mongrel_group)
194
+ deprec2.useradd(mongrel_user, :group => mongrel_group, :homedir => false)
195
+ # Set the primary group for the mongrel user (in case user already existed
196
+ # when previous command was run)
197
+ sudo "usermod --gid #{mongrel_group} #{mongrel_user}"
198
+ end
199
+
200
+ desc "set group ownership and permissions on dirs mongrel needs to write to"
201
+ task :set_perms_for_mongrel_dirs, :roles => :app do
202
+ tmp_dir = "#{deploy_to}/current/tmp"
203
+ shared_dir = "#{deploy_to}/shared"
204
+ files = ["#{mongrel_log_dir}/mongrel.log", "#{mongrel_log_dir}/#{rails_env}.log"]
205
+
206
+ sudo "chgrp -R #{mongrel_group} #{tmp_dir} #{shared_dir}"
207
+ sudo "chmod -R g+w #{tmp_dir} #{shared_dir}"
208
+ # set owner and group of log files
209
+ files.each { |file|
210
+ sudo "touch #{file}"
211
+ sudo "chown #{mongrel_user} #{file}"
212
+ sudo "chgrp #{mongrel_group} #{file}"
213
+ sudo "chmod g+w #{file}"
214
+ }
215
+ end
216
+
217
+ end
218
+ end
219
+ end
@@ -0,0 +1,135 @@
1
+ # Copyright 2006-2008 by Mike Bailey. All rights reserved.
2
+ Capistrano::Configuration.instance(:must_exist).load do
3
+ namespace :deprec do namespace :monit do
4
+
5
+ set :monit_user, 'monit'
6
+ set :monit_group, 'monit'
7
+ set :monit_confd_dir, '/etc/monit.d'
8
+
9
+ set :monit_check_interval, 60
10
+ set :monit_log, 'syslog facility log_daemon'
11
+ set :monit_mailserver, nil
12
+ set :monit_mail_from, 'monit@deprec.enabled.slice'
13
+ set :monit_alert_recipients, %w(root@localhost)
14
+ set :monit_timeout_recipients, %w(root@localhost)
15
+ set :monit_webserver_enabled, true
16
+ set :monit_webserver_port, 2812
17
+ set :monit_webserver_address, 'localhost'
18
+ set :monit_webserver_allowed_hosts_and_networks, %w(localhost)
19
+ set :monit_webserver_auth_user, 'admin'
20
+ set :monit_webserver_auth_pass, 'monit'
21
+
22
+ # Upstream changes: http://www.tildeslash.com/monit/dist/CHANGES.txt
23
+ # Ubuntu package version = monit-4.8.1
24
+ SRC_PACKAGES[:monit] = {
25
+ :filename => 'monit-4.10.1.tar.gz',
26
+ :md5sum => "d3143b0bbd79b53f1b019d2fc1dae656 monit-4.10.1.tar.gz",
27
+ :dir => 'monit-4.10.1',
28
+ :url => "http://www.tildeslash.com/monit/dist/monit-4.10.1.tar.gz",
29
+ :unpack => "tar zxf monit-4.10.1.tar.gz;",
30
+ :configure => %w(
31
+ ./configure
32
+ ;
33
+ ).reject{|arg| arg.match '#'}.join(' '),
34
+ :make => 'make;',
35
+ :install => 'make install;'
36
+ }
37
+
38
+ desc "Install monit"
39
+ task :install do
40
+ install_deps
41
+ deprec2.download_src(SRC_PACKAGES[:monit], src_dir)
42
+ deprec2.install_from_src(SRC_PACKAGES[:monit], src_dir)
43
+ # Initial push of system files - not kept locally
44
+ SYSTEM_CONFIG_FILES[:monit].each do |file|
45
+ deprec2.render_template(:monit, file.merge(:remote=>true))
46
+ end
47
+ activate
48
+ end
49
+
50
+ # install dependencies for monit
51
+ task :install_deps do
52
+ apt.install( {:base => %w(flex bison libssl-dev)}, :stable )
53
+ end
54
+
55
+ SYSTEM_CONFIG_FILES[:monit] = [
56
+
57
+ {:template => 'monit-init-script',
58
+ :path => '/etc/init.d/monit',
59
+ :mode => 0755,
60
+ :owner => 'root:root'},
61
+
62
+ {:template => 'monitrc.erb',
63
+ :path => "/etc/monitrc",
64
+ :mode => 0700,
65
+ :owner => 'root:root'},
66
+
67
+ {:template => 'nothing',
68
+ :path => "/etc/monit.d/nothing",
69
+ :mode => 0700,
70
+ :owner => 'root:root'}
71
+ ]
72
+
73
+ desc <<-DESC
74
+ Generate nginx config from template. Note that this does not
75
+ push the config to the server, it merely generates required
76
+ configuration files. These should be kept under source control.
77
+ The can be pushed to the server with the :config task.
78
+ DESC
79
+ task :config_gen do
80
+ SYSTEM_CONFIG_FILES[:monit].each do |file|
81
+ deprec2.render_template(:monit, file)
82
+ end
83
+ end
84
+
85
+ desc "Push monit config files to server"
86
+ task :config do
87
+ deprec2.push_configs(:monit, SYSTEM_CONFIG_FILES[:monit])
88
+ end
89
+
90
+ desc "Start Monit"
91
+ task :start, :roles => :app do
92
+ send(run_method, "/etc/init.d/monit start")
93
+ end
94
+
95
+ desc "Stop Monit"
96
+ task :stop, :roles => :app do
97
+ send(run_method, "/etc/init.d/monit stop")
98
+ end
99
+
100
+ desc "Restart Monit"
101
+ task :restart, :roles => :app do
102
+ send(run_method, "/etc/init.d/monit restart")
103
+ end
104
+
105
+ desc "Reload Monit"
106
+ task :reload, :roles => :app do
107
+ send(run_method, "/etc/init.d/monit reload")
108
+ end
109
+
110
+ desc <<-DESC
111
+ Activate monit start scripts on server.
112
+ Setup server to start monit on boot.
113
+ DESC
114
+ task :activate do
115
+ send(run_method, "update-rc.d monit defaults")
116
+ end
117
+
118
+ desc <<-DESC
119
+ Dectivate monit start scripts on server.
120
+ Setup server to start monit on boot.
121
+ DESC
122
+ task :deactivate do
123
+ send(run_method, "update-rc.d -f monit remove")
124
+ end
125
+
126
+ task :backup do
127
+ # there's nothing to backup for monit
128
+ end
129
+
130
+ task :restore do
131
+ # there's nothing to restore for monit
132
+ end
133
+
134
+ end end
135
+ end