设为首页 收藏本站
查看: 1350|回复: 0

[经验分享] OpenStack 部署总结之:在CentOS 6.5上使用RDO安装双结算结点的icehouse(Ml2+GRE)

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2014-9-5 09:32:51 | 显示全部楼层 |阅读模式
本文主要介绍如何在CentOS6.5上通过RDO来安装一个双计算节点的icehouse环境,网络方式采用Ml2+Gre由于安装的过程中涉及的软件较多,以及依赖关系比较复杂,建议使用一个全新的操作系统来进行安装。


硬件环境

两台Dell的R720服务器机,每台机器有4个网卡,只用到em1,以及em2,且这两个网卡都接有网线。公网和管理网络合用em1,虚拟机网络使用em2。

交换机方面,由于条件原因,只采用一个交换机,不过理论上将em1和em2的交换机分开效率会更高。

服务器
   

公网/管理网络
   

VM Net
    角色

服务器1
   

em1:192.168.100.242
   

em2:10.1.1.2
   

控制节点,网络节点,存储节点,计算节点

服务器2
   

em2:192.168.100.244
   

em2:10.1.1.3
   

计算节点

和vlan模式配置一个明显的区别,就是eth1,是需要配置一个私有的IP地址,必须配置。

由于使用的是GRE模式,所以就不需要麻烦网管设置Trunk



简单的逻辑图取自陈老师博客的图(忽略IP与设备名称)

SouthEast.jpg
虚拟机的通讯,是通过eth1(对应我的环境是em2),虚拟机访问外部网络,是通过服务器1上的L3agent,br-ex到eth0(对应我的环境是em1)上访问外部网络


安装步骤具体如下
安装操作系统
使用光盘或镜像文件安装操作系统.

分区的时候需要划分一个逻辑区,并且建立一个名称叫cinder-volumes的组。这个逻辑卷组会被cinder使用。

创建的效果类似于:
SouthEast.jpg

创建过程请参考:http://www.centos.org/docs/5/htm ... skdruid-manual.html

也可以装完操作系统后通过命令的方式来创建
修改fstab

修改/etc/fstab 去掉cinder-volume的开机挂载,不然会导致你无法重启

sed -i '/cinder-volume/s/^/#/' /etc/fstab
配置网络

两台服务器的配置相同,只是IP与HWADDR/UUID不同,配置 vi/etc/sysconfig/network-scripts/ifcfg-em1,编辑内容如下




    DEVICE=em1  
    HWADDR=C8:1F:66:E5:29:0D  
    TYPE=Ethernet  
    UUID=63d91b69-5c37-437e-898b-65403cef29a0  
    ONBOOT=yes  
    BOOTPROTO=static  
    IPADDR=192.168.100.242  
    GATEWAY=192.168.100.1  
    NETMASK=255.255.255.0  
    DNS1=8.8.8.8   

配置 vi/etc/sysconfig/network-scripts/ifcfg-em2,编辑内容如下


    DEVICE=em2  
    HWADDR=C8:1F:66:E5:29:0E  
    TYPE=Ethernet  
    UUID=b2cdb6e2-37d9-4fd0-b3d6-01f107ed80e0  
    ONBOOT=yes  
    BOOTPROTO=static  
    IPADDR=10.1.1.2  
    NETMASK=255.255.255.0  
    DNS1=8.8.8.8  


经过以上配置后,确定网络可以连接.

由于实例运行的过程中,可以将NetworkManager服务停止,以为这个服务没用的服务会占用大量的内存



    chkconfig NetworkManager off   


安装相关的yum源

yum源是否正确安装直接影响到安装的正确性,本人安装的过程中出现的很多问题都和源有关

安装的过程主要涉及到三个源:
安装163源

1,备份/etc/yum.repos.d/CentOS-Base.repo

    mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup  

2,下载对应版本repo文件, 放入/etc/yum.repos.d/(操作前请做好相应备份)

    CentOS5

    CentOS6

安装icehouse源

执行以下命令

    yum install -y http://rdo.fedorapeople.org/open ... elease-icehouse.rpm  

安装epel源

选用的是64位系统,执行以下命令

    rpm -ivh http://download.fedora.redhat.co ... ease-6-5.noarch.rpm  

在安装上面源的时候会生成foreman.repo源,这个源可直接删掉


设置YUM的cache

由于网络问题,安装过程可能会经常失败,所以此时可以设置yum 的cache来提高失败后再次安装的效率
PackStack

安装openstack-packstack

执行下面的命令



    yum install -y openstack-packstack   

可能会碰到计算节点安装某些程序总是失败,可以先在计算节点上安装完之后在到控制节点上再次执行


配置packstack

为了方便以后多次执行相同的packstack的配置,可以先导出一个原始的配置,然后在这个文件上做一些修改,以后就可以指定配置文件的方式安装openstack

生成自己的配置文件



    packstack --gen-answer-file=myanswer.txt     

修改配置文件


    #为了在环境中使用HEAT  
    CONFIG_HEAT_INSTALL=y  
    CONFIG_NTP_SERVERS=0.uk.pool.ntp.org  
    #配置两个计算节点  
    CONFIG_COMPUTE_HOSTS=192.168.100.242,192.168.100.244  
    #登陆控制台的密码  
    CONFIG_KEYSTONE_ADMIN_PW=admin  
    #前面的步骤已经创建了LVM  
    CONFIG_CINDER_VOLUMES_CREATE=n  
    #网络使用的配置  
    CONFIG_NOVA_COMPUTE_PRIVIF=em2  
    CONFIG_NOVA_NETWORK_PUBIF=em1  
    CONFIG_NOVA_NETWORK_PRIVIF=em2  
    CONFIG_LBAAS_INSTALL=y  
    CONFIG_NEUTRON_METERING_AGENT_INSTALL=y  
    #GRE模式的相关配置  
    CONFIG_NEUTRON_ML2_TYPE_DRIVERS=gre  
    CONFIG_NEUTRON_ML2_TENANT_NETWORK_TYPES=gre  
    CONFIG_NEUTRON_ML2_TUNNEL_ID_RANGES=100:1000  
    CONFIG_NEUTRON_OVS_TENANT_NETWORK_TYPE=gre  
    CONFIG_NEUTRON_OVS_TUNNEL_RANGES=100:1000  
    #使用em2作为通道  
    CONFIG_NEUTRON_OVS_TUNNEL_IF=em2  
    #不安装DEMO用户  
    CONFIG_PROVISION_DEMO=n  
    CONFIG_HEAT_CLOUDWATCH_INSTALL=y  
    CONFIG_HEAT_CFN_INSTALL=y  



修改hosts

在两个节点的/etc/hosts文件中分别添加对方的IP以及名称,同事为了提高从源的下载速度,也可以在hosts文件中配置源的信息,例如在192.168.100.242上的hots文件如下:


    ::1         localhost localhost.localdomainlocalhost6 localhost6.localdomain6  
    127.0.0.1   develop5  
    192.168.100.244   develop6  
    ::1         localhost localhost.localdomainlocalhost6 localhost6.localdomain6  
    192.118.12.243          mirrors.skyshe.cn  
    208.113.241.137         ceph.com  
    152.19.134.191          repos.fedorapeople.org  
    123.58.173.106          mirrors.163.com  
    152.19.134.191          repos.fedorapeople.org  
    69.56.251.103           openvswitch.org  
    66.109.26.212           mirror.centos.org  
    23.253.148.10           yum.theforeman.org   

执行配置文件

packstack --answer-file=myanswer.txt  

这个过程可能比较漫长,中间可能会因为网络中断几次,中断后请继续
配置br-ex

安装完毕后,由于目前RDO的问题,没有创建br-ex,需要我们手工来创建,这个只需要在192.168.100.242上配置进行就可以,具体点说,应该是在网络节点上进行。
修改ifcfg-em1文件


    DEVICE=em1  
    HWADDR=C8:1F:66:E5:29:0D  
    ONBOOT=yes  
    DEVICETYPE=ovs  
    TYPE=OVSPort  
    OVS_BRIDGE=br-ex  


创建ifcfg-br-ex文件


    DEVICE=br-ex  
    DEVICETYPE=ovs  
    TYPE=OVSBridge  
    ONBOOT=yes  
    OVSBOOTPROTO=none  
    IPADDR=192.168.100.242  
    NETMASK=255.255.255.0  
    DEFROUTE=yes  
    PREFIX=24  
    GATEWAY=192.168.100.1  
    DNS1=202.103.24.68  


配置OVS


    ovs-vsctladd-br br-ex  
    ovs-vsctladd-port br-ex em1; service network restart  



成功配置OVS以及添加虚拟机后的配置如下:
控制+网络+计算

OVS的配置


    [iyunv@develop5~(keystone_admin)]# ovs-vsctl show  
    d3ac11c9-8d88-4abc-8ca0-19788ab1491b  
        Bridge br-ex  
            Port "em1"  
                Interface "em1"  
            Port "qg-158cc8c6-4f"  
                Interface"qg-158cc8c6-4f"  
                    type: internal  
            Port br-ex  
                Interface br-ex  
                    type: internal  
        Bridge br-int  
            fail_mode: secure  
            Port "tapa104132f-bd"  
                tag: 1  
                Interface"tapa104132f-bd"  
                    type: internal  
            Port "qvo0715cfb5-b4"  
                tag: 1  
                Interface"qvo0715cfb5-b4"  
            Port "tape8875e25-22"  
                tag: 2  
                Interface"tape8875e25-22"  
                    type: internal  
            Port br-int  
                Interface br-int  
                    type: internal  
            Port "qvoeb74bfb0-1b"  
                tag: 1  
                Interface"qvoeb74bfb0-1b"  
            Port "qvod119e70f-3f"  
                tag: 1  
                Interface"qvod119e70f-3f"  
            Port patch-tun  
                Interface patch-tun  
                    type: patch  
                    options: {peer=patch-int}  
            Port "qvo948222df-c9"  
                tag: 1  
                Interface"qvo948222df-c9"  
            Port "qr-da6f872b-7c"  
                tag: 1  
                Interface"qr-da6f872b-7c"  
                    type: internal  
        Bridge br-tun  
            Port "gre-0a010103"  
                Interface "gre-0a010103"  
                    type: gre  
                    options: {in_key=flow,local_ip="10.1.1.2", out_key=flow, remote_ip="10.1.1.3"}  
            Port patch-int  
                Interface patch-int  
                    type: patch  
                    options: {peer=patch-tun}  
            Port br-tun  
                Interface br-tun  
                    type: internal  
        ovs_version: "1.11.0"  

Linux 网桥的配置
SouthEast.jpg


计算节点:OVS配置
    [iyunv@develop6~]# ovs-vsctl show  
    17cbd24e-df55-4f3d-b6a4-446b88b47ac4  
        Bridge br-int  
            fail_mode: secure  
            Port "qvo28484b00-f0"  
                tag: 1  
                Interface"qvo28484b00-f0"  
            Port "qvo61070289-31"  
                tag: 1  
                Interface"qvo61070289-31"  
            Port "qvo3207417a-bd"  
                tag: 1  
                Interface"qvo3207417a-bd"  
            Port patch-tun  
                Interface patch-tun  
                    type: patch  
                    options: {peer=patch-int}  
            Port br-int  
                Interface br-int  
                    type: internal  
        Bridge br-tun  
            Port patch-int  
                Interface patch-int  
                    type: patch  
                    options: {peer=patch-tun}  
            Port br-tun  
                Interface br-tun  
                    type: internal  
            Port "gre-0a010102"  
                Interface "gre-0a010102"  
                    type: gre  
                    options: {in_key=flow,local_ip="10.1.1.3", out_key=flow, remote_ip="10.1.1.2"}  
        ovs_version: "1.11.0"  

Linux网桥的配置


SouthEast.jpg
安装验证

    可以打开登录页面,并用配置的密码进行登录
    可以创建网络,实例
    配置的实例可以与外部网络互通




运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-24496-1-1.html 上篇帖子: OpenStack Heat总结之:Icehouse中通过Heat+Ceilometer实现Autoscaling 下篇帖子: OpenStack 网络总结之:理解GRE隧道的工作流程
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表