官网地址https://docs.openstack.org/kolla-ansible/latest/user/quickstart.html

参考:https://www.jianshu.com/p/e0e470f9fd4d

虚拟机多节点:https://www.cnblogs.com/linkenpark/p/9542071.html

其他多节点:https://blog.csdn.net/wzlsunice88/article/details/79241489

1、准备环境:

  • 物理机或者虚拟机三台(本文使用公有云的CentOS7系统)
  • control节点 2个网络接口:
    •   eth0:192.168.31.3  eth1:192.168.31.4      外网:10.10.1.1
  • compute节点:
    •   eth0:192.168.31.2
    • 也是cinder节点:添加一块硬盘配置lvm存储
  • 8GB主内存、40GB磁盘空间(视情况而定)

2、准备部署:

  2.1 服务器配置IP

    vim /etc/sysconfig/network-scripts/ifcfg-eth0
    systemctl restart network # 重启网络

  2.2 安装依赖关系

    yum install -y epel-release
    yum install -y python-pip
    pip install -U pip     yum install python-devel libffi-devel gcc openssl-devel libselinux-python
    yum install docker -y
    如果docker有冲突,需要卸载rpm -qa |grep docker ,然后yum remove -y *,最后重装1.12(最新1.13)yum install docker-engine-1.12.6*,启动服务systemctl start docker
    查看cpu是否支持虚拟化
    egrep -c '(vmx|svm)' /proc/cpuinfo

  2.3 安装ansible

    yum install ansible

  2.4 安装kolla-ansible,用来部署

    pip install kolla-ansible

  2.5 centos7下将globals.yml和passwords.yml复制到/etc/kolla目录 

    For CentOS, run:

      cp -r /usr/share/kolla-ansible/etc_examples/kolla /etc/

    For Ubuntu, run:

      cp -r /usr/local/share/kolla-ansible/etc_examples/kolla /etc/

  2.6 将all-in-one和multinode库存文件复制到当前目录。  

    For CentOS, run:

      cp /usr/share/kolla-ansible/ansible/inventory/* .

    For Ubuntu, run:

      cp /usr/local/share/kolla-ansible/ansible/inventory/* .

3 准备在主机上部署OpenStack(如果是多节点需要配置multinode文件)

    3.0 多节点需要配置multinode文件,单节点不需要:

    3.0.1配置如下:

 [control]
localhost ansible_connection=local
[network:children]
control [compute]
compute主机名
[monitoring]
14 localhost ansible_connection=local
18 [storage:children]
compute
[deployment]
localhost ansible_connection=local

    3.0.2 检查库存配置是否正确

      ansible -i multinode all -m ping

  

  3.1 部署中使用的密码存储在/etc/kolla/passwords.yml文件中。

    通过运行下面命令生成随机密码:

      kolla-genpwd

    初始化之后,可手动更改keystone_admin_password密码(OpenStack登录密码)

      vim /etc/kolla/passwords.yml
      keystone_admin_password:admin

  3.2 编辑globals.yml配置文件

  
  单节点模式:
  kolla_base_distro: "centos"
  # binary使用像apt或yum这样的软件仓库,source使用原始源代码归档,git存储库或本地源代码目录
  kolla_install_type: "source"
  openstack_release: "rocky" # 使用的版本,master版本我尝试过启动不行   network_interface: "eth0" # OpenStack使用的网络接口   # 第二个接口专用于Neutron外部(或公共)网络,可以是vlan或flat,取决于网络的创建方式。
  # 这个接口应该是活动的,没有IP地址。否则,实例将无法访问外部网络
  neutron_external_interface: "eth1"
  kolla_internal_vip_address: "192.168.31.3" # et0 ip

   多节点模式配置: 

  kolla_base_distro: "centos"
  # binary使用像apt或yum这样的软件仓库,source使用原始源代码归档,git存储库或本地源代码目录
  kolla_install_type: "source"
  openstack_release: "rocky" # 使用的版本
,master版本我尝试过启动不行
  network_interface: "eth0" # OpenStack使用的网络接口   # 第二个接口专用于Neutron外部(或公共)网络,可以是vlan或flat,取决于网络的创建方式。   # 这个接口应该是活动的,没有IP地址。否则,实例将无法访问外部网络   neutron_external_interface: "eth1"   kolla_internal_vip_address: "192.168.31.3" # control节点et0 ip

4、开始部署

单节点启动:
   4.1.1、带有kolla的引导服务器部署依赖关系

    kolla-ansible -i ./all-in-one bootstrap-servers
  4.1.2、对主机执行预部署检查
    kolla-ansible -i ./all-in-one prechecks
   4.1.3、执行OpenStack部署
    kolla-ansible -i ./all-in-one deploy 多节点启动:
   4.2.1、带有kolla的引导服务器部署依赖关系     
    kolla-ansible -i ./multinode bootstrap-servers   
   4.2.2、对主机执行预部署检查
    
    kolla-ansible -i ./multinode prechecks   
   4.2.3、执行OpenStack部署     
    kolla-ansible -i ./multinode deploy

5、使用OpenStack

  5.1 OpenStack需要一个openrc文件,其中设置了admin用户的凭证。

  要生成这个文件运行以下命令:

  kolla-ansible post-deploy
  . /etc/kolla/admin-openrc.sh

  5.2 安装基本的OpenStack CLI客户端:

  pip install python-openstackclient python-glanceclient python-neutronclient

  5.3 运行脚本创建示例网络,图像等

  . /usr/share/kolla-ansible/init-runonce

  打开浏览器输入机器公有云外网ip 18.68.x.x,用户admin ,密码admin 可登录openstack_dashboard,如图所示:  

    

重装记得,删除干净,不然报错

  docker stop  $(docker ps -qa)
  docker rm -f   $(docker ps -qa)
  docker volume rm $(docker volume ls -q)
 
一些坑,,定期更新:
  在公有云上创建的openstack,无法创建instance,提示
 
 

最新文章

  1. html中的空格显示问题
  2. 常用Meta整理
  3. Ajax异步刷新,测试用户名是否被注册
  4. HDU 1171 Big Event in HDU 多重背包二进制优化
  5. JAVA中关于同步与死锁的问题
  6. Linux_cloudera-scm-agent: unrecognized service
  7. 配置BeanUtils包,同时也是对导入第三包的步骤说明
  8. python应用部署--flask
  9. SpringBoot入门教程(三)通过properties实现多个数据库环境自动切换配置
  10. Django练习——图书管理系统
  11. django——模板层
  12. 使用Python的库qrcode生成二维码
  13. [原][openstack-pike][controller node][issue-2][glance] Could not parse rfc1738 URL from string 'mysql+pymysql=http://glance:glance@controller/glance'
  14. 同一个电脑安装两个jdk版本
  15. python requests post和get
  16. 2019.01.16 bzoj3526: [Poi2014]Card(线段树)
  17. mysql 中 datetime和 timestamp的区别
  18. Mycat问题总结
  19. IntelliJ IDEA 历史版本下载地址
  20. thinkphp签到的实现代码

热门文章

  1. (转)Awesome PyTorch List
  2. CCF计算机网络会议日期
  3. JS 事件绑定、事件监听、事件委托详细介绍
  4. 【BZOJ 5125】小Q的书架
  5. HDU 3526 Computer Assembling(最小割)
  6. latex建立参考文献的超链接
  7. 【Java】【泛型】
  8. P2016 战略游戏
  9. DjangoBlog安装
  10. JavaScript 局部刷新