ApacheStratos的安装与配置

目录

我们提供的服务有:成都网站设计、成都做网站、微信公众号开发、网站优化、网站认证、万州ssl等。为上千家企事业单位解决了网站和推广的问题。提供周到的售前咨询和贴心的售后服务,是有科学管理、有技术的万州网站制作公司

  • 创建OpenStack镜像

  • 配置Puppet Master

  • 运行Stratos

  • Troubleshooting

以下所有软件的OS环境均为Ubuntu14.04

1. 创建OpenStack镜像

  • 制作OpenStack的基础镜像Ubuntu14.04
    参考:Step 1 - Spawn an instance

  • 启动虚拟

  • 修改镜像源

# vi /etc/apt/source.list1

删除所有官方的镜像源,添加阿里云的镜像源,并执行apt-get update。

deb http://cn.archive.ubuntu.com/ubuntu/ trusty main restricted universe multiverse
deb http://cn.archive.ubuntu.com/ubuntu/ trusty-security main restricted universe multiverse
deb http://cn.archive.ubuntu.com/ubuntu/ trusty-updates main restricted universe multiverse
deb http://cn.archive.ubuntu.com/ubuntu/ trusty-proposed main restricted universe multiverse
deb http://cn.archive.ubuntu.com/ubuntu/ trusty-backports main restricted universe multiverse12345
  • 修改时区为中国时区,Puppet Master和Agent的时间完全同步,否则会出现无法正常通讯的情况。

# cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime1
  • 修改Python源为国内的豆瓣提供的源,否则会出现镜像制作步骤中配置cartridge时超时的问题,错误信息为:pip installs-gittle timeout。

# cd ~# mkdir .pip# cd .pip# vim pip.conf1234

添加并保存如下内容:

[global] index-url = http://pypi.douban.com/simple [install] trusted-host = pypi.douban.com1234
  • 执行如下命令,进行Cartriage配置

sudo -iapt-get install zip unzip
mkdir -p /root/bin
cd /root/bin
wget "https://git-wip-us.apache.org/repos/asf?p=stratos.git;a=blob_plain;f=tools/config-scripts/ec2/config.sh;hb=HEAD" -O config.sh
chmod +x config.sh
wget "https://git-wip-us.apache.org/repos/asf?p=stratos.git;a=blob_plain;f=tools/init-scripts/ec2/ubuntu/init.sh;hb=HEAD" -O init.sh
chmod +x init.sh
mkdir -p /root/bin/puppetinstall
wget "https://git-wip-us.apache.org/repos/asf?p=stratos.git;a=blob_plain;f=tools/puppet3-agent/puppetinstall/puppetinstall;hb=HEAD" -O puppetinstall/puppetinstall
chmod +x puppetinstall/puppetinstall
wget "https://git-wip-us.apache.org/repos/asf?p=stratos.git;a=blob_plain;f=tools/puppet3-agent/stratos_sendinfo.rb;hb=HEAD" -O stratos_sendinfo.rb
chmod +x stratos_sendinfo.rb12345678910111213

此处需要注意最后一步,官网的步骤中没有对stratos_sendinfo.rb赋可执行权限的操作。

  • 设置时间与Puppet Master保持一致

sed -i 's:^TIMEZONE=.*$:TIMEZONE=\"Asia/Shanghai\":g' /root/bin/puppetinstall/puppetinstall1
  • 运行config.sh文件,此处的service-name可输入default或者不输入值,若输入php,在运行期间会出现php配置失败 的情况,可能是由于puppet脚本有错误。(刚配置php可以访问ip:80,但cartriage agent运行完后无法访问。Stratos Application的启动状态一直停留在starting,原因是程序会访问80端口但无响应)。

2. 配置Puppet Master

  • 参考官网步骤:6. Setup Puppet Master

  • 此处注意,需要将apache-stratos-python-cartridge-agent-4.1.5.zip文件解压后去掉4.1.5的版本号去掉后重新解压后拷贝到puppet的modules的相关目录下。

  • 配置base.pp文件中的内容时,需要与nodes目录下的其他资源的定义相符合,比如在base.pp目录下定义 了$tomcat_version这个变量,则需要在/etc/puppet/manifests/nodes/tomcat.pp目录下的内容与之对 应,这样才能正确的文件推送。

node /tomcat/ inherits base {  $tomcat_version            = '8.0.36'
  $docroot = "/mnt/apache-tomcat-${tomcat_version}/webapps/"
  $samlalias="/mnt/apache-tomcat-${tomcat_version}/webapps/"

  class {'tomcat':}
}1234567

3. 运行Stratos

  • 启动Stratos
    调试运行时可启动H2数据库,连内置CEP。

  • 创建各Stratos对象
    创建Cartridge的代码如下:

{
    "type": "java",
    "category": "framework",
    "provider": "oracle",
    "host": "leaptocloud.com",
    "displayName": "java",
    "description": "java Cartridge",
    "version": "7",
    "multiTenant": true,
    "portMapping": [
        {
            "name": "http-22",
            "protocol": "http",
            "port": 22,
            "proxyPort": 8280
        }
    ],
    "iaasProvider": [
        {
            "type": "openstack",
            "p_w_picpathId": "RegionOne/f8850fcb-a1a5-4288-a808-2c2a0b97adcb",
            "property": [
                {
                    "name": "instanceType",
                    "value": "RegionOne/2"
                }
            ],
            "networkInterfaces": [
                {
                    "networkUuid": "84eeb7b2-82f4-478a-b768-e24d7d0544ee"
                }
            ]        }
    ]}1234567891011121314151617181920212223242526272829303132333435

portMapping配置需要填正确的port配置。配置错误时,会出现applicaiton无法启动的问题。

4. Troubleshooting

  • Cartridge agent运行时可查看syslog日志,若出现不能正常启动或者启动出错的情况,可手动删除python agent进行,修改配置后,重新运行agent程序:

# nohup /mnt/apache-stratos-python-cartridge-agent-/agent.py &1

并查看nohup日志进行调试运行。

  • 调试关键路径
    /root/bin/puppetinstall
    /tmp/payload/launch-params
    /root/bin/puppetinstall/puppetinstall


本文标题:ApacheStratos的安装与配置
文章出自:http://myzitong.com/article/pijjjo.html