安装Nova

[root@linux-node1 src]# cd ~

[root@linux-node1 ~]# cd /usr/local/src/nova-2014.1

[root@linux-node1 nova-2014.1]# python setup.py install

[root@linux-node1 nova]# pwd

/usr/local/src/nova-2014.1/etc/nova

[root@linux-node1 nova]# ll

总用量 48

-rw-rw-r-- 1 1004 1004  3120 4月  17 17:47 api-paste.ini

-rw-rw-r-- 1 1004 1004   723 4月  17 17:47 cells.json

-rw-rw-r-- 1 1004 1004  1346 4月  17 17:47 logging_sample.conf

-rw-rw-r-- 1 1004 1004 16750 4月  17 17:47 policy.json

-rw-rw-r-- 1 1004 1004   124 4月  17 17:47 README-nova.conf.txt

-rw-rw-r-- 1 1004 1004    73 4月  17 17:47 release.sample

-rw-rw-r-- 1 1004 1004   934 4月  17 17:47 rootwrap.conf

drwxrwxr-x 2 1004 1004  4096 4月  17 17:56 rootwrap.d

[root@linux-node1 nova]# mkdir /etc/nova

[root@linux-node1 nova]# mkdir /var/log/nova

[root@linux-node1 nova]# mkdir /var/lib/nova

[root@linux-node1 nova]# mkdir /var/run/nova

[root@linux-node1 nova]# mkdir /var/lib/nova/instances

[root@linux-node1 nova]# cp -r * /etc/nova/

[root@linux-node1 nova]# cd /etc/nova/

上传一个Nova的配置文件,配置文件件附件nova20148191418.conf

[root@linux-node1 nova]# ll

总用量 48

-rw-r--r-- 1 root root  3120 8月  19 05:25 api-paste.ini

-rw-r--r-- 1 root root   723 8月  19 05:25 cells.json

-rw-r--r-- 1 root root  1346 8月  19 05:25 logging_sample.conf

-rw-r--r-- 1 root root 16750 8月  19 05:25 policy.json

-rw-r--r-- 1 root root   124 8月  19 05:25 README-nova.conf.txt

-rw-r--r-- 1 root root    73 8月  19 05:25 release.sample

-rw-r--r-- 1 root root   934 8月  19 05:25 rootwrap.conf

drwxr-xr-x 2 root root  4096 8月  19 05:25 rootwrap.d

[root@linux-node1 nova]# rz 

z waiting to receive.**B0100000023be50

[root@linux-node1 nova]# ll

总用量 148

-rw-r--r-- 1 root root  3120 8月  19 05:25 api-paste.ini

-rw-r--r-- 1 root root   723 8月  19 05:25 cells.json

-rw-r--r-- 1 root root  1346 8月  19 05:25 logging_sample.conf

-rw-r--r-- 1 root root 99091 8月  19 2014 nova.conf

-rw-r--r-- 1 root root 16750 8月  19 05:25 policy.json

-rw-r--r-- 1 root root   124 8月  19 05:25 README-nova.conf.txt

-rw-r--r-- 1 root root    73 8月  19 05:25 release.sample

-rw-r--r-- 1 root root   934 8月  19 05:25 rootwrap.conf

drwxr-xr-x 2 root root  4096 8月  19 05:25 rootwrap.d

[root@linux-node1 nova]# mv logging_sample.conf logging.conf 

[root@linux-node1 ~]# keystone service-create --name=nova --type=compute --description="Openstack Compute"

+-------------+----------------------------------+

|   Property  |              Value               |

+-------------+----------------------------------+

| description |        Openstack Compute         |

|   enabled   |               True               |

|      id     | 95b294a2be074f548baedbd5744c518f |

|     name    |               nova               |

|     type    |             compute              |

+-------------+----------------------------------+

批量替换更改配置文件

:%s/192.168.1.1/192.168.33.11/g

connection=mysql://nova:nova@192.168.33.11/nova

rabbit_host=192.168.33.11

# The RabbitMQ broker port where a single node is used.

# (integer value)

rabbit_port=5672

# RabbitMQ HA cluster host:port pairs. (list value)

rabbit_hosts=$rabbit_host:$rabbit_port

# Connect over SSL for RabbitMQ. (boolean value)

rabbit_use_ssl=false

# The RabbitMQ userid. (string value)

rabbit_userid=guest

# The RabbitMQ password. (string value)

rabbit_password=guest

# The strategy to use for auth: noauth or keystone. (string

# value)

auth_strategy=keystone

# Host providing the admin Identity API endpoint (string

# value)

auth_host=192.168.33.11

# Port of the admin Identity API endpoint (integer value)

auth_port=35357

# Protocol of the admin Identity API endpoint(http or https)

# (string value)

auth_protocol=http

# Complete public Identity API endpoint (string value)

auth_uri=http://192.168.33.11:5000

# API version of the admin Identity API endpoint (string

# value)

auth_version=v2.0

# Keystone account username (string value)

admin_user=admin

# Keystone account password (string value)

admin_password=admin

# Keystone service account tenant name to validate user tokens

# (string value)

admin_tenant_name=admin

[root@linux-node1 nova]# grep '^[a-z]' /etc/nova/nova.conf 

rabbit_host=192.168.33.11

rabbit_port=5672

rabbit_hosts=$rabbit_host:$rabbit_port

rabbit_use_ssl=false

rabbit_userid=guest

rabbit_password=guest

rabbit_virtual_host=/

rpc_backend=rabbit

my_ip=192.168.33.11

state_path=/var/lib/nova

auth_strategy=keystone

instances_path=$state_path/instances

network_api_class=nova.network.neutronv2.api.API

linuxnet_interface_driver=nova.network.linux_net.LinuxBridgeInterfaceDriver

neutron_url=http://192.168.33.11:9696

neutron_admin_username=neutron

neutron_admin_password=neutron

neutron_admin_tenant_name=service

neutron_admin_auth_url=http://192.168.33.11:5000/v2.0

neutron_auth_strategy=keystone

security_group_api=neutron

lock_path=/var/lib/nova/tmp

debug=true

resize_fs_using_block_device=false

compute_driver=libvirt.LibvirtDriver

use_cow_p_w_picpaths=false

vnc_enabled=false

volume_api_class=nova.volume.cinder.API

connection=mysql://nova:nova@192.168.33.11/nova

auth_host=192.168.33.11

auth_port=35357

auth_protocol=http

auth_uri=http://192.168.33.11:5000

auth_version=v2.0

admin_user=admin

admin_password=admin

admin_tenant_name=admin

virt_type=qemu

vif_driver=nova.virt.libvirt.vif.NeutronLinuxBridgeVIFDriver

同步Nova的数据库

[root@linux-node1 ~]# nova-manage db sync

查看一下数据库

[root@linux-node1 ~]# mysql -h 192.168.33.11 -unova -pnova -e"use nova;show tables;"

+--------------------------------------------+

| Tables_in_nova                             |

+--------------------------------------------+

| agent_builds                               |

| aggregate_hosts                            |

| aggregate_metadata                         |

| aggregates                                 |

| block_device_mapping                       |

| bw_usage_cache                             |

| cells                                      |

| certificates                               |

| compute_nodes                              |

| console_pools                              |

| consoles                                   |

| dns_domains                                |

| fixed_ips                                  |

| floating_ips                               |

| instance_actions                           |

| instance_actions_events                    |

| instance_faults                            |

| instance_group_member                      |

| instance_group_metadata                    |

| instance_group_policy                      |

| instance_groups                            |

| instance_id_mappings                       |

| instance_info_caches                       |

| instance_metadata                          |

| instance_system_metadata                   |

| instance_type_extra_specs                  |

| instance_type_projects                     |

| instance_types                             |

| instances                                  |

| iscsi_targets                              |

| key_pairs                                  |

| migrate_version                            |

| migrations                                 |

| networks                                   |

| pci_devices                                |

| project_user_quotas                        |

| provider_fw_rules                          |

| quota_classes                              |

| quota_usages                               |

| quotas                                     |

| reservations                               |

| s3_p_w_picpaths                                  |

| security_group_default_rules               |

| security_group_instance_association        |

| security_group_rules                       |

| security_groups                            |

| services                                   |

| shadow_agent_builds                        |

| shadow_aggregate_hosts                     |

| shadow_aggregate_metadata                  |

| shadow_aggregates                          |

| shadow_block_device_mapping                |

| shadow_bw_usage_cache                      |

| shadow_cells                               |

| shadow_certificates                        |

| shadow_compute_nodes                       |

| shadow_console_pools                       |

| shadow_consoles                            |

| shadow_dns_domains                         |

| shadow_fixed_ips                           |

| shadow_floating_ips                        |

| shadow_instance_actions                    |

| shadow_instance_actions_events             |

| shadow_instance_faults                     |

| shadow_instance_group_member               |

| shadow_instance_group_metadata             |

| shadow_instance_group_policy               |

| shadow_instance_groups                     |

| shadow_instance_id_mappings                |

| shadow_instance_info_caches                |

| shadow_instance_metadata                   |

| shadow_instance_system_metadata            |

| shadow_instance_type_extra_specs           |

| shadow_instance_type_projects              |

| shadow_instance_types                      |

| shadow_instances                           |

| shadow_iscsi_targets                       |

| shadow_key_pairs                           |

| shadow_migrate_version                     |

| shadow_migrations                          |

| shadow_networks                            |

| shadow_pci_devices                         |

| shadow_project_user_quotas                 |

| shadow_provider_fw_rules                   |

| shadow_quota_classes                       |

| shadow_quota_usages                        |

| shadow_quotas                              |

| shadow_reservations                        |

| shadow_s3_p_w_picpaths                           |

| shadow_security_group_default_rules        |

| shadow_security_group_instance_association |

| shadow_security_group_rules                |

| shadow_security_groups                     |

| shadow_services                            |

| shadow_snapshot_id_mappings                |

| shadow_snapshots                           |

| shadow_task_log                            |

| shadow_virtual_interfaces                  |

| shadow_volume_id_mappings                  |

| shadow_volume_usage_cache                  |

| shadow_volumes                             |

| snapshot_id_mappings                       |

| snapshots                                  |

| task_log                                   |

| virtual_interfaces                         |

| volume_id_mappings                         |

| volume_usage_cache                         |

| volumes                                    |

+--------------------------------------------+

表创建了就证明我们安装是没有问题的。

[root@linux-node1 ~]# keystone service-create --name=nova --type=compute --description="Openstack Compute"

+-------------+----------------------------------+

|   Property  |              Value               |

+-------------+----------------------------------+

| description |        Openstack Compute         |

|   enabled   |               True               |

|      id     | 95b294a2be074f548baedbd5744c518f |

|     name    |               nova               |

|     type    |             compute              |

+-------------+----------------------------------+

[root@linux-node1 ~]# keystone endpoint-create \

> --service-id=95b294a2be074f548baedbd5744c518f \

> --publicurl=http://192.168.33.11:8774/v2/%\(tenant_id\)s \

> --internalurl=http://192.168.33.11:8774/v2/%\(tenant_id\)s \

> --adminurl=http://192.168.33.11:8774/v2/%\(tenant_id\)s

+-------------+--------------------------------------------+

|   Property  |                   Value                    |

+-------------+--------------------------------------------+

|   adminurl  | http://192.168.33.11:8774/v2/%(tenant_id)s |

|      id     |      1ad88c16010d41da93288d7b4fe78332      |

| internalurl | http://192.168.33.11:8774/v2/%(tenant_id)s |

|  publicurl  | http://192.168.33.11:8774/v2/%(tenant_id)s |

|    region   |                 regionOne                  |

|  service_id |      95b294a2be074f548baedbd5744c518f      |

+-------------+--------------------------------------------+

复制

keystone endpoint-create --service-id=95b294a2be074f548baedbd5744c518f --publicurl=http://192.168.33.11:8774/v2/%\(tenant_id\)s --internalurl=http://192.168.33.11:8774/v2/%\(tenant_id\)s --adminurl=

[root@linux-node1 ~]# cd init.d

[root@linux-node1 init.d]# cp openstack-nova-api /etc/init.d/

[root@linux-node1 init.d]# cp openstack-nova-cert /etc/init.d/

[root@linux-node1 init.d]# cp openstack-nova-conductor /etc/init.d/

[root@linux-node1 init.d]# cp openstack-nova-scheduler /etc/init.d/

[root@linux-node1 init.d]# cp openstack-nova-consoleauth /etc/init.d/

[root@linux-node1 init.d]# cp openstack-nova-novncproxy /etc/init.d/

[root@linux-node1 init.d]# chmod +x /etc/init.d/openstack-*

[root@linux-node1 init.d]# chkconfig --add openstack-nova-api

[root@linux-node1 init.d]# chkconfig --add openstack-nova-cert

[root@linux-node1 init.d]# chkconfig --add openstack-nova-conductor

[root@linux-node1 init.d]# chkconfig --add openstack-nova-scheduler

[root@linux-node1 init.d]# chkconfig --add openstack-nova-consoleauth

[root@linux-node1 init.d]# chkconfig --add openstack-nova-novncproxy 

[root@linux-node1 init.d]# chkconfig openstack-nova-api on

[root@linux-node1 init.d]# chkconfig openstack-nova-cert on

[root@linux-node1 init.d]# chkconfig openstack-nova-conductor on

[root@linux-node1 init.d]# chkconfig openstack-nova-scheduler on

[root@linux-node1 init.d]# chkconfig openstack-nova-consoleauth on

[root@linux-node1 init.d]# chkconfig openstack-nova-novncproxy on

[root@linux-node1 init.d]# for i in {api,cert,conductor,scheduler,consoleauth,novncproxy};do /etc/init.d/openstack-nova-$i start;done

正在启动 openstack-nova-api                              [确定]

正在启动 openstack-nova-cert                             [确定]

正在启动 openstack-nova-conductor                        [确定]

正在启动 openstack-nova-scheduler                        [确定]

正在启动 openstack-nova-consoleauth                      [确定]

正在启动 openstack-nova-novncproxy                       [确定]

[root@linux-node1 init.d]# ps aux|grep nova

我们发现openstack-nova-novncproxy没有启动起来那么下面我们来找一下原因。

手动启动一下看一下报错

[root@linux-node1 ~]# nova-novncproxy --config-file=/etc/nova/nova.conf 

Can not find novnc html/js/css files at /usr/share/novnc.

因为vnc的包没有装

[root@linux-node1 ~]# wget

[root@linux-node1 ~]# ll

总用量 13620

-rw-------. 1 root root     1149 7月  22 19:08 anaconda-ks.cfg

-rw-r--r--  1 root root 13167616 3月  18 09:04 cirros-0.3.2-x86_64-disk.img

drwxr-xr-x  2 root root     4096 5月   4 16:08 init.d

-rw-r--r--  1 root root    14344 7月  16 13:03 init.d.zip

-rw-r--r--. 1 root root    23833 7月  22 19:08 install.log

-rw-r--r--. 1 root root     7688 7月  22 19:07 install.log.syslog

-rw-r--r--  1 root root      129 8月  18 22:09 keystone-admin

-rw-r--r--  1 root root   711551 8月  19 06:37 v0.4.tar.gz

[root@linux-node1 ~]# tar zxf v0.4.tar.gz 

[root@linux-node1 ~]# ls

anaconda-ks.cfg  cirros-0.3.2-x86_64-disk.img  init.d  init.d.zip  install.log  install.log.syslog  keystone-admin  noVNC-0.4  v0.4.tar.gz

[root@linux-node1 ~]# mv noVNC-0.4/ /usr/share/novnc

[root@linux-node1 ~]# /etc/init.d/openstack-nova-novncproxy start

正在启动 openstack-nova-novncproxy                       [确定]

[root@linux-node1 ~]# ps aux|grep nova

[root@linux-node1 ~]# lsof -i:6080

COMMAND     PID USER   FD   TYPE DEVICE SIZE/OFF NODE NAME

nova-novn 14778 root    3u  IPv4 188276      0t0  TCP *:6080 (LISTEN)

[root@linux-node1 ~]# ps aux|grep 14778

root     14778  0.2  1.6 303292 30932 pts/0    S    06:45   0:00 /usr/bin/python /usr/bin/nova-novncproxy --logfile /var/log/nova/novncproxy.log

root     14851  0.0  0.0 103248   840 pts/0    S+   06:49   0:00 grep 14778

安装horizon

[root@linux-node1 ~]# cd /usr/local/src/horizon-2014.1

[root@linux-node1 horizon-2014.1]# python setup.py install

[root@linux-node1 horizon-2014.1]# cd openstack_dashboard/local

[root@linux-node1 local]# ls

enabled  __init__.py  local_settings.py.example

[root@linux-node1 local]# mv local_settings.py.example local_settings.py

[root@linux-node1 local]# vim local_settings.py 

OPENSTACK_HOST = "192.168.33.11"

OPENSTACK_KEYSTONE_URL = "http://%s:5000/v2.0" % OPENSTACK_HOST

OPENSTACK_KEYSTONE_DEFAULT_ROLE = "_member_"

[root@linux-node1 horizon-2014.1]# cd openstack_dashboard/local

[root@linux-node1 local]# ls

enabled  __init__.py  local_settings.py.example

[root@linux-node1 local]# mv local_settings.py.example local_settings.py

[root@linux-node1 local]# vim local_settings.py 

[root@linux-node1 local]# cd ../..

[root@linux-node1 horizon-2014.1]# cd ../

[root@linux-node1 src]# pwd

/usr/local/src

[root@linux-node1 src]# yum install httpd mod_wsgi

[root@linux-node1 src]# cd ~

[root@linux-node1 ~]# mv /usr/local/src/horizon-2014.1 /var/www/

[root@linux-node1 ~]# id apache

uid=48(apache) gid=48(apache) 组=48(apache)

[root@linux-node1 ~]# chown -R apache:apache /var/www/horizon-2014.1/

配置Apache的配置文件

[root@linux-node1 ~]# cd /etc/httpd/conf.d/

[root@linux-node1 conf.d]# ls

README  welcome.conf  wsgi.conf

[root@linux-node1 conf.d]# rz

z waiting to receive.**B0100000023be50

[root@linux-node1 conf.d]# ll

总用量 16

-rw-r--r-- 1 root root 955 8月  19 2014 horizon.conf

-rw-r--r-- 1 root root 392 7月  23 22:18 README

-rw-r--r-- 1 root root 299 7月  18 14:27 welcome.conf

-rw-r--r-- 1 root root  43 6月  11 19:00 wsgi.conf

[root@linux-node1 conf.d]# vim horizon.conf 

<VirtualHost *:80>

        ServerAdmin admin@unixhot.com

        ServerName 192.168.33.11

        DocumentRoot /var/www/horizon-2014.1/

        ErrorLog /var/log/httpd/horizon_error.log

        LogLevel info

        CustomLog /var/log/httpd/horizon_access.log combined

        WSGIScriptAlias / /var/www/horizon-2014.1/openstack_dashboard/wsgi/django.wsgi

        WSGIDaemonProcess horizon user=apache group=apache processes=3 threads=10 home=/var/www/horizon-2014.1

        WSGIApplicationGroup horizon

        SetEnv APACHE_RUN_USER apache

        SetEnv APACHE_RUN_GROUP apache

        WSGIProcessGroup horizon

        Alias /media /var/www/horizon-2014.1/openstack_dashboard/static

        <Directory /var/www/horizon-2014.1/>

                Options FollowSymLinks MultiViews

                 AllowOverride None

                Order allow,deny

                Allow from all

        </Directory>

</VirtualHost>

WSGISocketPrefix /var/run/horizon

[root@linux-node1 conf.d]# mkdir /var/run/horizon

[root@linux-node1 conf.d]# pwd

/etc/httpd/conf.d

启动Apache

[root@linux-node1 ~]# /etc/init.d/httpd start

正在启动 httpd                                           [确定]

访问一下但是有报错

[root@linux-node1 ~]# vim /var/www/horizon-2014.1/openstack_dashboard/views.py +35

@vary.vary_on_cookie

def splash(request):

    if request.user.is_authenticated():

        return shortcuts.redirect(horizon.get_user_home(request.user))

    form = forms.Login(request)

[root@linux-node1 ~]# vim /var/www/horizon-2014.1/openstack_dashboard/views.py +22

from openstack_auth import forms

在浏览器地址栏输入

我们可以用demo用户登录