OpenStack Kilo : Nova 設定2015/11/12 |
OpenStack Compute Service(Nova)をインストールします。
|
|
[1] | Keystone に Nova 用のユーザー等々を登録しておきます。 |
# nova ユーザー作成 (service プロジェクト所属) [root@dlp ~]# openstack user create --project service --password servicepassword nova +------------+----------------------------------+ | Field | Value | +------------+----------------------------------+ | email | None | | enabled | True | | id | f7fce03582694a4faccc3d6af03fff07 | | name | nova | | project_id | f8d301995a9b423b85d3e250336ee6c3 | | username | nova | +------------+----------------------------------+ # nova ユーザーを admin ロール に加える [root@dlp ~]# openstack role add --project service --user nova admin +-------+----------------------------------+ | Field | Value | +-------+----------------------------------+ | id | de393fc067984d469b46bc46f156ce30 | | name | admin | +-------+----------------------------------+ # nova 用サービスエントリ作成 [root@dlp ~]# openstack service create --name nova --description "OpenStack Compute service" compute +-------------+----------------------------------+ | Field | Value | +-------------+----------------------------------+ | description | OpenStack Compute service | | enabled | True | | id | c257f00cf7f3496ea64eddccccae9c7c | | name | nova | | type | compute | +-------------+----------------------------------+ # 自ホストを定義しておく [root@dlp ~]# export controller=10.0.0.30
# nova 用エンドポイント作成 [root@dlp ~]# openstack endpoint create \ --publicurl http://$controller:8774/v2/%\(tenant_id\)s \ --internalurl http://$controller:8774/v2/%\(tenant_id\)s \ --adminurl http://$controller:8774/v2/%\(tenant_id\)s \ --region RegionOne \ compute +--------------+----------------------------------------+ | Field | Value | +--------------+----------------------------------------+ | adminurl | http://10.0.0.30:8774/v2/%(tenant_id)s | | id | 1af2c7a365de411094057106217892ae | | internalurl | http://10.0.0.30:8774/v2/%(tenant_id)s | | publicurl | http://10.0.0.30:8774/v2/%(tenant_id)s | | region | RegionOne | | service_id | c257f00cf7f3496ea64eddccccae9c7c | | service_name | nova | | service_type | compute | +--------------+----------------------------------------+ |
[2] | Nova をインストールします。 |
[root@dlp ~]# dnf -y install openstack-nova
|
[3] | Nova 用のユーザーとデータベースを MariaDB に登録しておきます。 |
[root@dlp ~]# mysql -u root -p Enter password: Welcome to the MariaDB monitor. Commands end with ; or \g. Your MariaDB connection id is 20 Server version: 10.0.20-MariaDB MariaDB Server Copyright (c) 2000, 2015, Oracle, MariaDB Corporation Ab and others. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
MariaDB [(none)]>
create database nova; Query OK, 1 row affected (0.00 sec)
MariaDB [(none)]>
grant all privileges on nova.* to nova@'localhost' identified by 'password'; Query OK, 0 rows affected (0.00 sec)
MariaDB [(none)]>
grant all privileges on nova.* to nova@'%' identified by 'password'; Query OK, 0 rows affected (0.00 sec)
MariaDB [(none)]>
MariaDB [(none)]> flush privileges; Query OK, 0 rows affected (0.00 sec) exit Bye |
[4] | Nova の基本設定です。 |
[root@dlp ~]# mv /etc/nova/nova.conf /etc/nova/nova.conf.org
[root@dlp ~]#
vi /etc/nova/nova.conf # 新規作成 [DEFAULT] # 自ホストのIP my_ip=10.0.0.30 # IPv6が不要な場合は記述 use_ipv6=false state_path=/var/lib/nova enabled_apis=ec2,osapi_compute,metadata osapi_compute_listen=0.0.0.0 osapi_compute_listen_port=8774 rootwrap_config=/etc/nova/rootwrap.conf api_paste_config=api-paste.ini auth_strategy=keystone log_dir=/var/log/nova # Memcached サーバーを指定 memcached_servers=10.0.0.30:11211 scheduler_driver=nova.scheduler.filter_scheduler.FilterScheduler notification_driver=nova.openstack.common.notifier.rpc_notifier rpc_backend=rabbit # Glance サーバーを指定 [glance] host=10.0.0.30 port=9292 protocol=http
[oslo_concurrency]
lock_path=/var/lib/nova/tmp # RabbitMQ サーバー接続情報 [oslo_messaging_rabbit] rabbit_host=10.0.0.30 rabbit_port=5672 rabbit_userid=guest rabbit_password=password # MariaDB サーバー接続情報 [database] connection=mysql://nova:password@10.0.0.30/nova # Keystone サーバー接続情報 [keystone_authtoken] auth_uri=http://10.0.0.30:5000 auth_url=http://10.0.0.30:35357 auth_plugin=password project_domain_id=default user_domain_id=default project_name=service username=nova password=servicepassword chmod 640 /etc/nova/nova.conf [root@dlp ~]# chgrp nova /etc/nova/nova.conf |
[5] | Nova ネットワーク ( nova-network ) を利用する場合のネットワーク設定です。 |
[root@dlp ~]#
vi /etc/nova/nova.conf # [DEFAULT] セクション内の適当な場所へ追記 network_driver=nova.network.linux_net libvirt_vif_driver=nova.virt.libvirt.vif.LibvirtGenericVIFDriver linuxnet_interface_driver=nova.network.linux_net.LinuxBridgeInterfaceDriver firewall_driver=nova.virt.libvirt.firewall.IptablesFirewallDriver network_api_class=nova.network.api.API security_group_api=nova network_manager=nova.network.manager.FlatDHCPManager network_size=254 allow_same_net_traffic=False multi_host=True send_arp_for_ha=True share_dhcp_address=True force_dhcp_release=True # パブリック用のインターフェース名 public_interface=eno16777736 # 適当なブリッジインターフェイス名 flat_network_bridge=br100 # フラットDHCPブリッジに使用するインターフェース名 flat_interface=dummy0 # フラットDHCPブリッジに指定したダミーインターフェースを追加して起動
[root@dlp ~]#
[root@dlp ~]# cat > /etc/sysconfig/network-scripts/ifcfg-dummy0 <<EOF
DEVICE=dummy0 BOOTPROTO=none ONBOOT=yes TYPE=Ethernet NM_CONTROLLED=no EOF echo "alias dummy0 dummy" > /etc/modprobe.d/dummy.conf [root@dlp ~]# ifup dummy0 |
[6] | Nova をサービス起動します。 レガシーネットワーク ( nova-network ) を利用しない場合は「network」を除外してください。 |
[root@dlp ~]# nova-manage db sync [root@dlp ~]# chown -R nova. /var/log/nova
[root@dlp ~]#
for service in api objectstore conductor scheduler cert consoleauth compute network; do
systemctl start openstack-nova-$service systemctl enable openstack-nova-$service done # 動作確認 [root@dlp ~]# nova-manage service list Binary Host Zone Status State Updated_At nova-conductor dlp.srv.world internal enabled :-) 2015-11-13 14:08:02 nova-scheduler dlp.srv.world internal enabled :-) 2015-11-13 14:08:03 nova-cert dlp.srv.world internal enabled :-) 2015-11-13 14:08:02 nova-consoleauth dlp.srv.world internal enabled :-) 2015-11-13 14:08:02 nova-compute dlp.srv.world nova enabled :-) 2015-11-13 14:08:04 nova-network dlp.srv.world internal enabled :-) 2015-11-13 14:08:04 |
Sponsored Link |
|