deprec 1.9.3 → 2.0.0
Sign up to get free protection for your applications and to get access to all the features.
- data/CHANGELOG +280 -0
- data/COPYING +19 -0
- data/LICENSE +339 -0
- data/README +152 -0
- data/THANKS +17 -0
- data/bin/depify +128 -0
- data/docs/EXAMPLE-installing_tracks.txt +41 -0
- data/docs/README.nagios +22 -0
- data/docs/README.rails +17 -0
- data/docs/config_gen_explained.txt +39 -0
- data/docs/{README.quickstart → deprec-1.x/deprec-1.x.quickstart} +4 -1
- data/docs/{building_edge_capistrano.txt → deprec-1.x/notes.txt} +6 -3
- data/docs/old/deprec_banner.gif +0 -0
- data/docs/windows_linux.txt +350 -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.rb +8 -1
- data/lib/deprec/capistrano_extensions.rb +442 -0
- data/lib/deprec/recipes.rb +50 -233
- data/lib/deprec/recipes/aoe.rb +79 -0
- data/lib/deprec/recipes/app/mongrel.rb +213 -0
- data/lib/deprec/recipes/app/passenger.rb +197 -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 +68 -0
- data/lib/deprec/recipes/db/mysql.rb +144 -0
- data/lib/deprec/recipes/db/postgresql.rb +104 -0
- data/lib/deprec/recipes/db/sqlite.rb +37 -0
- data/lib/deprec/recipes/ddclient.rb +51 -0
- data/lib/deprec/recipes/deprec.rb +199 -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 +6 -2
- data/lib/deprec/recipes/monit.rb +143 -0
- data/lib/deprec/recipes/nagios.rb +305 -0
- data/lib/deprec/recipes/network.rb +93 -0
- data/lib/deprec/recipes/ntp.rb +103 -0
- data/lib/deprec/recipes/php.rb +58 -0
- data/lib/deprec/recipes/postfix.rb +115 -0
- data/lib/deprec/recipes/rails.rb +300 -55
- data/lib/deprec/recipes/ruby/mri.rb +55 -0
- data/lib/deprec/recipes/ruby/ree.rb +41 -0
- data/lib/deprec/recipes/sphinx.rb +86 -0
- data/lib/deprec/recipes/ssh.rb +85 -18
- data/lib/deprec/recipes/ssl.rb +55 -0
- data/lib/deprec/recipes/starling.rb +119 -0
- data/lib/deprec/recipes/svn.rb +163 -183
- data/lib/deprec/recipes/trac.rb +239 -62
- data/lib/deprec/recipes/ubuntu.rb +18 -100
- data/lib/deprec/recipes/users.rb +90 -0
- data/lib/deprec/recipes/utils.rb +58 -0
- data/lib/deprec/recipes/vnstat.rb +85 -0
- data/lib/deprec/recipes/web/apache.rb +119 -0
- data/lib/deprec/recipes/web/nginx.rb +172 -0
- data/lib/deprec/recipes/wordpress.rb +96 -0
- data/lib/deprec/recipes/wpmu.rb +103 -0
- data/lib/deprec/recipes/xen.rb +267 -0
- data/lib/deprec/recipes/xentools.rb +75 -0
- data/lib/deprec/templates/aoe/aoe-init +55 -0
- data/lib/deprec/templates/aoe/fence_aoemask +351 -0
- data/lib/deprec/templates/apache/namevirtualhosts.conf +5 -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/ddclient/ddclient.conf.erb +11 -0
- data/lib/deprec/templates/ddclient/ddclient.erb +15 -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/apache_vhost.erb +148 -0
- data/lib/deprec/templates/mongrel/logrotate.conf.erb +11 -0
- data/lib/deprec/{third_party/mongrel_cluster/resources/mongrel_cluster → templates/mongrel/mongrel_cluster-init-script} +19 -6
- 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/mongrel/nginx_vhost.erb +41 -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 +21 -0
- data/lib/deprec/templates/passenger/passenger.conf.erb +21 -0
- data/lib/deprec/templates/passenger/passenger.load.erb +3 -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.conf → postfix/main.cf.erb} +6 -8
- 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/ssl/make-ssl-cert +138 -0
- data/lib/deprec/templates/ssl/ssl-cert-snakeoil.key +15 -0
- data/lib/deprec/templates/ssl/ssl-cert-snakeoil.pem +19 -0
- data/lib/deprec/templates/starling/monit.conf.erb +14 -0
- data/lib/deprec/templates/starling/starling-init-script.erb +71 -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/wpmu/apache_vhost.conf.erb +13 -0
- data/lib/deprec/templates/xen/network-bridge-wrapper +3 -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/xentools/15-disable-hwclock +40 -0
- data/lib/deprec/templates/xentools/40-setup-networking +145 -0
- data/lib/deprec/templates/xentools/xen-tools.conf.erb +276 -0
- data/lib/deprec/templates/xentools/xm.tmpl.erb +138 -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/{deprec/third_party/vmbuilder/plugins → vmbuilder_plugins}/gem.rb +10 -17
- data/lib/{deprec/third_party/vmbuilder/plugins → vmbuilder_plugins}/std.rb +69 -19
- metadata +204 -55
- data/bin/deprec +0 -35
- data/docs/README.slicehost +0 -14
- data/docs/README.svn_trac +0 -19
- data/lib/deprec/capistrano_extensions/actor_extensions.rb +0 -89
- data/lib/deprec/capistrano_extensions/cli_extensions.rb +0 -38
- data/lib/deprec/capistrano_extensions/deprec_extensions.rb +0 -137
- data/lib/deprec/generators/deprec/USAGE +0 -11
- data/lib/deprec/generators/deprec/deprec_generator.rb +0 -24
- data/lib/deprec/generators/deprec/templates/deploy.rb +0 -90
- data/lib/deprec/generators/loader.rb +0 -20
- data/lib/deprec/recipes/apache.rb +0 -91
- data/lib/deprec/recipes/cache_svn.rb +0 -74
- data/lib/deprec/recipes/vmware.rb +0 -114
- data/lib/deprec/templates/trac.ini.erb +0 -106
- data/lib/deprec/third_party/THIRD_PARTY_README +0 -12
- data/lib/deprec/third_party/mongrel_cluster/LICENSE +0 -506
- data/lib/deprec/third_party/mongrel_cluster/recipes.rb +0 -96
- data/lib/deprec/third_party/railsmachine/LICENSE +0 -506
- data/lib/deprec/third_party/railsmachine/recipes/apache.rb +0 -92
- data/lib/deprec/third_party/railsmachine/recipes/mysql.rb +0 -73
- data/lib/deprec/third_party/railsmachine/recipes/templates/httpd-ssl.conf +0 -80
- data/lib/deprec/third_party/railsmachine/recipes/templates/httpd.conf +0 -57
- data/lib/deprec/third_party/vmbuilder/plugins.rb +0 -8
- data/lib/deprec/third_party/vmbuilder/plugins/apt.rb +0 -144
- data/resources/capistrano_include_dotfiles.patch +0 -17
Binary file
|
@@ -0,0 +1,350 @@
|
|
1
|
+
http://cheat.errtheblog.com/s/deprec2/
|
2
|
+
|
3
|
+
This is a copy of Chris Turners deprec2 howto (found here
|
4
|
+
http://crackthenut.cracklabs.com/deprec2-your-slice/). I'm adding it here
|
5
|
+
because his site is down at the moment and I almost cried myself to sleep at the
|
6
|
+
thought of losing it (thank you google cache)
|
7
|
+
|
8
|
+
------------------------------
|
9
|
+
|
10
|
+
This is a summary of how we build our servers and deploy our Rails apps from
|
11
|
+
Ubuntu with the the current pre-release version of deprec2 + capistrano2.
|
12
|
+
|
13
|
+
We use Slicehost to host our Rails apps (highly recommended) and we use deprec +
|
14
|
+
capistrano to build our slices and deploy our apps. Mike Bailey has been hard at
|
15
|
+
work on deprec2, which builds on capistrano2 by Jamis Buck. Thank you to Mike
|
16
|
+
and Jamis for making these great tools that make life easier.
|
17
|
+
|
18
|
+
The machine I was deploying from here (my “development” machine) is an
|
19
|
+
Ubuntu Dapper slice with Ruby 1.8.6 and rubygems 1.0.1.
|
20
|
+
|
21
|
+
The target machine here was a Slicehost slice with Ubuntu Gutsy.
|
22
|
+
|
23
|
+
This will build the slice with Ruby 1.8.6 and latest rails (2.0.2 as of this
|
24
|
+
writing) For serving up your app it installs mongrel+nginx (not apache - though
|
25
|
+
it can easily be modified to use it)
|
26
|
+
|
27
|
+
We use another remote machine to hold our source repositories and access those
|
28
|
+
via the svn+ssh protocol. That is reflected in these instructions.
|
29
|
+
|
30
|
+
Step 1 gets your development machine set up properly and is a one-time deal. You
|
31
|
+
won’t have to repeat it for each new slice you build/deploy to.
|
32
|
+
|
33
|
+
Step 2 installs everything you’ll need on your slice and deploys your app
|
34
|
+
|
35
|
+
I wanted to get this posted sooner rather than later - it may be a bit terse -
|
36
|
+
let me know if anything is confusing or inaccurate. I’ll TRY to keep these
|
37
|
+
instruction updated as deprec2 moves into full release and other things change.
|
38
|
+
Step 1 - Set Up The Machine You Are Deploying From (running Ubuntu in this case)
|
39
|
+
|
40
|
+
This will make sure your development machine is set up the right way so that
|
41
|
+
building your slice goes smoothly. You won’t have to repeat this when you
|
42
|
+
build/deploy to future slices.
|
43
|
+
1.1. Download the pre-release deprec2 gem
|
44
|
+
|
45
|
+
Deprec 2.0 isn’t quite released yet, but there is a pre-release gem available.
|
46
|
+
As of this writing it is at version 1.99-13. You can find it at deprec.org.
|
47
|
+
|
48
|
+
The URL is almost guaranteed to change, but I’ve been grabbing the gem by:
|
49
|
+
|
50
|
+
wget
|
51
|
+
http://www.deprec.org/attachment/wiki/WikiStart/deprec-1.99.13.gem?format=raw -O
|
52
|
+
deprec-1.99.13.gem
|
53
|
+
|
54
|
+
1.2. Install Deprec
|
55
|
+
|
56
|
+
sudo gem install deprec-1.99.13.gem
|
57
|
+
|
58
|
+
Make sure you run this command from the same directory where you downloaded the
|
59
|
+
deprec gem to.
|
60
|
+
This will also install the latest version of capistrano, should you not already
|
61
|
+
have it.
|
62
|
+
1.3. Install fastthread
|
63
|
+
|
64
|
+
sudo gem install fastthread
|
65
|
+
|
66
|
+
Fastthread is necessary if you are using Ruby 1.8.6 to avoid possible deadlocks
|
67
|
+
when using capistrano (or so I hear)
|
68
|
+
1.4. Generate keys
|
69
|
+
|
70
|
+
ssh-keygen -t rsa
|
71
|
+
|
72
|
+
Accept the default name/location.
|
73
|
+
|
74
|
+
Enter a passphrase if you wish.
|
75
|
+
|
76
|
+
On my machine this creates my keys in /home/username/.ssh
|
77
|
+
1.5. Setup a directory we can use for holding slice config files
|
78
|
+
|
79
|
+
This directory is not specific to any one rails project and once we set it up we
|
80
|
+
can use
|
81
|
+
it in the future to do some of the initial setup for other slices we may build.
|
82
|
+
|
83
|
+
From within /home/username:
|
84
|
+
|
85
|
+
mkdir -p config_slices/config
|
86
|
+
|
87
|
+
1.6. Create some files for Deprec/Capistrano
|
88
|
+
|
89
|
+
Change to your config_slices directory and:
|
90
|
+
|
91
|
+
depify .
|
92
|
+
|
93
|
+
This creates:
|
94
|
+
~/.caprc
|
95
|
+
~/config_slices/Capfile
|
96
|
+
~/config_slices/config/deploy.rb
|
97
|
+
|
98
|
+
1.7. Edit your .caprc
|
99
|
+
|
100
|
+
Open up ~/.caprc with a text editor
|
101
|
+
|
102
|
+
Uncomment and update this line to point at the appropriate directory
|
103
|
+
|
104
|
+
ssh_options[:keys] = %w(/path/to/your_home_dir/.ssh/id_rsa)
|
105
|
+
|
106
|
+
like this on my machine:
|
107
|
+
|
108
|
+
ssh_options[:keys] = %w(/home/username/.ssh/id_rsa)
|
109
|
+
|
110
|
+
and uncomment these lines:
|
111
|
+
|
112
|
+
ssh_options[:forward_agent] = ...
|
113
|
+
ssh_options[:paranoid] = ...
|
114
|
+
|
115
|
+
1.8. Generate some config files locally that will be pushed out to your slice in
|
116
|
+
a future step
|
117
|
+
|
118
|
+
Make sure you are still in config_slices directory
|
119
|
+
|
120
|
+
cap deprec:ssh:config_gen
|
121
|
+
|
122
|
+
This step generates configuration files which will be used to configure the ssh
|
123
|
+
client and server on the slice.
|
124
|
+
It also makes a directory to hold public keys for you and other users so deprec
|
125
|
+
can find your keys and copy those out to the slice for you.
|
126
|
+
1.9. (optional) Make some changes to the sshd_config before you send it to the
|
127
|
+
slice
|
128
|
+
|
129
|
+
This step changes a couple settings in the the file that will be used to
|
130
|
+
configure the slice’s ssh server.
|
131
|
+
It will be more secure if you don’t make either of these changes, but there is
|
132
|
+
a chance you might find them to be useful.
|
133
|
+
|
134
|
+
Edit ~/config_slices/config/ssh/etc/ssh/sshd_config
|
135
|
+
|
136
|
+
If you still want to be able to ssh into your slice with a password (not only
|
137
|
+
keys), change the line from
|
138
|
+
|
139
|
+
PasswordAuthentication no
|
140
|
+
|
141
|
+
to
|
142
|
+
|
143
|
+
PasswordAuthentication yes
|
144
|
+
|
145
|
+
If you still want to be able to ssh into your slice as root, change the line
|
146
|
+
from
|
147
|
+
|
148
|
+
PermitRootLogin no
|
149
|
+
|
150
|
+
to
|
151
|
+
|
152
|
+
PermitRootLogin yes
|
153
|
+
|
154
|
+
1.10. Make some changes to the ssh_config before you send it to the slice
|
155
|
+
|
156
|
+
This step changes a couple settings in the the file that will be used to
|
157
|
+
configure the slice’s ssh client.
|
158
|
+
This prevents the slice from getting a host key error when it uses ssh to check
|
159
|
+
out your code from the svn repo.
|
160
|
+
|
161
|
+
Edit ~/config_slices/config/ssh/etc/ssh/ssh_config
|
162
|
+
|
163
|
+
Change:
|
164
|
+
|
165
|
+
#StrictHostKeyChecking ask
|
166
|
+
|
167
|
+
to
|
168
|
+
|
169
|
+
StrictHostKeyChecking no
|
170
|
+
|
171
|
+
1.11. Copy your public key to a place where deprec can find it
|
172
|
+
|
173
|
+
cp ~/.ssh/id_rsa.pub ~/config_slices/config/ssh/authorized_keys/deploy_user
|
174
|
+
|
175
|
+
Note: this copies and renames the file from id_rsa.pub to deploy_user
|
176
|
+
|
177
|
+
You can put whatever you want for deploy_user - this will be the username we
|
178
|
+
create on the slice later. I just use my last name. deprec makes it easy to
|
179
|
+
add/manage additional users on the slice in the future - no need to have a
|
180
|
+
single, dedicated “deploy” user.
|
181
|
+
1.12. Copy your public key out to your svn machine
|
182
|
+
|
183
|
+
PUT SOMETHING HERE
|
184
|
+
|
185
|
+
Step 2 - Set up your slice and deploy your app
|
186
|
+
|
187
|
+
Now that our development machine is set up we can move on to dealing with our
|
188
|
+
slice.
|
189
|
+
2.1. Create a new slice or rebuild one from SliceManager
|
190
|
+
|
191
|
+
Note your slice’s IP address and new root password.
|
192
|
+
2.2. Change the root password on the slice
|
193
|
+
|
194
|
+
From within config_slices directory:
|
195
|
+
|
196
|
+
cap deprec:users:passwd USER=root HOSTS=your.slice.ip.address
|
197
|
+
|
198
|
+
1. You will be prompted for which user to change the password for - default
|
199
|
+
is root, which is what we want - so just hit enter
|
200
|
+
2. You will be prompted for root’s new password - type one in
|
201
|
+
3. You will be prompted for the slice’s current root password - enter the
|
202
|
+
password slicehost emailed you
|
203
|
+
|
204
|
+
Your slice’s root password has been changed.
|
205
|
+
2.3. Create a new user on the slice to do your deployment with
|
206
|
+
|
207
|
+
From within config_slices directory:
|
208
|
+
|
209
|
+
cap deprec:users:add USER=root HOSTS=your.slice.ip.address
|
210
|
+
|
211
|
+
1. You will be prompted for a new username - enter whatever you used for
|
212
|
+
deploy_user in step 1.11
|
213
|
+
2. You will be asked if this should be an admin account -> enter yes
|
214
|
+
3. It should tell you it has found the key you copied above (if not you named
|
215
|
+
the key wrong or did not copy it to the correct place in 1.11) and ask if you
|
216
|
+
want to copy it out to the slice - default is yes - so hit enter
|
217
|
+
4. You will be prompted for a new password for deploy_user -> enter one
|
218
|
+
5. You will be prompted for a password - enter your slice’s new root
|
219
|
+
password from previous step
|
220
|
+
|
221
|
+
Your deploy_user has now been created on the slice and that users public key has
|
222
|
+
been copied over.
|
223
|
+
2.4. (optional) Make sure your keys work and some stuff about ssh-agent
|
224
|
+
|
225
|
+
At this point your user has been created on the slice and you should be able to
|
226
|
+
ssh into the
|
227
|
+
slice from your development machine.
|
228
|
+
|
229
|
+
If you want to make sure your keys are working properly:
|
230
|
+
|
231
|
+
PLACEHOLDER:
|
232
|
+
|
233
|
+
-test ssh into your slice with no password
|
234
|
+
|
235
|
+
-instruction for running ssh-agent to eliminate passphrases and make sure key
|
236
|
+
can get forwarded to svn if applicable
|
237
|
+
|
238
|
+
-also test you can also ssh into your svn (if you use svn+ssh) - if not then add
|
239
|
+
public key to authorized_keys on svn machine
|
240
|
+
2.5. Copy the ssh/sshd configs over to the slice
|
241
|
+
|
242
|
+
From within config_slices directory:
|
243
|
+
|
244
|
+
cap deprec:ssh:config USER=deploy_user HOSTS=my.slice.ip.address
|
245
|
+
|
246
|
+
This configures the ssh client and server on the slice according to the config
|
247
|
+
files we generated/edited in Step 1.
|
248
|
+
2.6. Setup your deploy.rb
|
249
|
+
|
250
|
+
cd my_rails_project
|
251
|
+
depify .
|
252
|
+
|
253
|
+
Edit my_rails_project/config/deploy.rb:
|
254
|
+
|
255
|
+
If you do not keep database.yml under source control add this line at the top
|
256
|
+
(after require ‘deprec’):
|
257
|
+
|
258
|
+
set :database_yml_in_scm, false
|
259
|
+
|
260
|
+
This will make sure that database.yml is symlinked from the shared/config dir
|
261
|
+
(we’ll create that file later)
|
262
|
+
If you keep database.yml in source control you should not put this line in.
|
263
|
+
|
264
|
+
Now change the following lines to match your specifics:
|
265
|
+
|
266
|
+
set :user, "deploy_user"
|
267
|
+
set :application, "my_rails_project"
|
268
|
+
set :repository,
|
269
|
+
"svn+ssh://my_svn_useruser@my_svn/path_to/my_rails_project/trunk" #or whatever
|
270
|
+
set :domain, "my.slice.ip.address" #or domain name if you have that setup
|
271
|
+
role :app, domain
|
272
|
+
role :web, domain
|
273
|
+
role :db, domain, :primary => true
|
274
|
+
|
275
|
+
2.7. Install ruby/rails/mysql/mongrel/nginx and everything else you need on the
|
276
|
+
slice
|
277
|
+
|
278
|
+
From within my_rails_project directory:
|
279
|
+
|
280
|
+
cap deprec:rails:install_rails_stack
|
281
|
+
|
282
|
+
And you thought that would be hard…
|
283
|
+
This step saves you a LOT of work (thank you Mike Bailey)
|
284
|
+
It takes a little while, ~10 min when I ran it.
|
285
|
+
2.8. Run the initial deploy to get things configured
|
286
|
+
|
287
|
+
From within my_rails_project directory:
|
288
|
+
|
289
|
+
cap deploy:setup
|
290
|
+
cap deploy
|
291
|
+
|
292
|
+
This sets up your application on the slice and does an initial check out from
|
293
|
+
your svn.
|
294
|
+
2.9. Create database.yml on the slice if you don’t keep it in source control
|
295
|
+
|
296
|
+
Skip this step if database.yml is under source control.
|
297
|
+
|
298
|
+
Add the following to my_rails_project/config/deploy.rb inside the
|
299
|
+
namespace:deploy block
|
300
|
+
|
301
|
+
db_params = {
|
302
|
+
"adapter"=>"mysql",
|
303
|
+
"database"=>"#{application}_#{rails_env}",
|
304
|
+
"username"=>"root",
|
305
|
+
"password"=>"",
|
306
|
+
"host"=>"localhost",
|
307
|
+
"socket"=>""
|
308
|
+
}
|
309
|
+
|
310
|
+
db_params.each do |param, default_val|
|
311
|
+
set "db_#{param}".to_sym,
|
312
|
+
lambda { Capistrano::CLI.ui.ask "Enter database #{param}" do |q|
|
313
|
+
q.default=default_val end}
|
314
|
+
end
|
315
|
+
|
316
|
+
task :my_generate_database_yml, :roles => :app do
|
317
|
+
database_configuration = "#{rails_env}:\n"
|
318
|
+
db_params.each do |param, default_val|
|
319
|
+
val=self.send("db_#{param}")
|
320
|
+
database_configuration<<" #{param}: #{val}\n"
|
321
|
+
end
|
322
|
+
run "mkdir -p #{deploy_to}/#{shared_dir}/config"
|
323
|
+
put database_configuration, "#{deploy_to}/#{shared_dir}/config/database.yml"
|
324
|
+
end
|
325
|
+
|
326
|
+
Now run this task to create database.yml
|
327
|
+
|
328
|
+
cap deploy:my_generate_database_yml
|
329
|
+
|
330
|
+
Follow the prompts - this makes database.yml - the defaults are likely ok (just
|
331
|
+
hit enter) at all of the prompts.
|
332
|
+
|
333
|
+
2.10. Create the database and apply migrations
|
334
|
+
|
335
|
+
Still from within my_rails_project directory:
|
336
|
+
|
337
|
+
cap deprec:db:create
|
338
|
+
cap deprec:db:migrate
|
339
|
+
|
340
|
+
This creates your database and applies your migrations.
|
341
|
+
|
342
|
+
2.11. Restart mongrel+nginx
|
343
|
+
|
344
|
+
Still from within my_rails_project directory:
|
345
|
+
|
346
|
+
cap deprec:mongrel:restart
|
347
|
+
cap deprec:nginx:restart
|
348
|
+
|
349
|
+
Now you should be able to point your browser at your slice and see your app
|
350
|
+
running. Congrats!
|
@@ -0,0 +1,95 @@
|
|
1
|
+
# vnstat
|
2
|
+
|
3
|
+
# install vnstat
|
4
|
+
http://humdi.net/vnstat/vnstat-1.6.tar.gz
|
5
|
+
sudo apt-get install vnstat
|
6
|
+
|
7
|
+
# initialize it for a virtual interface
|
8
|
+
vnstat -u -i vif-apt
|
9
|
+
|
10
|
+
# generate images
|
11
|
+
http://humdi.net/vnstat/vnstati-beta3.tar.gz
|
12
|
+
apt-get install libgd2-noxpm-dev libgd2-noxpm
|
13
|
+
vnstati -s -i vif-apt -o /tmp/vnstat.png
|
14
|
+
|
15
|
+
# php web frontend
|
16
|
+
http://www.sqweek.com/sqweek/files/vnstat_php_frontend-1.3.tar.gz
|
17
|
+
|
18
|
+
|
19
|
+
# Steps for setting up vnstat on a new Xen dom0
|
20
|
+
|
21
|
+
1. Install vnstat on host
|
22
|
+
|
23
|
+
# Steps for adding a new server to vnstat monitoring
|
24
|
+
|
25
|
+
1. Add it to vnstat monitoring
|
26
|
+
|
27
|
+
vnstat -u -i web2-eth0
|
28
|
+
|
29
|
+
2.
|
30
|
+
|
31
|
+
|
32
|
+
#
|
33
|
+
# Add all eth interfaces
|
34
|
+
#
|
35
|
+
for x in `ls /proc/sys/net/ipv4/conf | grep eth | cut -f 1 -d' '`; do
|
36
|
+
vnstat -u -i $x
|
37
|
+
done
|
38
|
+
|
39
|
+
#!/bin/bash
|
40
|
+
#
|
41
|
+
# Dump vnstat data
|
42
|
+
#
|
43
|
+
dump_dir=/var/lib/vnstat_dumps
|
44
|
+
|
45
|
+
test -d $dump_dir || mkdir -p $dump_dir
|
46
|
+
|
47
|
+
for x in `ls /var/lib/vnstat/*-eth*`; do
|
48
|
+
vnstat --dumpdb -i `basename $x` > ${dump_dir}/vnstat_dump_`basename $x`
|
49
|
+
done
|
50
|
+
|
51
|
+
for x in eth0 eth1; do
|
52
|
+
vnstat --dumpdb -i $x > ${dump_dir}/vnstat_dump_`hostname`-$x
|
53
|
+
done
|
54
|
+
|
55
|
+
|
56
|
+
|
57
|
+
#!/bin/bash
|
58
|
+
#
|
59
|
+
# Pull vnstat metrics back from Xen dom0's
|
60
|
+
#
|
61
|
+
|
62
|
+
dump_dir=/var/lib/vnstat_dumps
|
63
|
+
|
64
|
+
test -d $dump_dir || mkdir -p $dump_dir
|
65
|
+
for x in sm03; do
|
66
|
+
rsync -avz ${x}:${dump_dir}/ /var/www/vnstat/dumps/
|
67
|
+
done
|
68
|
+
|
69
|
+
|
70
|
+
|
71
|
+
#
|
72
|
+
# Separate internal and external traffic on NAT'ed slices
|
73
|
+
#
|
74
|
+
|
75
|
+
The following in /etc/network/interfaces will allow us to monitor
|
76
|
+
internal and external traffic by reading separate interface counters
|
77
|
+
on the domU.
|
78
|
+
|
79
|
+
# First IP on internal network (for external traffic)
|
80
|
+
auto eth0
|
81
|
+
iface eth0 inet static
|
82
|
+
address 192.168.1.70
|
83
|
+
netmask 255.255.255.255
|
84
|
+
|
85
|
+
# Second IP on internal network (for internal traffic only)
|
86
|
+
auto eth1
|
87
|
+
iface eth1 inet static
|
88
|
+
address 192.168.1.71
|
89
|
+
netmask 255.255.255.0
|
90
|
+
|
91
|
+
# Route external traffic out eth0
|
92
|
+
up route add -net 192.168.1.1 netmask 255.255.255.255 dev eth0
|
93
|
+
up route add default gw 192.168.1.1
|
94
|
+
|
95
|
+
|
@@ -0,0 +1,31 @@
|
|
1
|
+
#
|
2
|
+
# xen-tools : interesting bits
|
3
|
+
#
|
4
|
+
|
5
|
+
xt-install-image Install a new distribution.
|
6
|
+
xt-customize-image Run a collection of hook scripts to customise the freshly installed system.
|
7
|
+
xt-create-xen-config Create a Xen configuration file in so that xm can start the new domain.
|
8
|
+
|
9
|
+
|
10
|
+
# PARTITIONING
|
11
|
+
/etc/xen-tools/partitions.d/
|
12
|
+
--partition partition_scheme_file
|
13
|
+
|
14
|
+
# Automatic IP provisioning
|
15
|
+
--ip=auto /etc/xen-tools/ips.txt
|
16
|
+
|
17
|
+
# Config template
|
18
|
+
/etc/xen-tools/xm.tmpl
|
19
|
+
--template
|
20
|
+
|
21
|
+
# tar up first image and use for installation
|
22
|
+
xen-create-image --size=2Gb --swap=128Mb --dhcp \
|
23
|
+
--lvm=myvolumegroup --hostname=vm01.my.flat \
|
24
|
+
--install-method=tar --install-source=/path/to/tar.file.tar
|
25
|
+
|
26
|
+
# Roles
|
27
|
+
/etc/xen-tools/role.d
|
28
|
+
--role=filename -role-args
|
29
|
+
|
30
|
+
# skeleton dir
|
31
|
+
/etc/xen-tools/skel
|