| Sean Dague | e263c82 | 2014-12-05 14:25:28 -0500 | [diff] [blame] | 1 | #!/bin/bash | 
|  | 2 | # | 
| Dean Troyer | 9a532b8 | 2013-09-23 13:44:38 -0500 | [diff] [blame] | 3 | # lib/nova_plugins/hypervisor-xenserver | 
|  | 4 | # Configure the XenServer hypervisor | 
|  | 5 |  | 
|  | 6 | # Enable with: | 
|  | 7 | # VIRT_DRIVER=xenserver | 
|  | 8 |  | 
|  | 9 | # Dependencies: | 
|  | 10 | # ``functions`` file | 
|  | 11 | # ``nova`` configuration | 
|  | 12 |  | 
|  | 13 | # install_nova_hypervisor - install any external requirements | 
|  | 14 | # configure_nova_hypervisor - make configuration changes, including those to other services | 
|  | 15 | # start_nova_hypervisor - start any external services | 
|  | 16 | # stop_nova_hypervisor - stop any external services | 
|  | 17 | # cleanup_nova_hypervisor - remove transient data and cache | 
|  | 18 |  | 
|  | 19 | # Save trace setting | 
| Ian Wienand | 523f488 | 2015-10-13 11:03:03 +1100 | [diff] [blame] | 20 | _XTRACE_XENSERVER=$(set +o | grep xtrace) | 
| Dean Troyer | 9a532b8 | 2013-09-23 13:44:38 -0500 | [diff] [blame] | 21 | set +o xtrace | 
|  | 22 |  | 
|  | 23 |  | 
|  | 24 | # Defaults | 
|  | 25 | # -------- | 
|  | 26 |  | 
| Dean Troyer | 9a532b8 | 2013-09-23 13:44:38 -0500 | [diff] [blame] | 27 | # Allow ``build_domU.sh`` to specify the flat network bridge via kernel args | 
|  | 28 | FLAT_NETWORK_BRIDGE_DEFAULT=$(sed -e 's/.* flat_network_bridge=\([[:alnum:]]*\).*$/\1/g' /proc/cmdline) | 
|  | 29 | if is_service_enabled neutron; then | 
| Huan Xie | bea1e19 | 2016-04-19 07:01:30 +0100 | [diff] [blame] | 30 | XEN_INTEGRATION_BRIDGE_DEFAULT=$(sed -e 's/.* xen_integration_bridge=\([[:alnum:]]*\).*$/\1/g' /proc/cmdline) | 
|  | 31 | XEN_INTEGRATION_BRIDGE=${XEN_INTEGRATION_BRIDGE:-$XEN_INTEGRATION_BRIDGE_DEFAULT} | 
| Dean Troyer | 9a532b8 | 2013-09-23 13:44:38 -0500 | [diff] [blame] | 32 | fi | 
|  | 33 |  | 
|  | 34 | VNCSERVER_PROXYCLIENT_ADDRESS=${VNCSERVER_PROXYCLIENT_ADDRESS=169.254.0.1} | 
|  | 35 |  | 
|  | 36 |  | 
|  | 37 | # Entry Points | 
|  | 38 | # ------------ | 
|  | 39 |  | 
|  | 40 | # clean_nova_hypervisor - Clean up an installation | 
| Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 41 | function cleanup_nova_hypervisor { | 
| Dean Troyer | 9a532b8 | 2013-09-23 13:44:38 -0500 | [diff] [blame] | 42 | # This function intentionally left blank | 
|  | 43 | : | 
|  | 44 | } | 
|  | 45 |  | 
|  | 46 | # configure_nova_hypervisor - Set config files, create data dirs, etc | 
| Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 47 | function configure_nova_hypervisor { | 
| Dean Troyer | 9a532b8 | 2013-09-23 13:44:38 -0500 | [diff] [blame] | 48 | if [ -z "$XENAPI_CONNECTION_URL" ]; then | 
|  | 49 | die $LINENO "XENAPI_CONNECTION_URL is not specified" | 
|  | 50 | fi | 
|  | 51 | read_password XENAPI_PASSWORD "ENTER A PASSWORD TO USE FOR XEN." | 
|  | 52 | iniset $NOVA_CONF DEFAULT compute_driver "xenapi.XenAPIDriver" | 
| Bob Ball | 786a3a3 | 2014-06-16 08:37:05 +0100 | [diff] [blame] | 53 | iniset $NOVA_CONF xenserver connection_url "$XENAPI_CONNECTION_URL" | 
|  | 54 | iniset $NOVA_CONF xenserver connection_username "$XENAPI_USER" | 
|  | 55 | iniset $NOVA_CONF xenserver connection_password "$XENAPI_PASSWORD" | 
| Dean Troyer | 9a532b8 | 2013-09-23 13:44:38 -0500 | [diff] [blame] | 56 | iniset $NOVA_CONF DEFAULT flat_injected "False" | 
|  | 57 | # Need to avoid crash due to new firewall support | 
|  | 58 | XEN_FIREWALL_DRIVER=${XEN_FIREWALL_DRIVER:-"nova.virt.firewall.IptablesFirewallDriver"} | 
|  | 59 | iniset $NOVA_CONF DEFAULT firewall_driver "$XEN_FIREWALL_DRIVER" | 
| Mate Lakat | d15c8a0 | 2014-02-04 12:38:14 +0000 | [diff] [blame] | 60 |  | 
|  | 61 | local dom0_ip | 
|  | 62 | dom0_ip=$(echo "$XENAPI_CONNECTION_URL" | cut -d "/" -f 3-) | 
|  | 63 |  | 
|  | 64 | local ssh_dom0 | 
|  | 65 | ssh_dom0="sudo -u $DOMZERO_USER ssh -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null root@$dom0_ip" | 
|  | 66 |  | 
| Bob Ball | 348ae44 | 2014-03-20 16:56:04 +0000 | [diff] [blame] | 67 | # Find where the plugins should go in dom0 | 
|  | 68 | xen_functions=`cat $TOP_DIR/tools/xen/functions` | 
|  | 69 | PLUGIN_DIR=`$ssh_dom0 "$xen_functions; set -eux; xapi_plugin_location"` | 
|  | 70 |  | 
| Mate Lakat | d15c8a0 | 2014-02-04 12:38:14 +0000 | [diff] [blame] | 71 | # install nova plugins to dom0 | 
|  | 72 | tar -czf - -C $NOVA_DIR/plugins/xenserver/xenapi/etc/xapi.d/plugins/ ./ | | 
| Bob Ball | 348ae44 | 2014-03-20 16:56:04 +0000 | [diff] [blame] | 73 | $ssh_dom0 "tar -xzf - -C $PLUGIN_DIR && chmod a+x $PLUGIN_DIR/*" | 
| Mate Lakat | d15c8a0 | 2014-02-04 12:38:14 +0000 | [diff] [blame] | 74 |  | 
|  | 75 | # install console logrotate script | 
|  | 76 | tar -czf - -C $NOVA_DIR/tools/xenserver/ rotate_xen_guest_logs.sh | | 
|  | 77 | $ssh_dom0 'tar -xzf - -C /root/ && chmod +x /root/rotate_xen_guest_logs.sh && mkdir -p /var/log/xen/guest' | 
|  | 78 |  | 
|  | 79 | # Create a cron job that will rotate guest logs | 
|  | 80 | $ssh_dom0 crontab - << CRONTAB | 
| jianghua wang | 797668b | 2015-10-08 06:40:21 +0100 | [diff] [blame] | 81 | * * * * * /root/rotate_xen_guest_logs.sh >/dev/null 2>&1 | 
| Mate Lakat | d15c8a0 | 2014-02-04 12:38:14 +0000 | [diff] [blame] | 82 | CRONTAB | 
|  | 83 |  | 
|  | 84 | # Create directories for kernels and images | 
|  | 85 | { | 
|  | 86 | echo "set -eux" | 
|  | 87 | cat $TOP_DIR/tools/xen/functions | 
|  | 88 | echo "create_directory_for_images" | 
|  | 89 | echo "create_directory_for_kernels" | 
| Huan Xie | 26edd7b | 2016-08-08 07:23:36 +0000 | [diff] [blame] | 90 | echo "install_conntrack_tools" | 
| Mate Lakat | d15c8a0 | 2014-02-04 12:38:14 +0000 | [diff] [blame] | 91 | } | $ssh_dom0 | 
|  | 92 |  | 
| Huan Xie | f881a0e | 2016-09-27 05:57:06 +0000 | [diff] [blame] | 93 | if is_service_enabled neutron; then | 
|  | 94 | # Remove restriction on linux bridge in Dom0 when neutron is enabled | 
|  | 95 | $ssh_dom0 "rm -f /etc/modprobe.d/blacklist-bridge*" | 
| Huan Xie | 2864150 | 2016-09-20 06:49:50 +0000 | [diff] [blame] | 96 |  | 
|  | 97 | count=`$ssh_dom0 "iptables -t filter -L XenServerDevstack |wc -l"` | 
|  | 98 | if [ "$count" = "0" ]; then | 
|  | 99 | { | 
|  | 100 | echo "iptables -t filter --new XenServerDevstack" | 
|  | 101 | echo "iptables -t filter -I INPUT -j XenServerDevstack" | 
|  | 102 | echo "iptables -t filter -I XenServerDevstack -p tcp --dport 6640 -j ACCEPT" | 
|  | 103 | } | $ssh_dom0 | 
|  | 104 | fi | 
| Huan Xie | f881a0e | 2016-09-27 05:57:06 +0000 | [diff] [blame] | 105 | fi | 
| Dean Troyer | 9a532b8 | 2013-09-23 13:44:38 -0500 | [diff] [blame] | 106 | } | 
|  | 107 |  | 
|  | 108 | # install_nova_hypervisor() - Install external components | 
| Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 109 | function install_nova_hypervisor { | 
| Sean Dague | 60996b1 | 2015-04-08 09:06:49 -0400 | [diff] [blame] | 110 | pip_install_gr xenapi | 
| Dean Troyer | 9a532b8 | 2013-09-23 13:44:38 -0500 | [diff] [blame] | 111 | } | 
|  | 112 |  | 
|  | 113 | # start_nova_hypervisor - Start any required external services | 
| Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 114 | function start_nova_hypervisor { | 
| Dean Troyer | 9a532b8 | 2013-09-23 13:44:38 -0500 | [diff] [blame] | 115 | # This function intentionally left blank | 
|  | 116 | : | 
|  | 117 | } | 
|  | 118 |  | 
|  | 119 | # stop_nova_hypervisor - Stop any external services | 
| Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 120 | function stop_nova_hypervisor { | 
| Dean Troyer | 9a532b8 | 2013-09-23 13:44:38 -0500 | [diff] [blame] | 121 | # This function intentionally left blank | 
|  | 122 | : | 
|  | 123 | } | 
|  | 124 |  | 
|  | 125 |  | 
|  | 126 | # Restore xtrace | 
| Ian Wienand | 523f488 | 2015-10-13 11:03:03 +1100 | [diff] [blame] | 127 | $_XTRACE_XENSERVER | 
| Dean Troyer | 9a532b8 | 2013-09-23 13:44:38 -0500 | [diff] [blame] | 128 |  | 
|  | 129 | # Local variables: | 
|  | 130 | # mode: shell-script | 
|  | 131 | # End: |