]> git.openstreetmap.org Git - chef.git/blob - roles/tile.rb
Report database size and replication delay for postgres
[chef.git] / roles / tile.rb
1 name "tile"
2 description "Role applied to all tile servers"
3
4 default_attributes(
5   :accounts => {
6     :users => {
7       :tile => {
8         :members => [:jburgess, :tomh]
9       }
10     }
11   },
12   :apache => {
13     :mpm => "event",
14     :timeout => 60,
15     :event => {
16       :server_limit => 60,
17       :max_request_workers => 1200,
18       :threads_per_child => 20,
19       :min_spare_threads => 300,
20       :max_spare_threads => 1200,
21       :max_connections_per_child => 0,
22       :async_request_worker_factor => 4,
23       :listen_cores_buckets_ratio => 6
24     }
25   },
26   :munin => {
27     :plugins => {
28       :renderd_processed => {
29         :graph_order => "reqPrio req reqLow dirty reqBulk dropped",
30         :reqPrio => { :draw => "AREA" },
31         :req => { :draw => "STACK" }
32       }
33     }
34   },
35   :postgresql => {
36     :settings => {
37       :defaults => {
38         :max_connections => "250",
39         :temp_buffers => "32MB",
40         :work_mem => "128MB",
41         :wal_buffers => "1024kB",
42         :wal_writer_delay => "500ms",
43         :commit_delay => "10000",
44         :checkpoint_segments => "60",
45         :max_wal_size => "2880MB",
46         :random_page_cost => "1.1",
47         :jit => "off",
48         :track_activity_query_size => "16384",
49         :autovacuum_vacuum_scale_factor => "0.05",
50         :autovacuum_analyze_scale_factor => "0.02"
51       }
52     }
53   },
54   :ssl => {
55     :ct_report_uri => false
56   },
57   :sysctl => {
58     :sockets => {
59       :comment => "Increase size of connection queue",
60       :parameters => {
61         "net.core.somaxconn" => 10000
62       }
63     },
64     :kernel_scheduler_tune => {
65       :comment => "Tune kernel scheduler preempt",
66       :parameters => {
67         "kernel.sched_min_granularity_ns" => 10000000,
68         "kernel.sched_wakeup_granularity_ns" => 15000000
69       }
70     }
71   },
72   :tile => {
73     :database => {
74       :style_file => "/srv/tile.openstreetmap.org/styles/default/openstreetmap-carto.style",
75       :tag_transform_script => "/srv/tile.openstreetmap.org/styles/default/openstreetmap-carto.lua"
76     },
77     :data => {
78       :simplified_land_polygons => {
79         :url => "https://osmdata.openstreetmap.de/download/simplified-land-polygons-complete-3857.zip",
80         :refresh => true
81       },
82       :simplified_water_polygons => {
83         :url => "https://osmdata.openstreetmap.de/download/simplified-water-polygons-split-3857.zip",
84         :refresh => true
85       },
86       :admin_boundaries => {
87         :url => "http://www.naturalearthdata.com/http//www.naturalearthdata.com/download/110m/cultural/ne_110m_admin_0_boundary_lines_land.zip",
88         :directory => "ne_110m_admin_0_boundary_lines_land"
89       },
90       :land_polygons => {
91         :url => "https://osmdata.openstreetmap.de/download/land-polygons-split-3857.zip",
92         :refresh => true
93       },
94       :water_polygons => {
95         :url => "https://osmdata.openstreetmap.de/download/water-polygons-split-3857.zip",
96         :refresh => true
97       },
98       :antarctica_icesheet_polygons => {
99         :url => "https://osmdata.openstreetmap.de/download/antarctica-icesheet-polygons-3857.zip",
100         :refresh => true
101       },
102       :antarctica_icesheet_outlines => {
103         :url => "https://osmdata.openstreetmap.de/download/antarctica-icesheet-outlines-3857.zip",
104         :refresh => true
105       }
106     },
107     :styles => {
108       :default => {
109         :repository => "https://github.com/gravitystorm/openstreetmap-carto.git",
110         :revision => "v5.2.0",
111         :max_zoom => 19
112       }
113     }
114   }
115 )
116
117 run_list(
118   "recipe[tile]"
119 )