SETUP » История » Версия 7
Владимир Ипатов, 08.11.2012 00:58
| 1 | 1 | Dmitry Chernyak | h1. SETUP |
|---|---|---|---|
| 2 | 1 | Dmitry Chernyak | |
| 3 | 1 | Dmitry Chernyak | {{toc}} |
| 4 | 1 | Dmitry Chernyak | |
| 5 | 1 | Dmitry Chernyak | Ensure both nodes are up. |
| 6 | 1 | Dmitry Chernyak | |
| 7 | 1 | Dmitry Chernyak | If you planning to use the secondary network for SAN and DRBD synchronization, you |
| 8 | 1 | Dmitry Chernyak | should configure secondary IP interfaces manually on both nodes at this time. |
| 9 | 1 | Dmitry Chernyak | |
| 10 | 1 | Dmitry Chernyak | Log in to the first node via ssh. Due to lack of DNS there may be |
| 11 | 1 | Dmitry Chernyak | a minute timeout before password prompt. |
| 12 | 1 | Dmitry Chernyak | |
| 13 | 2 | Владимир Ипатов | h2. NETWORK CONFIGURATION |
| 14 | 2 | Владимир Ипатов | |
| 15 | 2 | Владимир Ипатов | Network configuration may be highly various. |
| 16 | 2 | Владимир Ипатов | Here we describe several schemas. |
| 17 | 2 | Владимир Ипатов | |
| 18 | 7 | Владимир Ипатов | h3. Basic schema - one ethernet to all. |
| 19 | 2 | Владимир Ипатов | |
| 20 | 3 | Владимир Ипатов | one ethernet, one subnet, internet connection provided by external (not in claster) router. |
| 21 | 1 | Dmitry Chernyak | By default installer create bridge named xen-br0. You can customize parameters by editing /etc/network/interfaces. |
| 22 | 7 | Владимир Ипатов | In this case you must have nodes connected to gigabit ethernet switch. |
| 23 | 3 | Владимир Ипатов | By default it looks like: |
| 24 | 3 | Владимир Ипатов | <pre> |
| 25 | 3 | Владимир Ипатов | auto xen-br0 |
| 26 | 3 | Владимир Ипатов | iface xen-br0 inet static |
| 27 | 3 | Владимир Ипатов | address 192.168.5.88 |
| 28 | 3 | Владимир Ипатов | netmask 255.255.255.0 |
| 29 | 3 | Владимир Ипатов | network 192.168.5.0 |
| 30 | 3 | Владимир Ипатов | broadcast 192.168.5.255 |
| 31 | 3 | Владимир Ипатов | gateway 192.168.5.1 |
| 32 | 3 | Владимир Ипатов | bridge_ports eth0 |
| 33 | 3 | Владимир Ипатов | bridge_stp off |
| 34 | 3 | Владимир Ипатов | bridge_fd 0 |
| 35 | 3 | Владимир Ипатов | # up ifconfig eth0 mtu 9000 |
| 36 | 3 | Владимир Ипатов | # up ifconfig xen-br0 mtu 9000 |
| 37 | 3 | Владимир Ипатов | </pre> |
| 38 | 3 | Владимир Ипатов | Important parameters besides ipv4 settings is: |
| 39 | 3 | Владимир Ипатов | bridge_ports eth0 - means that physical interface eth0 enslaved to this bridge. |
| 40 | 3 | Владимир Ипатов | |
| 41 | 3 | Владимир Ипатов | up ifconfig eth0 mtu 9000 |
| 42 | 3 | Владимир Ипатов | up ifconfig xen-br0 mtu 9000 - setting jumbo frame on bridge for more net speed and less cpu utilization. |
| 43 | 3 | Владимир Ипатов | It will be actual on interface where drbd link will be. |
| 44 | 3 | Владимир Ипатов | However, setting mtu higher than 1500 will cause problems with any network equipment that |
| 45 | 3 | Владимир Ипатов | doesn't support jumbo frames. That's the reason because it option commented out by default. |
| 46 | 3 | Владимир Ипатов | |
| 47 | 3 | Владимир Ипатов | Also it is important to specify broadcast and network adresses - it will help automatically |
| 48 | 3 | Владимир Ипатов | fullfill /etc/ganeti/networks file(a file that specify networks for instances). |
| 49 | 1 | Dmitry Chernyak | However, it ins't required. |
| 50 | 3 | Владимир Ипатов | |
| 51 | 7 | Владимир Ипатов | h3. Default schema - two ethernets, one for interlink(ganeti interoperation+drbd link) and one for lan. |
| 52 | 1 | Dmitry Chernyak | |
| 53 | 7 | Владимир Ипатов | This schema suits most cases. It doesn't required gigabit switch, provide good performance and reliability. |
| 54 | 7 | Владимир Ипатов | Two gigabit network interfaces on nodes connected directly or via gigabit switch(if you want more than two nodes in cluster). |
| 55 | 7 | Владимир Ипатов | Other interfaces connected to lan. Routing, firewalling, dhcp, dns in lan performed by external router or server. |
| 56 | 7 | Владимир Ипатов | Lan failure doesn't affect cluster in this setup. |
| 57 | 7 | Владимир Ипатов | |
| 58 | 7 | Владимир Ипатов | |
| 59 | 7 | Владимир Ипатов | h3. Mupltiple bridges with routing, firewalling and wan access. |
| 60 | 7 | Владимир Ипатов | |
| 61 | 3 | Владимир Ипатов | Here is a bit more complicated network setup. |
| 62 | 3 | Владимир Ипатов | In this setup we have, for example, two private netwokrs and wan by ethernet. All routing and firewalling |
| 63 | 7 | Владимир Ипатов | performed by separate firewall instance in our cluster. This setup fit when you don't have expensive hardware routers and firewalls. |
| 64 | 3 | Владимир Ипатов | This is /etc/network/interfaces file in this setup: |
| 65 | 3 | Владимир Ипатов | <pre> |
| 66 | 5 | Владимир Ипатов | auto lan |
| 67 | 5 | Владимир Ипатов | iface lan inet static |
| 68 | 5 | Владимир Ипатов | address 192.168.21.10 |
| 69 | 5 | Владимир Ипатов | netmask 255.255.255.0 |
| 70 | 1 | Dmitry Chernyak | bridge_ports eth0 |
| 71 | 1 | Dmitry Chernyak | bridge_stp off |
| 72 | 1 | Dmitry Chernyak | bridge_fd 0 |
| 73 | 5 | Владимир Ипатов | |
| 74 | 5 | Владимир Ипатов | auto dmz |
| 75 | 5 | Владимир Ипатов | iface dmz inet static |
| 76 | 5 | Владимир Ипатов | address 192.168.20.10 |
| 77 | 5 | Владимир Ипатов | netmask 255.255.255.0 |
| 78 | 5 | Владимир Ипатов | gateway 192.168.20.1 |
| 79 | 5 | Владимир Ипатов | bridge_ports eth1 |
| 80 | 5 | Владимир Ипатов | bridge_stp off |
| 81 | 5 | Владимир Ипатов | bridge_fd 0 |
| 82 | 5 | Владимир Ипатов | up ifconfig eth1 mtu 9000 |
| 83 | 5 | Владимир Ипатов | up ifconfig dmz mtu 9000 |
| 84 | 5 | Владимир Ипатов | |
| 85 | 5 | Владимир Ипатов | auto wan1 |
| 86 | 5 | Владимир Ипатов | iface wan1 inet manual |
| 87 | 5 | Владимир Ипатов | bridge_ports eth2 |
| 88 | 5 | Владимир Ипатов | bridge_stp off |
| 89 | 5 | Владимир Ипатов | bridge_fd 0 |
| 90 | 1 | Dmitry Chernyak | </pre> |
| 91 | 5 | Владимир Ипатов | In this example we have separate lan interfaces, dmz interface(it isn't actually dmz, |
| 92 | 5 | Владимир Ипатов | it just named this) and wan interface. dmz interface - ganeti master dev and drbd link |
| 93 | 5 | Владимир Ипатов | interfase, so there is mtu 9000. |
| 94 | 6 | Владимир Ипатов | Also in this example you must edit MASTER_NETDEV and LINK_NETDEV in /etc/sci/sci.conf from default xen-br0 to dmz. |
| 95 | 5 | Владимир Ипатов | There is no address in wan for hypervisor, although we recommend you to get subnet from |
| 96 | 5 | Владимир Ипатов | your ISP in order to assign IP addresses to nodes to management it even if router instance |
| 97 | 5 | Владимир Ипатов | is down. |
| 98 | 5 | Владимир Ипатов | |
| 99 | 5 | Владимир Ипатов | Here is an example /etc/network/interfaces in router instance: |
| 100 | 5 | Владимир Ипатов | <pre> |
| 101 | 5 | Владимир Ипатов | auto eth0 |
| 102 | 5 | Владимир Ипатов | iface eth0 inet static |
| 103 | 5 | Владимир Ипатов | address 192.168.20.1 |
| 104 | 5 | Владимир Ипатов | netmask 255.255.255.0 |
| 105 | 5 | Владимир Ипатов | |
| 106 | 5 | Владимир Ипатов | auto eth1 |
| 107 | 5 | Владимир Ипатов | iface eth1 inet static |
| 108 | 5 | Владимир Ипатов | address 192.168.21.1 |
| 109 | 5 | Владимир Ипатов | netmask 255.255.255.0 |
| 110 | 5 | Владимир Ипатов | |
| 111 | 5 | Владимир Ипатов | auto eth2 |
| 112 | 5 | Владимир Ипатов | iface eth2 inet static |
| 113 | 5 | Владимир Ипатов | address 1.1.1.2 |
| 114 | 5 | Владимир Ипатов | netmask 255.255.255.0 |
| 115 | 1 | Dmitry Chernyak | address 1.1.1.1 |
| 116 | 1 | Dmitry Chernyak | </pre> |
| 117 | 1 | Dmitry Chernyak | Where eth0 linked to bridge dmz, eth1 linked to lan, eth2 linked to wan. |
| 118 | 7 | Владимир Ипатов | |
| 119 | 7 | Владимир Ипатов | h3. Datacenter schema - separate interfaces for lan, ganeti interoperation, drbd link. |
| 120 | 7 | Владимир Ипатов | If you have powerful networking infrastructure |
| 121 | 5 | Владимир Ипатов | |
| 122 | 5 | Владимир Ипатов | h3. VLAN schema |
| 123 | 5 | Владимир Ипатов | |
| 124 | 5 | Владимир Ипатов | If you have managed switches, you can set networking with VLANs. |
| 125 | 5 | Владимир Ипатов | You should add something like this for each VLAN: |
| 126 | 5 | Владимир Ипатов | <pre> |
| 127 | 5 | Владимир Ипатов | auto eth0.55 |
| 128 | 5 | Владимир Ипатов | iface eth0.55 inet manual |
| 129 | 5 | Владимир Ипатов | up ifconfig eth0.55 up |
| 130 | 5 | Владимир Ипатов | |
| 131 | 5 | Владимир Ипатов | auto bridge-example-vlan |
| 132 | 5 | Владимир Ипатов | iface bridge-example-vlan inet manual |
| 133 | 5 | Владимир Ипатов | up brctl addbr bridge-example-vlan |
| 134 | 5 | Владимир Ипатов | up brctl addif bridge-example-vlan eth0.55 |
| 135 | 5 | Владимир Ипатов | up brctl stp bridge-example-vlan off |
| 136 | 5 | Владимир Ипатов | up ifconfig bridge-example-vlan up |
| 137 | 5 | Владимир Ипатов | down ifconfig bridge-example-vlan down |
| 138 | 5 | Владимир Ипатов | down brctl delbr bridge-example-vlan |
| 139 | 5 | Владимир Ипатов | </pre> |
| 140 | 5 | Владимир Ипатов | Where 55 - VLAN number. |
| 141 | 5 | Владимир Ипатов | In this example node don't have an ip address in this VLAN, although you could |
| 142 | 5 | Владимир Ипатов | assign an ip to bridge just like standard bridge. |
| 143 | 5 | Владимир Ипатов | |
| 144 | 5 | Владимир Ипатов | Alternative schema is: |
| 145 | 5 | Владимир Ипатов | <pre> |
| 146 | 5 | Владимир Ипатов | auto vlan55 |
| 147 | 5 | Владимир Ипатов | iface vlan55 inet manual |
| 148 | 5 | Владимир Ипатов | vlan_raw_device eth0 |
| 149 | 5 | Владимир Ипатов | |
| 150 | 5 | Владимир Ипатов | auto bridge-example-vlan |
| 151 | 5 | Владимир Ипатов | iface bridge-example-vlan inet manual |
| 152 | 5 | Владимир Ипатов | bridge_ports vlan55 |
| 153 | 5 | Владимир Ипатов | bridge_stp off |
| 154 | 5 | Владимир Ипатов | bridge_fd 0 |
| 155 | 5 | Владимир Ипатов | </pre> |
| 156 | 5 | Владимир Ипатов | It do the same, but in another way. |
| 157 | 2 | Владимир Ипатов | |
| 158 | 1 | Dmitry Chernyak | h2. DEFINING ENVIRONMENT |
| 159 | 1 | Dmitry Chernyak | |
| 160 | 1 | Dmitry Chernyak | Edit @/etc/sci/sci.conf@ |
| 161 | 1 | Dmitry Chernyak | |
| 162 | 1 | Dmitry Chernyak | * You should specify node1 and node2 data as you have installed them. |
| 163 | 1 | Dmitry Chernyak | *NOTE*: You can setup the cluster even with one node. In this case just leave NODE2_ |
| 164 | 1 | Dmitry Chernyak | lines as is. In fact this is a dangerous setup, so you will be warned about this duging |
| 165 | 1 | Dmitry Chernyak | the procedures. |
| 166 | 1 | Dmitry Chernyak | |
| 167 | 1 | Dmitry Chernyak | * You should specify the cluster's name and IP. |
| 168 | 1 | Dmitry Chernyak | |
| 169 | 1 | Dmitry Chernyak | * NODE#_SAN_IP should be specified on both nodes or none. |
| 170 | 1 | Dmitry Chernyak | |
| 171 | 1 | Dmitry Chernyak | * If you haven't Internet uplink or have a local package mirrors, you should correct |
| 172 | 1 | Dmitry Chernyak | APT_ - settings. |
| 173 | 1 | Dmitry Chernyak | |
| 174 | 1 | Dmitry Chernyak | * If you need to uplink to the DNS hierarchy other than root hint zones, specify DNS_FORWARDERS |
| 175 | 1 | Dmitry Chernyak | (note trailing ';'). |
| 176 | 6 | Владимир Ипатов | |
| 177 | 6 | Владимир Ипатов | * MASTER_NETDEV - master interface name for ganeti. By default is xen-br0 |
| 178 | 6 | Владимир Ипатов | |
| 179 | 6 | Владимир Ипатов | * LINK_NETDEV - cluster link interface name. By default is xen-br0 |
| 180 | 6 | Владимир Ипатов | |
| 181 | 6 | Владимир Ипатов | * RESERVED_VOLS - list of volumes ignored by ganeti. Comma separated. You must specify vg for all volumes in this list. |
| 182 | 6 | Владимир Ипатов | |
| 183 | 1 | Dmitry Chernyak | |
| 184 | 1 | Dmitry Chernyak | h2. SETUP CLUSTER |
| 185 | 1 | Dmitry Chernyak | |
| 186 | 1 | Dmitry Chernyak | Issue: |
| 187 | 1 | Dmitry Chernyak | |
| 188 | 1 | Dmitry Chernyak | <pre> |
| 189 | 1 | Dmitry Chernyak | # sci-setup cluster |
| 190 | 1 | Dmitry Chernyak | </pre> |
| 191 | 1 | Dmitry Chernyak | |
| 192 | 1 | Dmitry Chernyak | Check and confirm settings printed. |
| 193 | 1 | Dmitry Chernyak | |
| 194 | 1 | Dmitry Chernyak | The process will go on. |
| 195 | 1 | Dmitry Chernyak | |
| 196 | 1 | Dmitry Chernyak | Next you will be prompted to accept ssh key from node2 and for the root's password to node2. |
| 197 | 1 | Dmitry Chernyak | |
| 198 | 1 | Dmitry Chernyak | On finish you will look something like this: |
| 199 | 1 | Dmitry Chernyak | |
| 200 | 1 | Dmitry Chernyak | <pre> |
| 201 | 1 | Dmitry Chernyak | Verify |
| 202 | 1 | Dmitry Chernyak | Wed Jan 12 15:36:10 2011 * Verifying global settings |
| 203 | 1 | Dmitry Chernyak | Wed Jan 12 15:36:10 2011 * Gathering data (1 nodes) |
| 204 | 1 | Dmitry Chernyak | Wed Jan 12 15:36:11 2011 * Verifying node status |
| 205 | 1 | Dmitry Chernyak | Wed Jan 12 15:36:11 2011 * Verifying instance status |
| 206 | 1 | Dmitry Chernyak | Wed Jan 12 15:36:11 2011 * Verifying orphan volumes |
| 207 | 1 | Dmitry Chernyak | Wed Jan 12 15:36:11 2011 * Verifying orphan instances |
| 208 | 1 | Dmitry Chernyak | Wed Jan 12 15:36:11 2011 * Verifying N+1 Memory redundancy |
| 209 | 1 | Dmitry Chernyak | Wed Jan 12 15:36:11 2011 * Other Notes |
| 210 | 1 | Dmitry Chernyak | Wed Jan 12 15:36:11 2011 * Hooks Results |
| 211 | 1 | Dmitry Chernyak | Node DTotal DFree MTotal MNode MFree Pinst Sinst |
| 212 | 1 | Dmitry Chernyak | gnt1.ganeti.example.org 100.0G 100.0G 1020M 379M 625M 0 0 |
| 213 | 1 | Dmitry Chernyak | gnt2.ganeti.example.org 100.0G 100.0G 1020M 379M 625M 0 0 |
| 214 | 1 | Dmitry Chernyak | If all is ok, proceed with /usr/local/sbin/sci-setup service |
| 215 | 1 | Dmitry Chernyak | </pre> |
| 216 | 1 | Dmitry Chernyak | |
| 217 | 1 | Dmitry Chernyak | h2. SETUP SERVICE INSTANCE |
| 218 | 1 | Dmitry Chernyak | |
| 219 | 1 | Dmitry Chernyak | The service instance is named 'sci' and have a few aliases. |
| 220 | 1 | Dmitry Chernyak | On setup, it's IP address is determined from @/etc/resolv.conf@ of your first node. |
| 221 | 1 | Dmitry Chernyak | This instance will be hardcoded in @/etc/hosts@ file of all cluster nodes and instances. |
| 222 | 1 | Dmitry Chernyak | |
| 223 | 1 | Dmitry Chernyak | Issue: |
| 224 | 1 | Dmitry Chernyak | |
| 225 | 1 | Dmitry Chernyak | <pre> |
| 226 | 1 | Dmitry Chernyak | # sci-setup service |
| 227 | 1 | Dmitry Chernyak | </pre> |
| 228 | 1 | Dmitry Chernyak | |
| 229 | 1 | Dmitry Chernyak | You'll see the progress of DRBD syncing disks, then the message |
| 230 | 1 | Dmitry Chernyak | <pre> |
| 231 | 1 | Dmitry Chernyak | * running the instance OS create scripts... |
| 232 | 1 | Dmitry Chernyak | </pre> |
| 233 | 1 | Dmitry Chernyak | appears. The further may take a while. The process finishes with |
| 234 | 1 | Dmitry Chernyak | <pre> |
| 235 | 1 | Dmitry Chernyak | * starting instance... |
| 236 | 1 | Dmitry Chernyak | </pre> |
| 237 | 1 | Dmitry Chernyak | message. |
| 238 | 1 | Dmitry Chernyak | |
| 239 | 1 | Dmitry Chernyak | Now you can log on to the sci instance using: |
| 240 | 1 | Dmitry Chernyak | |
| 241 | 1 | Dmitry Chernyak | <pre> |
| 242 | 1 | Dmitry Chernyak | # gnt-instance console sci |
| 243 | 1 | Dmitry Chernyak | </pre> |
| 244 | 1 | Dmitry Chernyak | |
| 245 | 1 | Dmitry Chernyak | Log in as root, the password is empty. |
| 246 | 1 | Dmitry Chernyak | *NOTE*: Due to empty password all remote connections to new instance is prohibited. |
| 247 | 1 | Dmitry Chernyak | You should change password and install @openssh-server@ package manually after |
| 248 | 1 | Dmitry Chernyak | successful bootstrap procedure. |
| 249 | 1 | Dmitry Chernyak | |
| 250 | 1 | Dmitry Chernyak | h2. SERVICE INSTANCE BOOTSTRAP |
| 251 | 1 | Dmitry Chernyak | |
| 252 | 1 | Dmitry Chernyak | The system will setup itself via puppet. This is the iterative process. You can monitor |
| 253 | 1 | Dmitry Chernyak | it by looking into @/var/log/daemon.log@. At start there is no @less@ command yet, so |
| 254 | 1 | Dmitry Chernyak | you can use @more@, @cat@, @tail@ or @tail -f@ until @less@ will be auto-installed. |
| 255 | 1 | Dmitry Chernyak | |
| 256 | 1 | Dmitry Chernyak | By default the iterations are repeated in 20 minutes. To shorten the wait time you can |
| 257 | 1 | Dmitry Chernyak | issue |
| 258 | 1 | Dmitry Chernyak | |
| 259 | 1 | Dmitry Chernyak | <pre> |
| 260 | 1 | Dmitry Chernyak | # /etc/init.d/puppet restart |
| 261 | 1 | Dmitry Chernyak | </pre> |
| 262 | 1 | Dmitry Chernyak | |
| 263 | 1 | Dmitry Chernyak | and then look into @daemon.log@ how it finishes. |
| 264 | 1 | Dmitry Chernyak | |
| 265 | 1 | Dmitry Chernyak | Repeat this a few times until puppet will do nothing in turn. |
| 266 | 1 | Dmitry Chernyak | |
| 267 | 1 | Dmitry Chernyak | h2. PREPARING FOR NEW INSTANCES |
| 268 | 1 | Dmitry Chernyak | |
| 269 | 1 | Dmitry Chernyak | New instances are created just by regular Ganeti commands such as: |
| 270 | 1 | Dmitry Chernyak | |
| 271 | 1 | Dmitry Chernyak | <pre> |
| 272 | 1 | Dmitry Chernyak | gnt-instance add -t drbd -o debootstrap+default -s 10g -B memory=256m -n NODE1_NAME:NODE2_NAME INSTANCE_NAME |
| 273 | 1 | Dmitry Chernyak | </pre> |
| 274 | 1 | Dmitry Chernyak | |
| 275 | 1 | Dmitry Chernyak | Altought, some tuning hooks are provided by SCI-CD project: |
| 276 | 1 | Dmitry Chernyak | # Each instance has installed @puppet@ for autoconfiguration and @openssh-client@ for file transfers etc. |
| 277 | 1 | Dmitry Chernyak | # The instance uses pygrub to boot kernel from /vmlinuz & Co on the innstance's own disk. |
| 278 | 1 | Dmitry Chernyak | # The instance's network interfaces may be set up automatically as described below. |
| 279 | 1 | Dmitry Chernyak | |
| 280 | 1 | Dmitry Chernyak | h3. INSTANCE INTERFACE AUTOCONFIGURATION |
| 281 | 1 | Dmitry Chernyak | |
| 282 | 1 | Dmitry Chernyak | If your instances may sit on several networks and you need static addressing in them, you should fulfill |
| 283 | 1 | Dmitry Chernyak | the file @/etc/ganeti/networks@ with all known networks you want to attach your instances. |
| 284 | 1 | Dmitry Chernyak | Each line in the file has format |
| 285 | 1 | Dmitry Chernyak | |
| 286 | 1 | Dmitry Chernyak | |NETWORK|NETMASK|BROADCAST|GATEWAY| |
| 287 | 1 | Dmitry Chernyak | |
| 288 | 1 | Dmitry Chernyak | Ganeti instance debootstrap hook looks in this file for the network, mathing the address of bootstraped |
| 289 | 1 | Dmitry Chernyak | instance and fulfill it's @/etc/network/interfaces@ accordingly. |
| 290 | 1 | Dmitry Chernyak | |
| 291 | 1 | Dmitry Chernyak | *NOTE*: If you have only one default network, you shouldn't care because it's data are preinstalled. |
| 292 | 1 | Dmitry Chernyak | *NOTE*: networks file must be copied to all cluster nodes (not automated yet). |
| 293 | 1 | Dmitry Chernyak | |
| 294 | 1 | Dmitry Chernyak | h2. SCI OPERATIONS |
| 295 | 1 | Dmitry Chernyak | |
| 296 | 1 | Dmitry Chernyak | Read [[OPERATIONS]] next. |