X-Git-Url: https://git.openstreetmap.org./chef.git/blobdiff_plain/3a4d52bd4c0f8e6ae7679145846b7bc7845d8ace..b8a8aabcb8c98a61b0c712268eb0fc1ef1d56af7:/roles/tilecache.rb?ds=sidebyside diff --git a/roles/tilecache.rb b/roles/tilecache.rb index db78d4d76..c9badd05d 100644 --- a/roles/tilecache.rb +++ b/roles/tilecache.rb @@ -2,10 +2,35 @@ name "tilecache" description "Role applied to all tile cache servers" default_attributes( + :accounts => { + :groups => { + :proxy => { + :members => [:tomh, :grant, :matt, :jburgess] + } + } + }, :apt => { - :sources => [ "nginx" ] + :sources => ["nginx"] + }, + :networking => { + :tcp_fastopen_key => "tile" + }, + :nginx => { + :access_log => false, + :cache => { + :proxy => { + :enable => true, + :keys_zone => "proxy_cache_zone:64M", + } + } }, :sysctl => { + :sockets => { + :comment => "Increase size of connection queue", + :parameters => { + "net.core.somaxconn" => 10000 + } + }, :network_conntrack_time_wait => { :comment => "Only track completed connections for 30 seconds", :parameters => { @@ -15,19 +40,57 @@ default_attributes( :network_conntrack_max => { :comment => "Increase max number of connections tracked", :parameters => { - "net.netfilter.nf_conntrack_max" => "131072" + "net.netfilter.nf_conntrack_max" => "524288" + } + }, + :network_local_port_range => { + :comment => "Increase available local port range", + :parameters => { + "net.ipv4.ip_local_port_range" => "1024\t65535" + } + }, + :network_tcp_timewait_reuse => { + :comment => "Allow tcp timewait reuse", + :parameters => { + "net.ipv4.tcp_tw_reuse" => 1 + } + }, + :kernel_tfo_listen_enable => { + :comment => "Enable TCP Fast Open for listening sockets", + :parameters => { + "net.ipv4.tcp_fastopen" => 3 } }, :squid_swappiness => { :comment => "Prefer not to swapout to free memory", :parameters => { - "vm.swappiness" => "30" + "vm.swappiness" => "1" + } + }, + :sched_wakeup => { + :comment => "Tune scheduler", + :parameters => { + "kernel.sched_min_granularity_ns" => "10000000", + "kernel.sched_wakeup_granularity_ns" => "15000000" + } + }, + :no_tcp_slow_start => { + :comment => "REMOVE ME: Temporary Reset TCP slow start back to kernel default", + :parameters => { + "net.ipv4.tcp_slow_start_after_idle" => "1", + "net.ipv4.tcp_no_metrics_save" => "0" + } + }, + :tcp_use_bbr => { + :comment => "Use TCP BBR Congestion Control", + :parameters => { + "net.core.default_qdisc" => "fq", + "net.ipv4.tcp_congestion_control" => "bbr" } } } ) run_list( - "role[geodns]", "recipe[tilecache]" )