]> git.openstreetmap.org Git - chef.git/blob - roles/nominatim.rb
50fa0f48447a66ae903032c8f10079e2c6475695
[chef.git] / roles / nominatim.rb
1 name "nominatim"
2 description "Role applied to all nominatim servers."
3
4 default_attributes(
5   :accounts => {
6     :users => {
7       :lonvia => { :status => :administrator },
8       :twain => { :status => :administrator },
9       :nominatim => {
10         :status => :role,
11         :members => [:lonvia, :tomh, :twain]
12       }
13     }
14   },
15   :apache => {
16     :mpm => "event",
17     :timeout => 30,
18     :keepalive => false,
19     :reqtimeout => true,
20     :event => {
21       :server_limit => 60,
22       :max_request_workers => 2400,
23       :threads_per_child => 50,
24       :min_spare_threads => 125,
25       :max_spare_threads => 925,
26       :async_request_worker_factor => 4
27     }
28   },
29   :apt => {
30     :sources => ["postgresql"]
31   },
32   :networking => {
33     :firewall => {
34       :http_rate_limit => "s:2/sec:15"
35     }
36   },
37   :postgresql => {
38     :settings => {
39       :defaults => {
40         :max_connections => "450",
41         :synchronous_commit => "off",
42         :checkpoint_segments => "32",
43         :checkpoint_timeout => "10min",
44         :checkpoint_completion_target => "0.9",
45         :shared_buffers => "2GB",
46         :autovacuum_max_workers => "1"
47       }
48     }
49   },
50   :sysctl => {
51     :postgres => {
52       :comment => "Increase shared memory for postgres",
53       :parameters => {
54         "kernel.shmmax" => 26 * 1024 * 1024 * 1024,
55         "kernel.shmall" => 26 * 1024 * 1024 * 1024 / 4096
56       }
57     },
58     :kernel_scheduler_tune => {
59       :comment => "Tune kernel scheduler preempt",
60       :parameters => {
61         "kernel.sched_min_granularity_ns" => 10000000,
62         "kernel.sched_wakeup_granularity_ns" => 15000000
63       }
64     },
65     :swappiness => {
66       :comment => "Reduce swap usage",
67       :parameters => {
68         "vm.swappiness" => 10
69       }
70     },
71     :network_conntrack_time_wait => {
72       :comment => "Only track completed connections for 30 seconds",
73       :parameters => {
74         "net.netfilter.nf_conntrack_tcp_timeout_time_wait" => "30"
75       }
76     },
77     :network_conntrack_max => {
78       :comment => "Increase max number of connections tracked",
79       :parameters => {
80         "net.netfilter.nf_conntrack_max" => "131072"
81       }
82     }
83   }
84 )
85
86 run_list(
87   "recipe[nominatim::default]"
88 )