]> git.openstreetmap.org Git - chef.git/blobdiff - roles/ironbelly.rb
Add alert rule for nominatim replication delay
[chef.git] / roles / ironbelly.rb
index e06df5b2f295acbc32463e3cde7b7e4a061aacdd..6c9157852c5a9a68eae80b128d20749cf24e567b 100644 (file)
@@ -2,30 +2,113 @@ name "ironbelly"
 description "Master role applied to ironbelly"
 
 default_attributes(
 description "Master role applied to ironbelly"
 
 default_attributes(
+  :bind => {
+    :clients => "equinix-ams"
+  },
+  :dhcpd => {
+    :first_address => "10.0.63.1",
+    :last_address => "10.0.63.254"
+  },
+  :elasticsearch => {
+    :cluster => {
+      :routing => {
+        :allocation => {
+          :disk => {
+            :watermark => {
+              :low => "95%",
+              :high => "98%",
+              :flood_stage => "99%"
+            }
+          }
+        }
+      }
+    },
+    :path => {
+      :data => "/store/elasticsearch"
+    }
+  },
   :networking => {
     :interfaces => {
   :networking => {
     :interfaces => {
+      :internal_ipv4 => {
+        :interface => "bond0",
+        :role => :internal,
+        :family => :inet,
+        :address => "10.0.48.10",
+        :bond => {
+          :mode => "802.3ad",
+          :lacprate => "fast",
+          :xmithashpolicy => "layer3+4",
+          :slaves => %w[eth0 eth1]
+        }
+      },
       :external_ipv4 => {
       :external_ipv4 => {
-        :interface => "eth0",
+        :interface => "bond0.2",
         :role => :external,
         :family => :inet,
         :role => :external,
         :family => :inet,
-        :address => ""
+        :address => "130.117.76.10"
       },
       :external_ipv6 => {
       },
       :external_ipv6 => {
-        :interface => "eth0",
+        :interface => "bond0.2",
         :role => :external,
         :family => :inet6,
         :role => :external,
         :family => :inet6,
-        :address => ""
-      },
-      :internal_ipv4 => {
-        :interface => "eth1",
-        :role => :internal,
-        :family => :inet,
-        :address => ""
+        :address => "2001:978:2:2C::172:A"
+      }
+    }
+  },
+  :planet => {
+    :replication => "enabled"
+  },
+  :prometheus => {
+    :snmp => {
+      "pdu1" => { :address => "10.0.48.100", :modules => %w[apcups], :labels => { "site" => "amsterdam" } },
+      "pdu2" => { :address => "10.0.48.101", :modules => %w[apcups], :labels => { "site" => "amsterdam" } },
+      "switch1" => { :address => "130.117.76.4", :modules => %w[if_mib juniper_ex4300], :labels => { "site" => "amsterdam" } }
+    },
+    :metrics => {
+      :uplink_interface => {
+        :help => "Site uplink interface name",
+        :labels => { :site => "amsterdam", :name => "ge-[01]/2/0" }
+      }
+    }
+  },
+  :rsyncd => {
+    :modules => {
+      :logs => {
+        :comment => "Log files",
+        :path => "/store/logs",
+        :read_only => false,
+        :write_only => true,
+        :list => false,
+        :uid => "www-data",
+        :gid => "www-data",
+        :transfer_logging => false,
+        :hosts_allow => [
+          "193.60.236.0/24",          # ucl external
+          "10.0.48.0/20",             # amsterdam internal
+          "130.117.76.0/27",          # amsterdam external
+          "2001:978:2:2C::172:0/112", # amsterdam external
+          "10.0.64.0/20",             # dublin internal
+          "184.104.226.96/27",        # dublin external
+          "2001:470:1:b3b::/64",      # dublin external
+          "10.0.32.0/20",             # bytemark internal
+          "89.16.162.16/28",          # bytemark external
+          "2001:41c9:2:d6::/64",      # bytemark external
+          "127.0.0.0/8",              # localhost
+          "::1"                       # localhost
+        ]
       }
     }
   }
       }
     }
   }
-);
+)
 
 run_list(
 
 run_list(
-  "role[ic]"
+  "role[equinix-ams]",
+  "role[gateway]",
+  "role[supybot]",
+  "role[backup]",
+  "role[planet]",
+  "role[planetdump]",
+  "recipe[rsyncd]",
+  "recipe[dhcpd]",
+  "recipe[tilelog]"
 )
 )