isaac-deprec 1.99.30
Sign up to get free protection for your applications and to get access to all the features.
- data/CHANGELOG +226 -0
- data/COPYING +19 -0
- data/LICENSE +339 -0
- data/README +138 -0
- data/THANKS +5 -0
- data/bin/depify +133 -0
- data/docs/ANNOUNCE.deprec2 +47 -0
- data/docs/README.install +88 -0
- data/docs/README.nagios +22 -0
- data/docs/README.rails +20 -0
- data/docs/README.svn +31 -0
- data/docs/ROADMAP.txt +74 -0
- data/docs/deprec-1.x/deprec-1.x.quickstart +50 -0
- data/docs/deprec-1.x/notes.txt +12 -0
- data/docs/deprec_banner.gif +0 -0
- data/docs/offline_installation.txt +16 -0
- data/docs/windows_linux.txt +350 -0
- data/docs/xen/plan.txt +5 -0
- data/docs/xen/traffic_monitoring_with_vnstat.txt +95 -0
- data/docs/xen/xen-tools-notes.txt +31 -0
- data/docs/xen/xen_on_hardy.txt +39 -0
- data/lib/deprec/capistrano_extensions.rb +435 -0
- data/lib/deprec/recipes/aoe.rb +79 -0
- data/lib/deprec/recipes/apache.rb +179 -0
- data/lib/deprec/recipes/apt_mirror.rb +99 -0
- data/lib/deprec/recipes/ar_sendmail.rb +67 -0
- data/lib/deprec/recipes/canonical.rb +57 -0
- data/lib/deprec/recipes/deprec.rb +188 -0
- data/lib/deprec/recipes/deprecated.rb +71 -0
- data/lib/deprec/recipes/example.rb +115 -0
- data/lib/deprec/recipes/git.rb +97 -0
- data/lib/deprec/recipes/gitosis.rb +48 -0
- data/lib/deprec/recipes/heartbeat.rb +138 -0
- data/lib/deprec/recipes/logrotate.rb +54 -0
- data/lib/deprec/recipes/lvm.rb +20 -0
- data/lib/deprec/recipes/memcache.rb +49 -0
- data/lib/deprec/recipes/mongrel.rb +219 -0
- data/lib/deprec/recipes/monit.rb +135 -0
- data/lib/deprec/recipes/mysql.rb +115 -0
- data/lib/deprec/recipes/nagios.rb +305 -0
- data/lib/deprec/recipes/network.rb +93 -0
- data/lib/deprec/recipes/nginx.rb +144 -0
- data/lib/deprec/recipes/ntp.rb +103 -0
- data/lib/deprec/recipes/passenger.rb +114 -0
- data/lib/deprec/recipes/php.rb +91 -0
- data/lib/deprec/recipes/postfix.rb +115 -0
- data/lib/deprec/recipes/rails.rb +282 -0
- data/lib/deprec/recipes/ree.rb +33 -0
- data/lib/deprec/recipes/ruby.rb +65 -0
- data/lib/deprec/recipes/sphinx.rb +86 -0
- data/lib/deprec/recipes/ssh.rb +93 -0
- data/lib/deprec/recipes/svn.rb +171 -0
- data/lib/deprec/recipes/trac.rb +277 -0
- data/lib/deprec/recipes/ubuntu.rb +20 -0
- data/lib/deprec/recipes/users.rb +90 -0
- data/lib/deprec/recipes/utils.rb +39 -0
- data/lib/deprec/recipes/vnstat.rb +85 -0
- data/lib/deprec/recipes/wordpress.rb +99 -0
- data/lib/deprec/recipes/xen.rb +269 -0
- data/lib/deprec/recipes.rb +40 -0
- data/lib/deprec/templates/aoe/aoe-init +55 -0
- data/lib/deprec/templates/aoe/fence_aoemask +351 -0
- data/lib/deprec/templates/apache/httpd-vhost-app.conf.erb +144 -0
- data/lib/deprec/templates/apache/httpd.conf +465 -0
- data/lib/deprec/templates/apache/index.html.erb +37 -0
- data/lib/deprec/templates/apache/master.css +72 -0
- data/lib/deprec/templates/apt/sources.list +18 -0
- data/lib/deprec/templates/apt_mirror/apt-mirror-cron +4 -0
- data/lib/deprec/templates/apt_mirror/mirror.list +33 -0
- data/lib/deprec/templates/ar_sendmail/logrotate.conf.erb +9 -0
- data/lib/deprec/templates/ar_sendmail/monit.conf.erb +5 -0
- data/lib/deprec/templates/deprec/caprc.erb +14 -0
- data/lib/deprec/templates/heartbeat/authkeys.erb +2 -0
- data/lib/deprec/templates/heartbeat/ha.cf.erb +15 -0
- data/lib/deprec/templates/heartbeat/haresources.erb +1 -0
- data/lib/deprec/templates/logrotate/logrotate.conf.erb +32 -0
- data/lib/deprec/templates/mongrel/logrotate.conf.erb +11 -0
- data/lib/deprec/templates/mongrel/mongrel_cluster-init-script +54 -0
- data/lib/deprec/templates/mongrel/mongrel_cluster.yml.erb +10 -0
- data/lib/deprec/templates/mongrel/monit.conf.erb +17 -0
- data/lib/deprec/templates/monit/monit-init-script +104 -0
- data/lib/deprec/templates/monit/monitrc.erb +227 -0
- data/lib/deprec/templates/monit/nothing +0 -0
- data/lib/deprec/templates/mysql/create_databases.sql +20 -0
- data/lib/deprec/templates/mysql/database.yml.prod +6 -0
- data/lib/deprec/templates/mysql/database.yml.stage +6 -0
- data/lib/deprec/templates/mysql/my.cnf.erb +140 -0
- data/lib/deprec/templates/mysql/sphinx.conf.prod +542 -0
- data/lib/deprec/templates/mysql/sphinx.conf.stage +542 -0
- data/lib/deprec/templates/nagios/cgi.cfg.erb +321 -0
- data/lib/deprec/templates/nagios/check_linux_free_memory.pl +118 -0
- data/lib/deprec/templates/nagios/check_mongrel_cluster.rb +82 -0
- data/lib/deprec/templates/nagios/commands.cfg.erb +240 -0
- data/lib/deprec/templates/nagios/contacts.cfg.erb +57 -0
- data/lib/deprec/templates/nagios/hosts.cfg.erb +143 -0
- data/lib/deprec/templates/nagios/htpasswd.users +1 -0
- data/lib/deprec/templates/nagios/localhost.cfg.erb +157 -0
- data/lib/deprec/templates/nagios/nagios.cfg.erb +1274 -0
- data/lib/deprec/templates/nagios/nagios_apache_vhost.conf.erb +45 -0
- data/lib/deprec/templates/nagios/nrpe.cfg.erb +210 -0
- data/lib/deprec/templates/nagios/nrpe.xinetd.erb +16 -0
- data/lib/deprec/templates/nagios/resource.cfg.erb +34 -0
- data/lib/deprec/templates/nagios/services.cfg.erb +79 -0
- data/lib/deprec/templates/nagios/templates.cfg.erb +9 -0
- data/lib/deprec/templates/nagios/timeperiods.cfg.erb +94 -0
- data/lib/deprec/templates/network/hostname.erb +1 -0
- data/lib/deprec/templates/network/hosts.erb +2 -0
- data/lib/deprec/templates/network/interfaces.erb +18 -0
- data/lib/deprec/templates/network/resolv.conf.erb +6 -0
- data/lib/deprec/templates/nginx/logrotate.conf.erb +13 -0
- data/lib/deprec/templates/nginx/mime.types.erb +70 -0
- data/lib/deprec/templates/nginx/nginx-init-script +62 -0
- data/lib/deprec/templates/nginx/nginx.conf.erb +125 -0
- data/lib/deprec/templates/nginx/nginx.logrotate.d +12 -0
- data/lib/deprec/templates/nginx/nothing.conf +1 -0
- data/lib/deprec/templates/nginx/rails_nginx_vhost.conf.erb +41 -0
- data/lib/deprec/templates/ntp/ntp.conf.erb +42 -0
- data/lib/deprec/templates/passenger/apache_vhost.erb +10 -0
- data/lib/deprec/templates/passenger/passenger.erb +20 -0
- data/lib/deprec/templates/postfix/aliases.erb +3 -0
- data/lib/deprec/templates/postfix/dynamicmaps.cf.erb +8 -0
- data/lib/deprec/templates/postfix/main.cf.erb +36 -0
- data/lib/deprec/templates/postfix/master.cf.erb +77 -0
- data/lib/deprec/templates/sphinx/monit.conf.erb +5 -0
- data/lib/deprec/templates/ssh/ssh_config.erb +50 -0
- data/lib/deprec/templates/ssh/sshd_config.erb +78 -0
- data/lib/deprec/templates/subversion/svn.apache.vhost.erb +43 -0
- data/lib/deprec/templates/trac/apache_vhost.conf.erb +24 -0
- data/lib/deprec/templates/trac/nginx_vhost.conf.erb +26 -0
- data/lib/deprec/templates/trac/trac.ini.erb +169 -0
- data/lib/deprec/templates/trac/trac_deprec.png +0 -0
- data/lib/deprec/templates/trac/tracd-init.erb +43 -0
- data/lib/deprec/templates/trac/users.htdigest.erb +0 -0
- data/lib/deprec/templates/vnstat/config.php +57 -0
- data/lib/deprec/templates/wordpress/apache2_wordpress_vhost.conf.erb +31 -0
- data/lib/deprec/templates/wordpress/wp-config.php.erb +31 -0
- data/lib/deprec/templates/xen/15-disable-hwclock +40 -0
- data/lib/deprec/templates/xen/40-setup-networking +145 -0
- data/lib/deprec/templates/xen/network-bridge-wrapper +3 -0
- data/lib/deprec/templates/xen/xen-tools.conf.erb +220 -0
- data/lib/deprec/templates/xen/xend-config.sxp.erb +195 -0
- data/lib/deprec/templates/xen/xend-init.erb +57 -0
- data/lib/deprec/templates/xen/xendomains.erb +137 -0
- data/lib/deprec/templates/xen/xm.tmpl.erb +85 -0
- data/lib/deprec.rb +8 -0
- data/lib/deprec_cmd_completion.sh +26 -0
- data/lib/vmbuilder_plugins/all.rb +20 -0
- data/lib/vmbuilder_plugins/apt.rb +93 -0
- data/lib/vmbuilder_plugins/emerge.rb +76 -0
- data/lib/vmbuilder_plugins/gem.rb +90 -0
- data/lib/vmbuilder_plugins/std.rb +203 -0
- 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
|