zoukankan      html  css  js  c++  java
  • openstack搭建之旅(原创)

    1、什么是openstack
    是一个集中管理虚拟机的平台,整合了各种虚拟化的技术。
    虚拟机的具体创建交给具体的虚拟化技术实现,而Openstack是整合这些虚拟化技术,提供一个统一管理的视图,对虚拟机进行集中管理,
    通过各个组件为虚拟机提供网络服务,存储服务。

    2、openstack解决了什么问题?
    集中管理虚拟机,搭建一个云操作系统。

    3、逻辑部件构成及运作过程
       webUI(Horizon)---终端用户发出创建虚拟机的REST请求,发出挂载新的硬盘....
          通过compute-api把REST请求参数转变为RPC请求参数,通过RPC发送到消息队列
       scheduler监听消息队列消息,根据配置比如算法,选择合适的计算节点来创建虚拟机,
           发送调度消息到消息队列
       计算节点上的computer服务监听目标是自己的消息,解析命令,进行创建虚拟机的动作
          通过镜像服务,获取镜像
          通过volume-api发出RPC存储请求到消息队列,Volume-Schedule会选择合适的存储节点,提供存储块给虚拟机
          通过network-api 发出网络请求,初始化网络数据模型,建立虚拟网卡,分配私有地址,更新DHCP的MAC-IP映射,分配弹性地址(NAT)

          最终会生成一个虚拟机配置文件,KVM的libvirt会根据配置文件创建和启动虚拟机,启动后获得dhcp分配的私有地址。

    4、实验环境搭建
      1)准备4台虚拟机作为要部署openstack的物理机器。虚拟机试验中作为物理机器,需要支持嵌套虚拟化。
      2)物理机器安装centos7.2,启用虚拟化支持。
    虚拟机CPU需要启用虚拟化支持
       #可以使用这种
    <cpu mode='custom' match='exact'>
        <model fallback='allow'>core2duo</model> <feature policy='require' name='vmx'/>
    </cpu> #这种方式为虚拟机定义需要模拟的CPU类型"core2duo",并且为虚拟机添加"vmx"特性
      #也可以使用这种 <cpu mode='host-model'> <model fallback='allow'/> </cpu>
       #或者这样  <cpu mode='host-passthrough'> <topology sockets='2' cores='2' threads='2'/> </cpu>
      #CPU穿透,在虚拟机中看到的vcpu将会与物理机的CPU同样配置,这种方式缺点在于如果要对虚拟机迁移,迁移的目的服务器硬件配置必须与当前物理机一样
    
    
    5、搭建起航
    1)规划
    建立三个物理网络,
    管理网络:192.168.4.0/24
    数据(虚拟机)网络:所有虚拟机之间的通信,都通过本网络。192.168.2.0/24

    存储网络:
    A、控制节点
    192.168.4.91
         192.168.2.91
    B、计算节点(虚拟机节点)
       每个计算节点需要建立1个网桥br100,实现与计算节点上网卡的连接绑定,在nova.conf文件中配置。
       计算节点上的所有虚拟机都加入br100的网络,所有的虚拟机通过计算节点的物理网卡连接到数据网交换机上。网关都设置为网络节点上网桥br100的IP。
       =====计算节点1=====
       eth0:192.168.4.99(管理)
    eth1:192.168.2.99(数据)
       =====计算节点2====
       eth0:192.168.4.98(管理)
     eth1:192.168.2.98
    (数据)
    C、存储节点op_volumn
        eth0:192.168.4.100(管理)
        eth1:192.168.2.100(数据-存储)
       
    B、网络节点
       部署 nova-network/quantum    DNSmas1
       所有虚拟机的对外访问都通过网络节点,一个是实现网关的终结,另外是在网络节点实现NAT。
       单网络节点会存在单点故障问题
       所以可以采用多网络节点部署模式,在每个计算节点安装nova-compute nova-network nova-api
       修改nova.conf配置文件: multi_host=True enabled_apis=metadata
     

       

       



  • 相关阅读:
    梦和现实, 哪个更真实呢? 程序的现实? 还是上古的梦?
    C#基础知识总结(一)
    C#学习路线
    C# 成员默认访问权限(public、private、protected、internal)
    C#基础知识总结(二)
    正则表达式C#正则表达式的符号及例子
    Dynamics CRM 2016/365 窗体中添加按钮
    01 tsung安装
    07 tsung 参数化
    02 jmeter 简单发送http请求
  • 原文地址:https://www.cnblogs.com/justart/p/7625808.html
Copyright © 2011-2022 走看看