xen-drbd

annotate xen-drbd-install.py @ 46:6964fb4421a5

nifix
author igor@manas.xt.vpn
date Mon Sep 29 16:09:02 2008 +0300 (2008-09-29)
parents 562d6e064e6f
children 01eb86555abb
rev   line source
igor@0 1 #!/usr/bin/python
igor@0 2
igor@37 3 import sys,re,getopt
igor@20 4 sys.path.append('/etc/xen')
igor@0 5
igor@10 6 def show_usage():
igor@10 7 print """
igor@10 8 Usage:
igor@37 9 xen-drbd-install [options] <command> (to view)
igor@37 10 xen-drbd-install [options] <command> | sh -s (to run)
igor@10 11
igor@30 12 <network> is the name of the file, which contains network description
igor@10 13
igor@10 14 Commands:
igor@10 15 make-drbd
igor@10 16 make-domains
igor@10 17 make-bridges
igor@10 18 make-links
igor@37 19
igor@37 20 Options:
igor@37 21 --help (-h) -- show usage information
igor@37 22 --network=name (-n) -- the network descriptions is in the file name.py (default: network.py)
igor@10 23 """
igor@10 24
igor@37 25
igor@37 26
igor@37 27 network='network'
igor@37 28 try:
igor@37 29 opts, args = getopt.getopt(sys.argv[1:], "hn:", ["help", "network="])
igor@37 30 except getopt.GetoptError, err:
igor@38 31 print str(err)
igor@37 32 usage()
igor@37 33 sys.exit(2)
igor@37 34
igor@37 35 for o, a in opts:
igor@37 36 if o in ("-h", "--help"):
igor@37 37 show_usage()
igor@37 38 sys.exit()
igor@37 39 elif o in ("-n", "--network"):
igor@37 40 network = a
igor@37 41 else:
igor@37 42 assert False, "unhandled option"
igor@37 43
igor@37 44 if len(args) != 1:
igor@10 45 show_usage()
igor@10 46 sys.exit(1)
igor@10 47
igor@0 48 try:
igor@39 49 execfile('/etc/xen/'+network)
igor@38 50 except IOError:
igor@38 51 print "Network configuration file <%s> not found " % network
igor@38 52 if network == 'network':
igor@38 53 print "You can use -n option to specify network filename"
igor@38 54 sys.exit(2)
igor@38 55 except NameError:
igor@38 56 domain=domains[0]
igor@38 57 execfile(network)
igor@0 58
igor@37 59
igor@0 60 drbd_base_port=7790
igor@0 61 meta_disk='/dev/%s/meta'%lvm_vg_name
igor@2 62 drbd_device={}
igor@0 63
igor@33 64 linux_domains=[]
igor@33 65 for dom in domains:
igor@33 66 if domain_types[domains.index(dom)] == 'linux':
igor@33 67 linux_domains.append(dom)
igor@33 68
igor@2 69 def make_drbd_hash():
igor@2 70 for dom in domains:
igor@2 71 for disk in disk_table[dom]:
igor@2 72 if disk.find(":") == -1:
igor@36 73 if disk.find("=") == -1:
igor@36 74 drbd_device[disk]=dom
igor@36 75 else:
igor@36 76 drbd_device[disk.split('=')[0]]=dom
igor@2 77 else:
igor@36 78 disk0=disk.split(':')[0]
igor@36 79 drbd_device[disk0.split('=')[0]]=disk.split(':')[1]
igor@2 80
igor@2 81 def make_lvm():
igor@9 82 print "###################################################"
igor@9 83 print "# MAKE LVM FOR DOMAINS DRBD DEVICES"
igor@9 84 print "#"
igor@9 85 for lvm_pv_name in re.compile('\s+').split(lvm_pv_names):
igor@9 86 print "pvcreate %s" % (lvm_pv_name)
igor@9 87 print "vgcreate /dev/%s %s" % (lvm_vg_name, lvm_pv_names)
igor@9 88 print "lvcreate -L %s -n %s /dev/%s" % (lvm_lv_drbd_meta_size, lvm_lv_drbd_meta_name, lvm_vg_name)
igor@33 89 for dom in linux_domains:
igor@2 90 for disk in disk_table[dom]:
igor@2 91 if disk.find(":") == -1:
igor@2 92 #if do_print:
igor@2 93 # print "lvcreate -L %s -n %s /dev/%s" % (disk, dom, lvm_vg_name)
igor@2 94 #drbd_devices.append([dom, "/dev/%s/%s" % (lvm_vg_name, dom)])
igor@2 95 drbd_device[disk]=dom
igor@2 96 else:
igor@2 97 drbd_device[disk.split(':')[0]]=disk.split(':')[0]
igor@12 98 print "lvcreate -L %s -n %s /dev/%s" % (disk.split(':')[2], disk.split(':')[1], lvm_vg_name)
igor@9 99 #drbd_devices.append([disk.split(':')[0], "/dev/%s/%s" % (lvm_vg_name, disk.split(':')[0])])
igor@9 100 print ""
igor@0 101
igor@0 102
igor@0 103 def make_drbdconf():
igor@9 104 print "###################################################"
igor@9 105 print "# MAKE DRBD CONFIG FILE /etc/drbd.conf"
igor@9 106 print "#"
igor@9 107
igor@2 108 print "cat <<DRBD > /etc/drbd.conf"
igor@9 109
igor@9 110
igor@9 111 for dom in domains:
igor@9 112 for disk in disk_table[dom]:
igor@37 113 drbd_number=int(re.compile('drbd').sub('',(disk.split(':')[0]).split('=')[0] ))
igor@9 114 resource=disk.split(':')[1]
igor@9 115 disk="/dev/%s/%s" % (lvm_vg_name,resource)
igor@9 116
igor@9 117 print """
igor@0 118 resource %s {
igor@2 119 protocol C;
igor@2 120 net {
igor@2 121 allow-two-primaries;
igor@2 122 after-sb-0pri discard-least-changes;
igor@2 123 after-sb-1pri call-pri-lost-after-sb;
igor@2 124 after-sb-2pri call-pri-lost-after-sb;
igor@2 125 }
igor@2 126 syncer {
igor@2 127 rate 5M;
igor@2 128 }
igor@2 129 on %s
igor@2 130 {
igor@2 131 device /dev/drbd%s;
igor@2 132 disk %s;
igor@2 133 address %s:%s;
igor@2 134 meta-disk %s[%s];
igor@2 135 }
igor@2 136 on %s
igor@2 137 {
igor@2 138 device /dev/drbd%s;
igor@2 139 disk %s;
igor@2 140 address %s:%s;
igor@2 141 meta-disk %s[%s];
igor@2 142 }
igor@0 143 }
igor@0 144
igor@9 145 """ % (resource, node1, drbd_number, disk, node1_ip, drbd_number+drbd_base_port, meta_disk, drbd_number, node2, drbd_number, disk, node2_ip, drbd_number+drbd_base_port, meta_disk, drbd_number )
igor@9 146 print "DRBD"
igor@9 147 print ""
igor@9 148
igor@9 149
igor@9 150 def make_drbdmeta():
igor@9 151 print "###################################################"
igor@9 152 print "# MAKE DRBD DEVICES "
igor@9 153 print "#"
igor@13 154 print "yes yes | drbdadm create-md all"
igor@9 155
igor@9 156 def make_drbdprimary():
igor@9 157 print "###################################################"
igor@9 158 print "# SET DRBD DEVICES PRIMARY "
igor@9 159 print "#"
igor@9 160
igor@9 161 print "drbdadm up all"
igor@9 162 for dom in domains:
igor@9 163 for disk in disk_table[dom]:
igor@9 164 print "drbdsetup %s primary -o" % disk.split(':')[0]
igor@0 165
igor@0 166
igor@2 167 def make_links():
igor@2 168
igor@9 169 print "###################################################"
igor@9 170 print "# MAKE SYMBOLIC LINKS TO /dev/drbd* FILES"
igor@9 171 print "#"
igor@2 172
igor@2 173 # drbd_devices={
igor@2 174 # 'dev' : 'resource',
igor@2 175 # }
igor@2 176
igor@2 177 make_drbd_hash()
igor@2 178 print "mkdir -p /dev/drbd"
igor@2 179 for dev in drbd_device.keys():
igor@2 180 resource=drbd_device[dev]
igor@2 181 print "ln -sf /dev/%s /dev/drbd/%s" %(dev, resource)
igor@0 182
igor@0 183 def make_fs():
igor@9 184
igor@9 185 print "###################################################"
igor@9 186 print "# MAKE FILESYSTEMS ON THE DRBDs"
igor@9 187 print "#"
igor@9 188
igor@9 189 for dev in drbd_device.keys():
igor@9 190 print "mkfs.ext3 %s /dev/%s" %(mkfs_options,dev)
igor@0 191
igor@0 192
igor@0 193 def make_mount():
igor@9 194 print "###################################################"
igor@9 195 print "# MOUNT U-DOMAINS FILESYSTEMS"
igor@9 196 print "#"
igor@9 197
igor@2 198 print "mkdir -p /domU"
igor@33 199 for dom in linux_domains:
igor@2 200 print "mkdir -p /domU/%s" % (dom)
igor@2 201 print "mount /dev/drbd/%s /domU/%s" % (dom,dom)
igor@0 202
igor@0 203 def make_umount():
igor@33 204 for dom in linux_domains:
igor@2 205 print "umount /domU/%s" % (dom)
igor@0 206
igor@0 207 def make_dns():
igor@2 208 i=1
igor@33 209 for dom in linux_domains:
igor@2 210 print "%s A %s.%s" % (dom, ip_network, i)
igor@2 211 i+=1
igor@0 212
igor@0 213 def make_dns_reverse():
igor@2 214 i=1
igor@33 215 for dom in linux_domains:
igor@2 216 print "%s A %s.%s." % (i, dom, domain_name)
igor@2 217 i+=1
igor@0 218
igor@0 219 def make_install_debian():
igor@2 220 print """
igor@43 221 apt-get install debootstrap lsof
igor@0 222 debootstrap %s /domU/%s %s
igor@0 223 chroot /domU/%s apt-get install -y --force-yes %s
igor@43 224 kill $(lsof +D /domU/%s | grep -v PID | awk '{print $2}' | sort -u) 2> /dev/null
igor@43 225 sleep 2
igor@43 226 kill -9 $(lsof +D /domU/%s | grep -v PID | awk '{print $2}' | sort -u) 2> /dev/null
igor@44 227 """ % (debian_release,linux_domains[0],debian_mirror,linux_domains[0],apt_get_install,linux_domains[0],linux_domains[0])
igor@0 228
igor@0 229 def make_rsync():
igor@44 230 for dom in linux_domains[1:]:
igor@2 231 print """
igor@0 232 rsync -a /domU/%s/ /domU/%s/
igor@44 233 """ % (linux_domains[0], dom)
igor@0 234
igor@43 235
igor@43 236 def make_install_packages():
igor@44 237 for dom in linux_domains:
igor@43 238 try:
igor@43 239 print """
igor@43 240 chroot /domU/%s apt-get install -y --force-yes %s
igor@43 241 kill $(lsof +D /domU/%s | grep -v PID | awk '{print $2}' | sort -u) 2> /dev/null
igor@43 242 sleep 2
igor@43 243 kill -9 $(lsof +D /domU/%s | grep -v PID | awk '{print $2}' | sort -u) 2> /dev/null
igor@43 244 """ % (dom,apt_get_install_table[dom],dom,dom)
igor@43 245 except:
igor@43 246 pass
igor@43 247
igor@0 248 def make_etcfstab():
igor@2 249 i=0
igor@33 250 for dom in linux_domains:
igor@2 251 i+=1
igor@2 252 print """
igor@0 253 cat <<FSTAB > /domU/%s/etc/fstab
igor@0 254 proc /proc proc defaults 0 0
igor@0 255 /dev/hda1 / ext3 defaults,errors=remount-ro 0 1
igor@0 256 FSTAB
igor@2 257 """ % (dom)
igor@0 258
igor@0 259 def make_etcnetworkinterfaces():
igor@2 260 i=0
igor@33 261 for dom in linux_domains:
igor@2 262 i+=1
igor@2 263 print """
igor@0 264 cat <<INTERFACES > /domU/%s/etc/network/interfaces
igor@0 265 auto lo eth0
igor@0 266 iface lo inet loopback
igor@0 267
igor@0 268 iface eth0 inet static
igor@9 269 address %s
igor@0 270 netmask 255.255.255.0
igor@0 271 network %s.0
igor@0 272 broadcast %s.255
igor@0 273 gateway %s
igor@0 274 dns-nameservers %s
igor@0 275 dns-search %s
igor@0 276 INTERFACES
igor@9 277 """ % (dom,ip_address_table[dom],ip_network, ip_network, ip_gateway, domain_name, ip_nameserver)
igor@0 278
igor@0 279 def make_etcresolvconf():
igor@33 280 for dom in linux_domains:
igor@2 281 print """
igor@0 282 cat <<RESOLVCONF > /domU/%s/etc/resolv.conf
igor@0 283 search %s
igor@0 284 nameserver %s
igor@0 285 RESOLVCONF
igor@2 286 """ % (dom,domain_name,ip_nameserver)
igor@0 287
igor@0 288 def make_etchostname():
igor@33 289 for dom in linux_domains:
igor@2 290 print """
igor@0 291 cat <<HOSTNAME > /domU/%s/etc/hostname
igor@0 292 %s
igor@0 293 HOSTNAME
igor@2 294 """ % (dom,dom)
igor@0 295
igor@0 296
igor@0 297 def make_etchosts():
igor@2 298 i=0
igor@33 299 for dom in linux_domains:
igor@2 300 i+=1
igor@2 301 print """
igor@0 302 cat <<HOSTS > /domU/%s/etc/hosts
igor@0 303 127.0.0.1 localhost
igor@9 304 %s %s.%s %s
igor@0 305
igor@0 306 ::1 ip6-localhost ip6-loopback
igor@0 307 fe00::0 ip6-localnet
igor@0 308 ff00::0 ip6-mcastprefix
igor@0 309 ff02::1 ip6-allnodes
igor@0 310 ff02::2 ip6-allrouters
igor@0 311 ff02::3 ip6-allhosts
igor@0 312 HOSTS
igor@9 313 """ % (dom,ip_address_table[dom],dom,domain_name,dom)
igor@0 314
igor@0 315 def make_rootssh():
igor@33 316 for dom in linux_domains:
igor@2 317 print """
igor@14 318 mkdir -p /domU/%s/home/eb/.ssh/
igor@14 319 chown -R 1000:1000 /domU/%s/home/eb
igor@0 320 cp ~/.ssh/id_dsa.pub /domU/%s/root/.ssh/authorized_keys
igor@14 321 chmod 600 /domU/%s/home/eb/.ssh/authorized_keys
igor@16 322 """ % (dom,dom,dom,dom)
igor@0 323
igor@0 324 def make_l3rc():
igor@33 325 for dom in linux_domains:
igor@2 326 print """
igor@2 327 cat <<EOF > /domU/%s/root/.l3rc
igor@0 328 l3cd=/users/igor/xen-drbd-dom0-setup/%s.%s/root
igor@0 329 EOF
igor@2 330 """ % (dom,dom,domain_name)
igor@0 331
igor@0 332
igor@0 333 def make_etc():
igor@2 334 make_etcfstab()
igor@2 335 make_etcnetworkinterfaces()
igor@2 336 make_etcresolvconf()
igor@2 337 make_etchosts()
igor@2 338 make_etchostname()
igor@2 339 make_rootssh()
igor@15 340 #make_l3rc()
igor@0 341
igor@9 342 def make_drbd():
igor@9 343 make_lvm()
igor@9 344 make_drbdconf()
igor@9 345 make_drbdmeta()
igor@9 346
igor@9 347 def make_domains():
igor@9 348 make_drbdprimary()
igor@9 349 make_links()
igor@2 350 make_fs()
igor@2 351 make_mount()
igor@2 352 make_install_debian()
igor@2 353 make_rsync()
igor@43 354 make_install_packages()
igor@2 355 make_etc()
igor@2 356 make_umount()
igor@0 357
igor@0 358 def get_management_ip():
igor@2 359 return management_ip
igor@0 360
igor@0 361 def get_default_gateway():
igor@2 362 return management_gw
igor@0 363
igor@0 364 def make_bridges():
igor@2 365 ip=get_management_ip()
igor@2 366 gw=get_default_gateway()
igor@21 367 print "ifconfig %s 0.0.0.0 down" % (trunk)
igor@2 368
igor@2 369 # tagged interfaces
igor@2 370 for bridge in bridges:
igor@2 371 vlan=vlans[bridges.index(bridge)]
igor@2 372 if vlan == 'tagged':
igor@2 373 print "/etc/xen/scripts/network-bridge start vifnum=%s bridge=%s netdev=%s" % (bridges.index(bridge)+2,bridge,trunk)
igor@2 374 print "ip link set %s up" % (trunk)
igor@2 375
igor@2 376 # untagged interfaces
igor@2 377 for bridge in bridges:
igor@2 378 vlan=vlans[bridges.index(bridge)]
igor@2 379 if vlan != 'tagged':
igor@2 380 print "vconfig add %s %s" % (trunk,vlan)
igor@2 381 print "/etc/xen/scripts/network-bridge start vifnum=%s bridge=%s netdev=%s.%s" % (bridges.index(bridge)+2,bridge,trunk,vlan)
igor@2 382 print "ip link set %s.%s up" % (trunk,vlan)
igor@2 383
igor@22 384 print "ifconfig %s.%s %s netmask %s" % (trunk,management_vlan,management_ip,management_netmask)
igor@2 385 if management_gw:
igor@2 386 print "route add default gw %s" % (management_gw)
igor@0 387
igor@0 388
igor@0 389
igor@0 390 #make_all_system()
igor@0 391
igor@37 392 if len(args) > 0:
igor@37 393 command = args[0]
igor@9 394 if command == 'make-drbd':
igor@9 395 make_drbd()
igor@9 396 elif command == 'make-domains':
igor@9 397 make_domains()
igor@9 398 elif command == 'make-bridges':
igor@2 399 make_bridges()
igor@2 400 elif command == 'make-links':
igor@2 401 make_links()
igor@2 402 else:
igor@2 403 show_usage()
igor@0 404 else:
igor@2 405 show_usage()
igor@0 406