]> git.openstreetmap.org Git - chef.git/blob - roles/tile.rb
Move promscale tuning to role and tune WAL sizes
[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       :external_data_script => "/srv/tile.openstreetmap.org/styles/default/scripts/get-external-data.py -c /srv/tile.openstreetmap.org/styles/default/external-data.yml",
77       :external_data_tables => %w[
78         icesheet_outlines
79         icesheet_polygons
80         ne_110m_admin_0_boundary_lines_land
81         simplified_water_polygons
82         water_polygons
83       ]
84     },
85     :styles => {
86       :default => {
87         :repository => "https://github.com/gravitystorm/openstreetmap-carto.git",
88         :revision => "v5.3.0",
89         :max_zoom => 19
90       }
91     }
92   }
93 )
94
95 run_list(
96   "recipe[tile]"
97 )