]> git.openstreetmap.org Git - chef.git/blob - cookbooks/tile/recipes/default.rb
c26f0f88557430ee455b446942e50f61d270842e
[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 web_passwords = data_bag_item("web", "passwords")
28
29 apache_module "alias"
30 apache_module "cgi"
31 apache_module "expires"
32 apache_module "headers"
33 apache_module "remoteip"
34 apache_module "rewrite"
35
36 apache_module "tile" do
37   conf "tile.conf.erb"
38 end
39
40 tilecaches = search(:node, "roles:tilecache").sort_by { |n| n[:hostname] }
41
42 apache_site "default" do
43   action [:disable]
44 end
45
46 apache_site "tile.openstreetmap.org" do
47   template "apache.erb"
48   variables :caches => tilecaches
49 end
50
51 template "/etc/logrotate.d/apache2" do
52   source "logrotate.apache.erb"
53   owner "root"
54   group "root"
55   mode 0o644
56 end
57
58 directory "/srv/tile.openstreetmap.org" do
59   owner "tile"
60   group "tile"
61   mode 0o755
62 end
63
64 package "renderd"
65
66 systemd_service "renderd" do
67   description "Mapnik rendering daemon"
68   after "postgresql.service"
69   wants "postgresql.service"
70   user "www-data"
71   exec_start "/usr/bin/renderd -f"
72   runtime_directory "renderd"
73   standard_error "null"
74   private_tmp true
75   private_devices true
76   private_network true
77   protect_system "full"
78   protect_home true
79   no_new_privileges true
80   restart "on-failure"
81 end
82
83 service "renderd" do
84   action [:enable, :start]
85   subscribes :restart, "systemd_service[renderd]"
86 end
87
88 directory "/srv/tile.openstreetmap.org/tiles" do
89   owner "tile"
90   group "tile"
91   mode 0o755
92 end
93
94 template "/etc/renderd.conf" do
95   source "renderd.conf.erb"
96   owner "root"
97   group "root"
98   mode 0o644
99   notifies :reload, "service[apache2]"
100   notifies :restart, "service[renderd]"
101 end
102
103 remote_directory "/srv/tile.openstreetmap.org/html" do
104   source "html"
105   owner "tile"
106   group "tile"
107   mode 0o755
108   files_owner "tile"
109   files_group "tile"
110   files_mode 0o644
111 end
112
113 template "/srv/tile.openstreetmap.org/html/index.html" do
114   source "index.html.erb"
115   owner "tile"
116   group "tile"
117   mode 0o644
118 end
119
120 package "python-cairo"
121 package "python-mapnik"
122 package "python-setuptools"
123
124 easy_install_package "pyotp"
125
126 package "fonts-noto-cjk"
127 package "fonts-noto-hinted"
128 package "fonts-noto-unhinted"
129 package "ttf-unifont"
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, :totp_key => web_passwords["totp_key"]
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 systemd_service "update-lowzoom@" do
243   description "Low zoom tile update service for %i layer"
244   user "tile"
245   exec_start "/usr/local/bin/update-lowzoom-%i"
246   private_tmp true
247   private_devices true
248   private_network true
249   protect_system "full"
250   protect_home true
251   no_new_privileges true
252   restart "on-failure"
253 end
254
255 directory "/srv/tile.openstreetmap.org/styles" do
256   owner "tile"
257   group "tile"
258   mode 0o755
259 end
260
261 node[:tile][:styles].each do |name, details|
262   style_directory = "/srv/tile.openstreetmap.org/styles/#{name}"
263   tile_directory = "/srv/tile.openstreetmap.org/tiles/#{name}"
264
265   template "/usr/local/bin/update-lowzoom-#{name}" do
266     source "update-lowzoom.erb"
267     owner "root"
268     group "root"
269     mode 0o755
270     variables :style => name
271   end
272
273   service "update-lowzoom@#{name}" do
274     action :disable
275     supports :restart => true
276   end
277
278   directory tile_directory do
279     owner "tile"
280     group "tile"
281     mode 0o755
282   end
283
284   details[:tile_directories].each do |directory|
285     directory directory[:name] do
286       owner "www-data"
287       group "www-data"
288       mode 0o755
289     end
290
291     directory[:min_zoom].upto(directory[:max_zoom]) do |zoom|
292       directory "#{directory[:name]}/#{zoom}" do
293         owner "www-data"
294         group "www-data"
295         mode 0o755
296       end
297
298       link "#{tile_directory}/#{zoom}" do
299         to "#{directory[:name]}/#{zoom}"
300         owner "tile"
301         group "tile"
302       end
303     end
304   end
305
306   file "#{tile_directory}/planet-import-complete" do
307     action :create_if_missing
308     owner "tile"
309     group "tile"
310     mode 0o444
311   end
312
313   git style_directory do
314     action :sync
315     repository details[:repository]
316     revision details[:revision]
317     user "tile"
318     group "tile"
319   end
320
321   link "#{style_directory}/data" do
322     to "/srv/tile.openstreetmap.org/data"
323     owner "tile"
324     group "tile"
325   end
326
327   execute "#{style_directory}/project.mml" do
328     action :nothing
329     command "carto -a 3.0.0 project.mml > project.xml"
330     cwd style_directory
331     user "tile"
332     group "tile"
333     subscribes :run, "git[#{style_directory}]"
334     notifies :restart, "service[renderd]", :immediately
335     notifies :restart, "service[update-lowzoom@#{name}]"
336   end
337 end
338
339 postgresql_version = node[:tile][:database][:cluster].split("/").first
340
341 package "postgis"
342 package "postgresql-#{postgresql_version}-postgis-2.3"
343
344 postgresql_user "jburgess" do
345   cluster node[:tile][:database][:cluster]
346   superuser true
347 end
348
349 postgresql_user "tomh" do
350   cluster node[:tile][:database][:cluster]
351   superuser true
352 end
353
354 postgresql_user "tile" do
355   cluster node[:tile][:database][:cluster]
356 end
357
358 postgresql_user "www-data" do
359   cluster node[:tile][:database][:cluster]
360 end
361
362 postgresql_database "gis" do
363   cluster node[:tile][:database][:cluster]
364   owner "tile"
365 end
366
367 postgresql_extension "postgis" do
368   cluster node[:tile][:database][:cluster]
369   database "gis"
370 end
371
372 %w(geography_columns planet_osm_nodes planet_osm_rels planet_osm_ways raster_columns raster_overviews spatial_ref_sys).each do |table|
373   postgresql_table table do
374     cluster node[:tile][:database][:cluster]
375     database "gis"
376     owner "tile"
377     permissions "tile" => :all
378   end
379 end
380
381 %w(geometry_columns planet_osm_line planet_osm_point planet_osm_polygon planet_osm_roads).each do |table|
382   postgresql_table table do
383     cluster node[:tile][:database][:cluster]
384     database "gis"
385     owner "tile"
386     permissions "tile" => :all, "www-data" => :select
387   end
388 end
389
390 postgresql_munin "gis" do
391   cluster node[:tile][:database][:cluster]
392   database "gis"
393 end
394
395 file node[:tile][:node_file] do
396   owner "tile"
397   group "www-data"
398   mode 0o640
399 end
400
401 directory "/var/log/tile" do
402   owner "tile"
403   group "tile"
404   mode 0o755
405 end
406
407 package "osm2pgsql"
408 package "osmosis"
409
410 package "ruby"
411 package "ruby-dev"
412
413 package "libproj-dev"
414 package "libxml2-dev"
415
416 gem_package "proj4rb"
417 gem_package "libxml-ruby"
418
419 remote_directory "/usr/local/lib/site_ruby" do
420   source "ruby"
421   owner "root"
422   group "root"
423   mode 0o755
424   files_owner "root"
425   files_group "root"
426   files_mode 0o644
427 end
428
429 template "/usr/local/bin/expire-tiles" do
430   source "expire-tiles.erb"
431   owner "root"
432   group "root"
433   mode 0o755
434 end
435
436 directory "/var/lib/replicate" do
437   owner "tile"
438   group "tile"
439   mode 0o755
440 end
441
442 directory "/var/lib/replicate/expire-queue" do
443   owner "tile"
444   group "www-data"
445   mode 0o775
446 end
447
448 template "/var/lib/replicate/configuration.txt" do
449   source "replicate.configuration.erb"
450   owner "tile"
451   group "tile"
452   mode 0o644
453 end
454
455 template "/usr/local/bin/replicate" do
456   source "replicate.erb"
457   owner "root"
458   group "root"
459   mode 0o755
460 end
461
462 systemd_service "expire-tiles" do
463   description "Tile dirtying service"
464   type "simple"
465   user "www-data"
466   exec_start "/usr/local/bin/expire-tiles"
467   standard_output "null"
468   private_tmp true
469   private_devices true
470   protect_system "full"
471   protect_home true
472   no_new_privileges true
473 end
474
475 systemd_path "expire-tiles" do
476   description "Tile dirtying trigger"
477   directory_not_empty "/var/lib/replicate/expire-queue"
478 end
479
480 service "expire-tiles.path" do
481   action [:enable, :start]
482   subscribes :restart, "systemd_path[expire-tiles]"
483 end
484
485 systemd_service "replicate" do
486   description "Rendering database replication service"
487   after "postgresql.service"
488   wants "postgresql.service"
489   user "tile"
490   exec_start "/usr/local/bin/replicate"
491   private_tmp true
492   private_devices true
493   protect_system "full"
494   protect_home true
495   no_new_privileges true
496   restart "on-failure"
497 end
498
499 service "replicate" do
500   action [:enable, :start]
501   subscribes :restart, "template[/usr/local/bin/replicate]"
502   subscribes :restart, "systemd_service[replicate]"
503 end
504
505 template "/etc/logrotate.d/replicate" do
506   source "replicate.logrotate.erb"
507   owner "root"
508   group "root"
509   mode 0o644
510 end
511
512 template "/usr/local/bin/render-lowzoom" do
513   source "render-lowzoom.erb"
514   owner "root"
515   group "root"
516   mode 0o755
517 end
518
519 template "/etc/cron.d/render-lowzoom" do
520   source "render-lowzoom.cron.erb"
521   owner "root"
522   group "root"
523   mode 0o644
524 end
525
526 package "liblockfile-simple-perl"
527 package "libfilesys-df-perl"
528
529 template "/usr/local/bin/cleanup-tiles" do
530   source "cleanup-tiles.erb"
531   owner "root"
532   group "root"
533   mode 0o755
534 end
535
536 tile_directories = node[:tile][:styles].collect do |_, style|
537   style[:tile_directories].collect { |directory| directory[:name] }
538 end.flatten.sort.uniq
539
540 template "/etc/cron.d/cleanup-tiles" do
541   source "cleanup-tiles.cron.erb"
542   owner "root"
543   group "root"
544   mode 0o644
545   variables :directories => tile_directories
546 end
547
548 munin_plugin "mod_tile_fresh"
549 munin_plugin "mod_tile_latency"
550 munin_plugin "mod_tile_response"
551 munin_plugin "mod_tile_zoom"
552
553 munin_plugin "renderd_processed"
554 munin_plugin "renderd_queue"
555 munin_plugin "renderd_queue_time"
556 munin_plugin "renderd_zoom"
557 munin_plugin "renderd_zoom_time"
558
559 munin_plugin "replication_delay" do
560   conf "munin.erb"
561 end