1. 硬件要求
  2. 安装OpenStack
    1. 1 安装CentOS 65系统并清空iptables防火墙规则
    2. 2 安装系统需要的工具包包括Openstack依赖的和CloudFoundry依赖的
    3. 3 安装EPEL repo
    4. 4 Upgrade 当前系统
    5. 5 安装openstack repo 目前CloudFoundry最高只能支持Havana版的Openstack
    6. 6 安装packstack
    7. 7 同步时间
    8. 8 安装单节点openstack
  3. 配置Openstack
    1. 0 安装后的Openstack Dashboard有个小bug使用下面命令fix
    2. 1 demo tenant的默认配额Quota不足以安装CloudFoundry所以先要增加demo的Quota
    3. 2 扩展磁盘空间
 

由于AWS和vSphere/vCloud都不是免费获得的,本文将描述如果部署CloudFoundry到开源IaaS的Openstack上。本文的重点是如何部署CloudFoundry,所以OpenStack的部署采取最简单的方案--单节点OpenStack,如果读者希望了解如何部署一个分布式的高可用性的OpenStack,请参考网络上面的相关文章。

所以,笔者选择了CentOS和Redhat的工具packstack来部署一个单节点的OpenStack。目前CloudFoundry只支持Folsom,Grizilly,和Havana三个版本的OpenStack。

0. 硬件要求

CPU:x86_64架构的Intel i5 i7或者至强
内存: 64GB以上
硬盘:500G以上的剩余空间
 

1. 安装OpenStack

1.1 安装CentOS 6.5系统,并清空iptables防火墙规则,经验证CENTOS 7 安装juno RDO也是可以的。

  1. # iptables -F
  2. ##centos7 运行如下命令
  3. systemctl disable firewalld
  4. systemctl stop firewalld

1.2 安装系统需要的工具包,包括Openstack依赖的和CloudFoundry依赖的

  1. <pre name="code" class="python"># yum install -y gcc python perl vim man wget ntpdate sysstat zlib-devel krb5-devel openssl-devel zlib libyaml-devel readline-devel  libyaml-devel readline-devel gcc-c++ glibc-headers  readline libxml2 libxml2-devel libxslt libxslt-devel genisoimage sqlite  sqlite-devel mysql mysql-devel postgresql postgresql-devel git 经验证,这一句不要
  2. sudo yum install gcc ruby ruby-devel mysql-devel postgresql-devel postgresql-libs sqlite-devel libxslt-devel libxml2-devel yajl-ruby 官方文档中的脚本,但是安装bosh的时候还是会遇到错误.
  3. 在安装bosh_cli的时候会报nokogiri 安装错误,需要执行下面的语句修正
  4. sudo yum groupinstall "Development Tools"


1.3 安装EPEL repo  安装openstack 这部分是一havana讲解的,juno的安装请参考官方文档。

  1. # rpm -Uvh http://ftp.sjtu.edu.cn/fedora/epel/6/i386/epel-release-6-8.noarch.rpm

1.4. Upgrade 当前系统

  1. # yum -y upgrade

1.5 安装openstack repo, 目前CloudFoundry最高只能支持Havana版的Openstack

  1. # rpm -Uvh https://repos.fedorapeople.org/repos/openstack/EOL/openstack-havana/rdo-release-havana-9.noarch.rpm

应为现在Havana 已经归类为老版本的openstack 路径发生了变化 epel 的路径错误

nano /etc/yum.repo.d/rdo-release.repo
将路径修改为
baseurl=https://repos.fedorapeople.org/repos/openstack/EOL/openstack-havana/epel-6/

1.6 安装packstack

  1. # yum install -y openstack-packstack

1.7 同步时间

  1. # ntpdate -u time.asia.apple.com

1.8 安装单节点openstack

  1. # packstack —allinone
因为HAVANA 版本的packstack 已经终止了生命周期,所以直接运行肯定会报错,报错之后,回事生成一个answer-file的txt 文件,修改里面的配置项
CONFIG_USE_EPEL=n 
CONFIG_USE_EPEL=y
运行packstack --answer-file=xxx.txt 便可成功安装。
 
 

2.配置Openstack

使用packstack安装之后的Openstack,所有的服务都安装在了一个节点上,并且创建了一个叫demo tenant和叫demo的用户。本文即使用demo用户和demo tenant安装CloudFoundry。

2.0 安装后的Openstack Dashboard有个小bug,使用下面命令fix

  1. # sed -i 's/"Member"/"\_member\_"/' /etc/openstack-dashboard/local_settings
  2. # service httpd restart

2.1 demo tenant的默认配额(Quota)不足以安装CloudFoundry,所以先要增加demo的Quota

  1. # nova quota-update --instances 30  --ram 60000 --cores 40 $(keystone tenant-list | awk '/ demo/ {print $2}’)

2.2 扩展磁盘空间  这一部分可以不执行在juno的时候

Openstack 默认分配给cinder的空间为20G, 而CloudFoundry大约需要500G的空间,需要先扩展一下cinder-volumns的大小. 如果有未分配的磁盘空间,可以直接扩展cinder-volumes这个volume group。如果没有磁盘空间的话,这里需要借助一下linux的loop device。关于loop device,详见http://en.wikipedia.org/wiki/Loop_device

  1. # dd if=/dev/zero of=/var/lib/cinder/cinder-volumes1 bs=1k count=500000000
  2. # losetup -f  (查找一个没有使用的loop device,笔者这里使用/dev/oop2)
  3. # losetup /dev/loop2 /var/lib/cinder/cinder-volumes1
  4. # pvcreate /dev/loop2
  5. # vgextend cinder-volumes /dev/loop2
 

这样,Openstack就已经设置完成,可以准备安装CloudFoundry了

开源的PaaS方案:在OpenStack上部署CloudFoundry (二)部署OpenStack的更多相关文章

  1. [原]CentOS7安装Rancher2.1并部署kubernetes (二)---部署kubernetes

    ##################    Rancher v2.1.7  +    Kubernetes 1.13.4  ################ ##################### ...

  2. 开源的PaaS方案:在OpenStack上部署CloudFoundry (一)简介

    目录(?)[-] OpenStack简介 OpenStack是一个美国国家航空航天局和Rackspace合作研发的以Apache许可证授权并且是一个自由软件和开放源代码项目 OpenStack是一个云 ...

  3. 开源的PaaS方案:在OpenStack上部署CloudFoundry (四)使用Micro Bosh部署CloudFoundry

    使用bosh部署应用是需要两部分,一个是创建虚拟机使用的模板stemcell,另外一个是应该的Release.所以,部署CloudFoundry之前需要上传stencil和release 4.1.1 ...

  4. 开源的PaaS方案:在OpenStack上部署CloudFoundry (三)部署BOSH

    BOSH是CloudFoundry提供的用来安装部署和升级CloudFoundry的自动化工具,可是说是CloudFoundry的一部分.总体来说,BOSH是Client/Server结构, BOSH ...

  5. 开源的PaaS方案:在OpenStack上部署CloudFoundry (五)常见问题

    部署CloudFoundry可能遇到的问题 1. Bosh 报告 OpenStack API Request Entity Too Large error 解决办法,修改/etc/nova/api-p ...

  6. OpenStack使用Bosh部署CloudFoundry(一)—准备OpenStack环境

    版本说明: CloudFoundry:V2版本 OpenStack:Folsom或者Grizzly版本 本篇文章采用OpenStack Folsom+nova-network的OpenStack环境, ...

  7. 部署OpenStack问题汇总(二)--openstack dashboard 问题解决方案

    在打开dashboard的时候报错: LocationParseError at /admin/ (LocationParseError(...), 'Failed to parse: Failed ...

  8. Kubernetes部署SpringCloud(二) 部署ZUUL与服务 非host, 伸缩与负载均衡

    因为服务需要可缩容,所以不能使用host部署. 涉及两个应用,zuul,basic-info-api 验证,在k8s任意一个node 从zuul 访问 basic-info-api 创建一个Sprin ...

  9. K8S 部署 ingress-nginx (二) 部署后端为 tomcat

    在上面已经部署了 ingress-nginx, https://www.cnblogs.com/klvchen/p/9903480.html 创建 service 和 pods cd vi tomca ...

随机推荐

  1. nand ECC 算法记录

    nandflash ECC 原理记录. nand ECC 全称是Error Checking and correction. 该算法分为列校验和行校验. 列校验有下图所示: * 如上图所示, CP0 ...

  2. HTML资料——做网页时遇到的

    HTML <meta> 标签 浏览器支持 IE Firefox Chrome Safari Opera           所有浏览器都支持 <meta> 标签. 定义和用法 ...

  3. BusyBox inittab配置

    inittab第一行指定初始化脚本,开启所有应用程序,必须有. ::sysinit:/etc/init.d/rcS 在第一行执行完后,执行剩余行命令,此终端要接受命令交互需开启sh. ::askfir ...

  4. Hibernate使用createSqlQuery进行模糊查询时找不到数据

    1. 首先明确一点,使用createSqlQuery如下两种方式的占位符都可以使用,这个在官方的文档可以查到. 注意使用模糊查询时,赋值两边不可以添加单引号. Query query = sess.c ...

  5. Yii CDbCriteria常用用法

    $criteria = new CDbCriteria;$criteria->compare('name',$this->name,true,'OR'); //like部分匹配//$cri ...

  6. bootstrap 兼容哪些浏览器

    Bootstrap的目标是在最新的桌面和移动浏览器上有最佳的表现,也就是说,在较老旧的浏览器上可能会导致某些组件表现出的样式有些不同,但是功能是完整的.bootstrap3支持的浏览器: Chrome ...

  7. 登录centos虚拟机后显示-bash-4.1

    http://zhidao.baidu.com/link?url=KwpGOdwFw1oxnL71pvPlfRgbRL_IuQeYRzIYJjiDb2SnX0dQye5yUXqHAGSyuD6u2nD ...

  8. 为什么要把session存入数据库

    比如网易的通行证,一个session能进入很多的网易下的网站

  9. 第二百九十一节,RabbitMQ多设备消息队列-安装与简介

    RabbitMQ多设备消息队列-安装与简介 RabbitMQ简介 解释RabbitMQ,就不得不提到AMQP(Advanced Message Queuing Protocol)协议. AMQP协议是 ...

  10. 在Access中执行SQL语句

    Access在小型系统开发中等到了广泛使用.虽然Access提供了可视化的操作方法,但许多开发人员还是喜欢直接用SQL语句操作数据表.如何在Access中打开SQL视图,对于初次使用Access的程序 ...