]> git.openstreetmap.org Git - chef.git/blob - roles/tile.rb
Disable parallel query on render nodes
[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         :max_parallel_workers_per_gather => "0",
42         :wal_buffers => "1024kB",
43         :wal_writer_delay => "500ms",
44         :commit_delay => "10000",
45         :checkpoint_segments => "60",
46         :max_wal_size => "2880MB",
47         :random_page_cost => "1.1",
48         :jit => "off",
49         :track_activity_query_size => "16384",
50         :autovacuum_vacuum_scale_factor => "0.05",
51         :autovacuum_analyze_scale_factor => "0.02"
52       }
53     }
54   },
55   :ssl => {
56     :ct_report_uri => false
57   },
58   :sysctl => {
59     :sockets => {
60       :comment => "Increase size of connection queue",
61       :parameters => {
62         "net.core.somaxconn" => 10000
63       }
64     },
65     :kernel_scheduler_tune => {
66       :comment => "Tune kernel scheduler preempt",
67       :parameters => {
68         "kernel.sched_min_granularity_ns" => 10000000,
69         "kernel.sched_wakeup_granularity_ns" => 15000000
70       }
71     }
72   },
73   :tile => {
74     :database => {
75       :style_file => "/srv/tile.openstreetmap.org/styles/default/openstreetmap-carto.style",
76       :tag_transform_script => "/srv/tile.openstreetmap.org/styles/default/openstreetmap-carto.lua",
77       :external_data_script => "/srv/tile.openstreetmap.org/styles/default/scripts/get-external-data.py -c /srv/tile.openstreetmap.org/styles/default/external-data.yml",
78       :external_data_tables => %w[
79         icesheet_outlines
80         icesheet_polygons
81         ne_110m_admin_0_boundary_lines_land
82         simplified_water_polygons
83         water_polygons
84       ]
85     },
86     :styles => {
87       :default => {
88         :repository => "https://github.com/gravitystorm/openstreetmap-carto.git",
89         :revision => "v5.3.1",
90         :max_zoom => 19
91       }
92     }
93   }
94 )
95
96 run_list(
97   "recipe[tile]"
98 )