]> git.openstreetmap.org Git - chef.git/blob - cookbooks/tile/recipes/default.rb
cdf2474e74c803287b9433aedd554b7e6cdd8bff
[chef.git] / cookbooks / tile / recipes / default.rb
1 #
2 # Cookbook Name:: tile
3 # Recipe:: default
4 #
5 # Copyright 2013, OpenStreetMap Foundation
6 #
7 # Licensed under the Apache License, Version 2.0 (the "License");
8 # you may not use this file except in compliance with the License.
9 # You may obtain a copy of the License at
10 #
11 #     http://www.apache.org/licenses/LICENSE-2.0
12 #
13 # Unless required by applicable law or agreed to in writing, software
14 # distributed under the License is distributed on an "AS IS" BASIS,
15 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 # See the License for the specific language governing permissions and
17 # limitations under the License.
18 #
19
20 include_recipe "apache"
21 include_recipe "git"
22 include_recipe "nodejs"
23 include_recipe "postgresql"
24 include_recipe "tools"
25
26 blocks = data_bag_item("tile", "blocks")
27
28 apache_module "alias"
29 apache_module "cgi"
30 apache_module "expires"
31 apache_module "headers"
32 apache_module "remoteip"
33 apache_module "rewrite"
34
35 apache_module "tile" do
36   conf "tile.conf.erb"
37 end
38
39 tilecaches = search(:node, "roles:tilecache").sort_by { |n| n[:hostname] }
40
41 apache_site "default" do
42   action [:disable]
43 end
44
45 apache_site "tile.openstreetmap.org" do
46   template "apache.erb"
47   variables :caches => tilecaches
48 end
49
50 template "/etc/logrotate.d/apache2" do
51   source "logrotate.apache.erb"
52   owner "root"
53   group "root"
54   mode 0o644
55 end
56
57 directory "/srv/tile.openstreetmap.org" do
58   owner "tile"
59   group "tile"
60   mode 0o755
61 end
62
63 package "renderd"
64
65 systemd_service "renderd" do
66   description "Mapnik rendering daemon"
67   after "postgresql.service"
68   wants "postgresql.service"
69   user "www-data"
70   exec_start "/usr/bin/renderd -f"
71   runtime_directory "renderd"
72   standard_error "null"
73   private_tmp true
74   private_devices true
75   private_network true
76   protect_system "full"
77   protect_home true
78   restart "on-failure"
79 end
80
81 service "renderd" do
82   action [:enable, :start]
83 end
84
85 directory "/srv/tile.openstreetmap.org/tiles" do
86   owner "tile"
87   group "tile"
88   mode 0o755
89 end
90
91 template "/etc/renderd.conf" do
92   source "renderd.conf.erb"
93   owner "root"
94   group "root"
95   mode 0o644
96   notifies :reload, "service[apache2]"
97   notifies :restart, "service[renderd]"
98 end
99
100 remote_directory "/srv/tile.openstreetmap.org/html" do
101   source "html"
102   owner "tile"
103   group "tile"
104   mode 0o755
105   files_owner "tile"
106   files_group "tile"
107   files_mode 0o644
108 end
109
110 template "/srv/tile.openstreetmap.org/html/index.html" do
111   source "index.html.erb"
112   owner "tile"
113   group "tile"
114   mode 0o644
115 end
116
117 package "python-cairo"
118 package "python-mapnik"
119
120 package "ttf-dejavu"
121 package "ttf-unifont"
122 package "fonts-droid-fallback"
123 package "fonts-sipa-arundina"
124 package "fonts-sil-padauk"
125 package "fonts-khmeros"
126 package "fonts-beng-extra"
127 package "fonts-gargi"
128 package "fonts-taml-tscu"
129 package "fonts-tibetan-machine"
130
131 directory "/srv/tile.openstreetmap.org/cgi-bin" do
132   owner "tile"
133   group "tile"
134   mode 0o755
135 end
136
137 template "/srv/tile.openstreetmap.org/cgi-bin/export" do
138   source "export.erb"
139   owner "tile"
140   group "tile"
141   mode 0o755
142   variables :blocks => blocks
143 end
144
145 template "/srv/tile.openstreetmap.org/cgi-bin/debug" do
146   source "debug.erb"
147   owner "tile"
148   group "tile"
149   mode 0o755
150 end
151
152 template "/etc/cron.hourly/export" do
153   source "export.cron.erb"
154   owner "root"
155   group "root"
156   mode 0o755
157 end
158
159 directory "/srv/tile.openstreetmap.org/data" do
160   owner "tile"
161   group "tile"
162   mode 0o755
163 end
164
165 package "mapnik-utils"
166
167 node[:tile][:data].each_value do |data|
168   url = data[:url]
169   file = "/srv/tile.openstreetmap.org/data/#{File.basename(url)}"
170
171   if data[:directory]
172     directory = "/srv/tile.openstreetmap.org/data/#{data[:directory]}"
173
174     directory directory do
175       owner "tile"
176       group "tile"
177       mode 0o755
178     end
179   else
180     directory = "/srv/tile.openstreetmap.org/data"
181   end
182
183   if file =~ /\.tgz$/
184     package "tar"
185
186     execute file do
187       action :nothing
188       command "tar -zxf #{file} -C #{directory}"
189       user "tile"
190       group "tile"
191     end
192   elsif file =~ /\.tar\.bz2$/
193     package "tar"
194
195     execute file do
196       action :nothing
197       command "tar -jxf #{file} -C #{directory}"
198       user "tile"
199       group "tile"
200     end
201   elsif file =~ /\.zip$/
202     package "unzip"
203
204     execute file do
205       action :nothing
206       command "unzip -qq -o #{file} -d #{directory}"
207       user "tile"
208       group "tile"
209     end
210   end
211
212   execute "#{file}_shapeindex" do
213     action :nothing
214     command "find #{directory} -type f -iname '*.shp' -print0 | xargs -0 --no-run-if-empty shapeindex --shape_files"
215     user "tile"
216     group "tile"
217     subscribes :run, "execute[#{file}]", :immediately
218   end
219
220   remote_file file do
221     if data[:refresh]
222       action :create
223       use_conditional_get true
224       ignore_failure true
225     else
226       action :create_if_missing
227     end
228
229     source url
230     owner "tile"
231     group "tile"
232     mode 0o644
233     backup false
234     notifies :run, "execute[#{file}]", :immediately
235     notifies :restart, "service[renderd]"
236   end
237 end
238
239 nodejs_package "carto"
240 nodejs_package "millstone"
241
242 directory "/srv/tile.openstreetmap.org/styles" do
243   owner "tile"
244   group "tile"
245   mode 0o755
246 end
247
248 node[:tile][:styles].each do |name, details|
249   style_directory = "/srv/tile.openstreetmap.org/styles/#{name}"
250   tile_directory = "/srv/tile.openstreetmap.org/tiles/#{name}"
251
252   template "/usr/local/bin/update-lowzoom-#{name}" do
253     source "update-lowzoom.erb"
254     owner "root"
255     group "root"
256     mode 0o755
257     variables :style => name
258   end
259
260   template "/etc/init.d/update-lowzoom-#{name}" do
261     source "update-lowzoom.init.erb"
262     owner "root"
263     group "root"
264     mode 0o755
265     variables :style => name
266   end
267
268   service "update-lowzoom-#{name}" do
269     action :disable
270     supports :restart => true
271   end
272
273   directory tile_directory do
274     owner "tile"
275     group "tile"
276     mode 0o755
277   end
278
279   details[:tile_directories].each do |directory|
280     directory directory[:name] do
281       owner "www-data"
282       group "www-data"
283       mode 0o755
284     end
285
286     directory[:min_zoom].upto(directory[:max_zoom]) do |zoom|
287       directory "#{directory[:name]}/#{zoom}" do
288         owner "www-data"
289         group "www-data"
290         mode 0o755
291       end
292
293       link "#{tile_directory}/#{zoom}" do
294         to "#{directory[:name]}/#{zoom}"
295         owner "tile"
296         group "tile"
297       end
298     end
299   end
300
301   file "#{tile_directory}/planet-import-complete" do
302     action :create_if_missing
303     owner "tile"
304     group "tile"
305     mode 0o444
306   end
307
308   git style_directory do
309     action :sync
310     repository details[:repository]
311     revision details[:revision]
312     user "tile"
313     group "tile"
314   end
315
316   link "#{style_directory}/data" do
317     to "/srv/tile.openstreetmap.org/data"
318     owner "tile"
319     group "tile"
320   end
321
322   execute "#{style_directory}/project.mml" do
323     action :nothing
324     command "carto project.mml > project.xml"
325     cwd style_directory
326     user "tile"
327     group "tile"
328     subscribes :run, "git[#{style_directory}]"
329     notifies :restart, "service[renderd]", :immediately
330     notifies :restart, "service[update-lowzoom-#{name}]"
331   end
332 end
333
334 package "postgis"
335
336 postgresql_user "jburgess" do
337   cluster node[:tile][:database][:cluster]
338   superuser true
339 end
340
341 postgresql_user "tomh" do
342   cluster node[:tile][:database][:cluster]
343   superuser true
344 end
345
346 postgresql_user "tile" do
347   cluster node[:tile][:database][:cluster]
348 end
349
350 postgresql_user "www-data" do
351   cluster node[:tile][:database][:cluster]
352 end
353
354 postgresql_database "gis" do
355   cluster node[:tile][:database][:cluster]
356   owner "tile"
357 end
358
359 postgresql_extension "postgis" do
360   cluster node[:tile][:database][:cluster]
361   database "gis"
362 end
363
364 %w(geography_columns planet_osm_nodes planet_osm_rels planet_osm_ways raster_columns raster_overviews spatial_ref_sys).each do |table|
365   postgresql_table table do
366     cluster node[:tile][:database][:cluster]
367     database "gis"
368     owner "tile"
369     permissions "tile" => :all
370   end
371 end
372
373 %w(geometry_columns planet_osm_line planet_osm_point planet_osm_polygon planet_osm_roads).each do |table|
374   postgresql_table table do
375     cluster node[:tile][:database][:cluster]
376     database "gis"
377     owner "tile"
378     permissions "tile" => :all, "www-data" => :select
379   end
380 end
381
382 postgresql_munin "gis" do
383   cluster node[:tile][:database][:cluster]
384   database "gis"
385 end
386
387 file node[:tile][:node_file] do
388   owner "tile"
389   group "www-data"
390   mode 0o640
391 end
392
393 directory "/var/log/tile" do
394   owner "tile"
395   group "tile"
396   mode 0o755
397 end
398
399 package "osm2pgsql"
400 package "osmosis"
401
402 package "ruby"
403 package "ruby-dev"
404
405 package "libproj-dev"
406 package "libxml2-dev"
407
408 gem_package "proj4rb"
409 gem_package "libxml-ruby"
410
411 remote_directory "/usr/local/lib/site_ruby" do
412   source "ruby"
413   owner "root"
414   group "root"
415   mode 0o755
416   files_owner "root"
417   files_group "root"
418   files_mode 0o644
419 end
420
421 template "/usr/local/bin/expire-tiles" do
422   source "expire-tiles.erb"
423   owner "root"
424   group "root"
425   mode 0o755
426 end
427
428 template "/etc/sudoers.d/tile" do
429   source "sudoers.erb"
430   owner "root"
431   group "root"
432   mode 0o440
433 end
434
435 directory "/var/lib/replicate" do
436   owner "tile"
437   group "tile"
438   mode 0o755
439 end
440
441 template "/var/lib/replicate/configuration.txt" do
442   source "replicate.configuration.erb"
443   owner "tile"
444   group "tile"
445   mode 0o644
446 end
447
448 template "/usr/local/bin/replicate" do
449   source "replicate.erb"
450   owner "root"
451   group "root"
452   mode 0o755
453 end
454
455 systemd_service "replicate" do
456   description "Rendering database replication service"
457   after "postgresql.service"
458   wants "postgresql.service"
459   user "tile"
460   exec_start "/usr/local/bin/replicate"
461   private_tmp true
462   private_devices true
463   protect_system "full"
464   protect_home true
465   restart "on-failure"
466 end
467
468 service "replicate" do
469   action [:enable, :start]
470   subscribes :restart, "template[/usr/local/bin/replicate]"
471   subscribes :restart, "systemd_service[replicate]"
472 end
473
474 template "/etc/logrotate.d/replicate" do
475   source "replicate.logrotate.erb"
476   owner "root"
477   group "root"
478   mode 0o644
479 end
480
481 template "/usr/local/bin/render-lowzoom" do
482   source "render-lowzoom.erb"
483   owner "root"
484   group "root"
485   mode 0o755
486 end
487
488 template "/etc/cron.d/render-lowzoom" do
489   source "render-lowzoom.cron.erb"
490   owner "root"
491   group "root"
492   mode 0o644
493 end
494
495 package "liblockfile-simple-perl"
496 package "libfilesys-df-perl"
497
498 template "/usr/local/bin/cleanup-tiles" do
499   source "cleanup-tiles.erb"
500   owner "root"
501   group "root"
502   mode 0o755
503 end
504
505 tile_directories = node[:tile][:styles].collect do |_, style|
506   style[:tile_directories].collect { |directory| directory[:name] }
507 end.flatten.sort.uniq
508
509 template "/etc/cron.d/cleanup-tiles" do
510   source "cleanup-tiles.cron.erb"
511   owner "root"
512   group "root"
513   mode 0o644
514   variables :directories => tile_directories
515 end
516
517 munin_plugin "mod_tile_fresh"
518 munin_plugin "mod_tile_latency"
519 munin_plugin "mod_tile_response"
520 munin_plugin "mod_tile_zoom"
521
522 munin_plugin "renderd_processed"
523 munin_plugin "renderd_queue"
524 munin_plugin "renderd_queue_time"
525 munin_plugin "renderd_zoom"
526 munin_plugin "renderd_zoom_time"
527
528 munin_plugin "replication_delay" do
529   conf "munin.erb"
530 end