天天看点

openstack(二)一键安装

  这里写一下红帽的一键部署openstack的方式,这里说一下用packstack根据应答文件(answer-file)方式自动部署,后续再针对每个服务单独讲解。

一、Preinstallation

1、在安装之前,说一下官方给出的硬件要求最小配置:

Controller Node: 1 processor, 2 GB memory, and 5 GB storage

Network Node: 1 processor, 512 MB memory, and 5 GB storage

Compute Node: 1 processor, 2 GB memory, and 10 GB storage

2、装系统时,建议最小化安装、LVM、block storage 

3、配置好yum源(openstack+rhel)

4、Red Hat Enterprise Linux Openstack与NetworkManager有冲突!!!

开始安装Openstack之前先关闭NetworkManager并启动network服务。

5、我们自己搭建的实验环境,可以把计算节点和存储、控制节点分开装,也可以都安装在一台服务器上;推荐的最小化配置是两台,其中一台用作计算,控制、存储等节点,另一台当做计算节点。

6、如果是用虚拟机搭建的环境,不要忘记开机机器的虚拟化功能,我的两台机器就是搭在vmware虚拟主机上的。

二、测试环境拓扑:

<a href="http://s4.51cto.com/wyfs02/M02/7C/81/wKiom1bR29KBqIpvAAJz3RXhfz0222.png" target="_blank"></a>

我的测试环境用172.25.4.10(servera)和172.25.4.11(serverb)

三、安装

1.在servera上安装openstack-packstack软件包

<code>#yum -y install openstack-packstack</code>

2.生成应答文件answer.txt

<code>#packstack --gen-answer-file /root/answer.txt</code>

3.修改自定义应答文件answer.txt,可根据自己的要求,更改相关配置;E.g.:

<code>CONFIG_DEFAULT_PASSWORD=mypassword                         </code><code>//</code><code>设置默认密码</code>

<code>CONFIG_HEAT_INSTALL=y                                      </code><code>//</code><code>安装heat组件</code>

<code>CONFIG_NTP_SERVERS=172.25.254.254                          </code><code>//</code><code>设置时间服务器</code>

<code>CONFIG_COMPUTE_HOSTS=172.25.4.10,172.25.4.11        </code><code>//</code><code>安装计算节点的主机</code>

<code>CONFIG_KEYSTONE_ADMIN_PW=redhat                     </code><code>//keystone</code><code>管理员密码</code>

<code>CONFIG_CINDER_VOLUMES_CREATE=n                      </code><code>//</code><code>默认有一个cinder-volume卷组,不创建测试卷组</code>

<code>CONFIG_LBAAS_INSTALL=y                               </code><code>//</code><code>安装负载均衡即服务组件</code>

<code>CONFIG_NEUTRON_METERING_AGENT_INSTALL=y              </code><code>//</code><code>使得ceilometer可以检测到网络数据</code>

<code>CONFIG_NEUTRON_FWAAS=y                               </code><code>//</code><code>配置防火墙即服务</code>

<code>CONFIG_NEUTRON_ML2_TYPE_DRIVERS=vlan                 </code><code>//</code><code>网络驱动模型,使用vlan划分网络</code>

<code>CONFIG_NEUTRON_ML2_TENANT_NETWORK_TYPES=vlan</code>

<code>CONFIG_NEUTRON_ML2_VLAN_RANGES=physnet1:1:1000       </code><code>//</code><code>设置网络名称(任意字符即可)及vlan编号范围</code>

<code>CONFIG_NEUTRON_OVS_BRIDGE_MAPPINGS=physnet1:br-ex    </code><code>//</code><code>设置网桥名称(物理网络绑定网桥)</code>

<code>CONFIG_NEUTRON_OVS_BRIDGE_IFACES=br-ex:eth0          </code><code>//</code><code>设置网桥接口(网桥绑定网卡接口)</code>

<code>CONFIG_HORIZON_SSL=y                                 </code><code>//</code><code>安装Web管理端界面</code>

<code>CONFIG_HEAT_CFN_INSTALL=y                            </code><code>//</code><code>支持兼容亚马逊的HEAT API接口</code>

<code>CONFIG_PROVISION_DEMO=n                              </code><code>//</code><code>部署环境是否为演示环境</code>

4.用应答文件部署openstack,用的puppet自动部署工具

<code>#packstack --answer-file /root/answer.txt</code>

部署过程大概需要30min左右。

5.部署完成之后,查看openstack的服务状态

<code>#cat keystonerc_admin</code>

<code>unset</code> <code>OS_SERVICE_TOKEN</code>

<code>export</code> <code>OS_USERNAME=admin</code>

<code>export</code> <code>OS_PASSWORD=mypassword</code>

<code>export</code> <code>OS_AUTH_URL=http:</code><code>//172</code><code>.25.4.10:5000</code><code>/v2</code><code>.0</code>

<code>export</code> <code>PS1=</code><code>'[\u@\h \W(keystone_admin)]\$ '</code>

<code>export</code> <code>OS_TENANT_NAME=admin</code>

<code>export</code> <code>OS_REGION_NAME=RegionOne</code>

<code>#source keystonerc_admin                 //加载环境变量</code>

<code>#openstack-status                       //查看状态</code>

<code>== Nova services ==</code>

<code>openstack-nova-api:                     active</code>

<code>openstack-nova-cert:                    active</code>

<code>openstack-nova-compute:                 active</code>

<code>openstack-nova-network:                 inactive  (disabled on boot)</code>

<code>openstack-nova-scheduler:               active</code>

<code>openstack-nova-conductor:               active</code>

<code>== Glance services ==</code>

<code>openstack-glance-api:                   active</code>

<code>openstack-glance-registry:              active</code>

<code>== Keystone service ==</code>

<code>openstack-keystone:                     inactive  (disabled on boot)</code>

<code>== Horizon service ==</code>

<code>openstack-dashboard:                    301</code>

<code>== neutron services ==</code>

<code>neutron-server:                         active</code>

<code>neutron-dhcp-agent:                     active</code>

<code>neutron-l3-agent:                       active</code>

<code>neutron-metadata-agent:                 active</code>

<code>neutron-lbaas-agent:                    active</code>

<code>neutron-openvswitch-agent:              active</code>

<code>neutron-metering-agent:                 active</code>

<code>== Swift services ==</code>

<code>openstack-swift-proxy:                  active</code>

<code>openstack-swift-account:                active</code>

<code>openstack-swift-container:              active</code>

<code>openstack-swift-object:                 active</code>

<code>== Cinder services ==</code>

<code>openstack-cinder-api:                   active</code>

<code>openstack-cinder-scheduler:             active</code>

<code>openstack-cinder-volume:                active</code>

<code>openstack-cinder-backup:                active</code>

<code>== Ceilometer services ==</code>

<code>openstack-ceilometer-api:               active</code>

<code>openstack-ceilometer-central:           active</code>

<code>openstack-ceilometer-compute:           active</code>

<code>openstack-ceilometer-collector:         active</code>

<code>openstack-ceilometer-alarm-notifier:    active</code>

<code>openstack-ceilometer-alarm-evaluator:   active</code>

<code>openstack-ceilometer-notification:      active</code>

<code>== Heat services ==</code>

<code>openstack-heat-api:                     active</code>

<code>openstack-heat-api-cfn:                 active</code>

<code>openstack-heat-api-cloudwatch:          inactive  (disabled on boot)</code>

<code>openstack-heat-engine:                  active</code>

<code>== Support services ==</code>

<code>mysqld:                                 active    (disabled on boot)</code>

<code>openvswitch:                            active</code>

<code>dbus:                                   active</code>

<code>target:                                 active</code>

<code>rabbitmq-server:                        active</code>

<code>memcached:                              active</code>

<code>== Keystone </code><code>users</code> <code>==</code>

<code>Warning keystonerc not sourced</code>

6、安装完成功之后,网卡的配置已经自动更改:

<code>[root@servera ~]</code><code># cat /etc/sysconfig/network-scripts/ifcfg-eth0</code>

<code>DEVICE=eth0</code>

<code>DEVICETYPE=ovs</code>

<code>TYPE=OVSPort</code>

<code>OVS_BRIDGE=br-ex</code>

<code>ONBOOT=</code><code>yes</code>

<code>BOOTPROTO=none</code>

<code>[root@servera ~]</code><code># cat /etc/sysconfig/network-scripts/ifcfg-br-ex</code>

<code>DEFROUTE=</code><code>yes</code>

<code>NAME=eth0</code>

<code>IPADDR=172.25.4.10</code>

<code>PREFIX=24</code>

<code>GATEWAY=172.25.4.254</code>

<code>DEVICE=br-ex</code>

<code>OVSBOOTPROTO=none</code>

<code>TYPE=OVSBridge</code>

四、安装完成

安装过程中可能遇到的报错:

1、MissingRequirements: The cinder server should contain a cinder-volumes volume group

解决办法:新建一个cinder-volumes的vg

<code>#pvcreate /dev/sdb1</code>

<code>#vgcreate cinder-volumes /dev/sdb1</code>

2、NTP报错:

Error: /usr/sbin/ntpdate 10.13.25.14 returned 1 instead of one of [0]

25 Feb 09:31:47 ntpdate[4771]: the NTP socket is in use, exiting

解决办法:

<code>#systemctl stop ntp.service</code>

傻白甜犯错:ntpserver 配置的是本身!!!

3、NTP的另一种报错:mNotice: /Stage[main]/Main/Exec[ntpdate]/returns: 25 Feb 09:40:42 ntpdate[7217]: no server suitable for synchronization found

1)在server上debug一下:

<code>[root@serverb ~]</code><code># ntpdate -d 10.13.25.14</code>

<code>25 Feb 09:52:40 ntpdate[7260]: ntpdate [email protected] Fri Oct 16 08:51:51 UTC 2015 (1)</code>

<code>Looking </code><code>for</code> <code>host 10.13.25.14 and service ntp</code>

<code>host found : servera.pod4.example.com</code>

<code>transmit(10.13.25.14)</code>

<code>10.13.25.14: Server dropped: no data</code>

<code>server 10.13.25.14, port 123</code>

<code>stratum 0, precision 0, leap 00, trust 000</code>

<code>refid [10.13.25.14], delay 0.00000, dispersion 64.00000</code>

<code>transmitted 4, </code><code>in</code> <code>filter 4</code>

<code>reference </code><code>time</code><code>:    00000000.00000000  Sun, Dec 31 1899 19:00:00.000</code>

<code>originate timestamp: 00000000.00000000  Sun, Dec 31 1899 19:00:00.000</code>

<code>transmit timestamp:  da7993be.d66affb9  Thu, Feb 25 2016  9:52:46.837</code>

<code>filter delay:  0.00000  0.00000  0.00000  0.00000</code>

<code>         </code><code>0.00000  0.00000  0.00000  0.00000</code>

<code>filter offset: 0.000000 0.000000 0.000000 0.000000</code>

<code>         </code><code>0.000000 0.000000 0.000000 0.000000</code>

<code>delay 0.00000, dispersion 64.00000</code>

<code>offset 0.000000</code>

<code>25 Feb 09:52:48 ntpdate[7260]: no server suitable </code><code>for</code> <code>synchronization found</code>

2) 检查服务是否启动成功,如果没启动,则start:

<code>#systemctl status ntpd.service</code>

3)检查ntp的版本,如果你使用的是ntp4.2(包括4.2)之后的版本,在restrict的定义中使用了notrust的话,会导致以上错误

# ntpq -c version  

4)检查防火墙是否屏蔽了udp的123端口

      本文转自Jx战壕  51CTO博客,原文链接:http://blog.51cto.com/xujpxm/1745682,如需转载请自行联系原作者

继续阅读