`
南京老油条
  • 浏览: 57226 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

给基于bosh安装的cloudfoundry添加python支持

阅读更多

前言:

      最近由于项目需要,建立了一个基于cloudfoundry的PaaS云,由于基于bosh安装的cloudfoundry官方代码中未提供对python的支持,所以就必须自己实现了,也就有了本文, 至于使用Django的用户,请参照添加python的方法添加Django.


  1.在blobstore中添加python的安装包

      这里,我选择了建立一个本地的simple_blobstore_proxy.
      code: https://github.com/yudai/simple_blobstore_proxy
     启动simple_blobstore_proxy:

bundle install
bundle exec ./bin/simple_blobstore_server

     向本地blobstore中添加python的安装包,执行以下脚本以完成添加

require 'base64'
require 'httpclient'
require 'multi_json'
require "atmos"
require "uri"

file_path = '/Users/leon/cf-release/final_builds/packages/python/1/python/python-2.7.4.tgz' #修改成你的文件path

SHARE_URL_EXP = '1893484800'
@atmos_options = {:unsupported => true}
@atmos_options[:uid] = 'bb6a0c89ef4048a8a0f814e25385d1c5/user1'
@atmos_options[:url] = 'http://10.0.0.211:9999'
@atmos_options[:secret] = 'secret'
@endpoint = 'http://10.0.0.211:9999'
@bucket = ''
@client = HTTPClient.new
@bucket = @options && @options[:bucket] || "resources"
@headers = {}
user = 'admin'
password = 'admin'

if user && password
  @headers["Authorization"] = "Basic " + Base64.encode64("#{user}:#{password}").strip
end

def url(id=nil)
  ["#{@endpoint}/#{@bucket}", id].compact.join("/")
end

def create_file(id, file)
  @client.post(url(id), {:content => file}, @headers).content
end

def encode_object_id(object_id)
  hash_string = "GET\n/rest/objects/#{object_id}\n#{@atmos_options[:uid]}\n#{SHARE_URL_EXP}"
  secret = Base64.decode64(@atmos_options[:secret])
  sig = HMAC::SHA1.digest(secret, hash_string)
  signature = Base64.encode64(sig.to_s).chomp
  json = MultiJson.encode({:oid => object_id, :sig => signature})
  URI::escape(Base64.encode64(json))
end

file = File.open(file_path,'r:utf-8')
oid = create_file(nil, file)

puts  oid
puts  Digest::SHA1.file(file_path).hexdigest
puts  file.size

 

2.修改本地cf的final.yml使用本地blobstore

---
final_name: appcloud
min_cli_version: 1.0.3
blobstore:
  provider: simple
  options:
    endpoint: http://10.0.0.201:9999  #这里填写simple_blobstore_server的IP
blobstore_options: deprecated

     创建private.yml   

---
blobstore:
  simple:
    user: admin
    password: admin

  blob.yml中添加

python/python-2.7.4.tgz:
  object_id: f6ffff96-a78a-4bd2-b86d-45b7e28e73e0
  sha: 2283858b832fc391b8e96bb600e0b39e52ae97bd
  size: 14489063

cloud_controller中添加python
   cf-release/jobs/cloud_controller/templates/runtimes.yml

---
python27:
  description: Python 2.7.4
  version: 2.7.4
  executable: /var/vcap/packages/dea_python27/bin/python2.7
  staging: /var/vcap/packages/ruby/bin/ruby stage
  version_output: 2.7.4
  version_flag: "python -c 'import platform; print platform.python_version()'
  environment:
    PATH: /var/vcap/packages/ruby/bin:/var/vcap/packages/dea_python27/bin:/var/vcap/packages/imagemagick/bin:$PATH
    LD_LIBRARY_PATH: '/var/vcap/packages/mysqlclient/lib/mysql:/var/vcap/packages/sqlite/lib:/var/vcap/packages/libpq/lib:/var/vcap/packages/imagemagick/lib:$LD_LIBRARY_PATH'
  status:
    name: current
  series: python27
  category: python

  cf-release/jobs/cloud_controller/spec

- dea_python27

   cf-release/jobs/dea/spec

- dea_python27

   cf-release/packages中添加dea_python27目录
      dea_python27目录中创建文件packaging , spec   
    packaging

# abort script on any command that exit with a non zero value
set -e

tar xzf python/python-2.7.4.tgz
(
  cd Python-2.7.4
  ./configure --prefix=${BOSH_INSTALL_TARGET} 
  make
  make install
)

    spec

---
name: dea_python27
dependencies:
files:
- python/python-2.7.4.tgz

 
修改src
       cf-release/src/dea/config/dea.yml中添加   

python27:
    executable: /var/vcap/packages/dea_python27/bin/python2.7#python
    version: 2.7.4
    version_flag: python -c 'import platform; print platform.python_version()'
environment:

 4.创建修改后的release,上传,部署

bosh create release –force
bosh upload release dev_releases/envcloud-131.1.yml
bosh deployment new-cf.yml
bosh deploy

 

分享到:
评论
5 楼 南京老油条 2013-12-26  
kingsmall 写道
我想在cf上部署cf 不支持的runtime。所以想按照你的日志学习一下python。并且希望部署buildpack,你有什么建议么?


那就精读一下dea_next的代码吧
4 楼 kingsmall 2013-12-26  
我想在cf上部署cf 不支持的runtime。所以想按照你的日志学习一下python。并且希望部署buildpack,你有什么建议么?
3 楼 南京老油条 2013-12-24  
还有就是,cf原先是支持python的,但是bosh安装的没有提供python支持,原因嘛就不说了.
也就不要做这方面的尝试了.
2 楼 南京老油条 2013-12-24  
kingsmall 写道
抱歉初学者,请问cloud foundry环境是V2么?还有“建立一个本地的simple_blobstore_proxy.” ,这个是在cloud foundry 上面建立,还是非cloud founry 机器。


基于appcloud-131的,
simple_blobstore_proxy 是一个独立于cf之外负责存储的节点,当然cf本身也内置blobstore
1 楼 kingsmall 2013-12-23  
抱歉初学者,请问cloud foundry环境是V2么?还有“建立一个本地的simple_blobstore_proxy.” ,这个是在cloud foundry 上面建立,还是非cloud founry 机器。

相关推荐

    Cloud Foundry:云时代的Linux/LAMP.pdf

    例如,AppFog基于Cloud Foundry并增加了PHP支持,AppState建立了支持Perl和Python的私有云,而Tier 3则为Cloud Foundry添加了.NET支持。 在中国,新浪SAE宣布基于Cloud Foundry增加对Ruby的支持,盛大云的OC Luong...

    Cloud Foundry 体系结构

    Cloud Foundry 支持多种编程语言和框架,如 Java、Ruby、Node.js、Python、Go 等,允许开发者选择最适合他们需求的开发工具。此外,它还具备良好的扩展性,可以通过添加新的服务经纪人接入各种云服务,如数据库、...

    Cloud Foundry架构及应用介绍.pptx

    1. **BOSH**: 是一个用于部署和管理分布式系统的工具,用于创建、更新和监控Cloud Foundry实例。 2. **API**: 提供RESTful接口,允许用户和系统与Cloud Foundry进行交互,包括应用程序的部署、更新和管理。 3. **...

    淡成-Cloud Foundry PaaS平台对软件开发的影响

    Cloud Foundry支持多种编程语言和框架,比如Java、Python、Ruby和Node.js,以及提供多种服务,如数据库、消息队列、大数据服务等,其中还包括了对Hadoop的支持。 在私有云环境中安装Cloud Foundry涉及多个步骤,...

    cloud-foundry-notes:Cloud Foundry笔记

    1. **多语言支持**:Cloud Foundry支持多种编程语言,包括Java、Ruby、Node.js、Python、Go等,这使得它具有广泛的开发者基础。 2. **容器化**:Cloud Foundry使用Docker容器作为应用程序的运行环境,确保应用程序...

    python-buildpack-release:适用于Python Buildpack的BOSH版本

    Python Buildpack则是Cloud Foundry支持Python应用程序的关键组件,它自动识别、配置并优化Python应用的运行环境,确保代码能够顺利运行。 BOSH(Blockchain Operations System Hadoop)是Cloud Foundry团队开发的...

    Awesome-Cloud-Foundry

    1. 自动化部署:Cloud Foundry支持多种编程语言,如Java、Node.js、Python、Ruby等,通过简单的命令行工具,可以快速将应用程序部署到云环境中。 2. 持续交付:平台提供了持续集成和持续交付的能力,允许开发者频繁...

    cloud-foundry-public

    Cloud Foundry支持水平扩展,可以根据应用需求动态添加或减少实例。Diego组件的健康检查机制确保在故障发生时自动恢复应用,保持高可用性。 **5. 安全性** Cloud Foundry遵循安全最佳实践,提供角色基础的访问控制...

    sensu-client-boshrelease:sensu-client-boshrelease

    当前支持的CloudFoundry职位是: GoRouter 此版本的目的是与一起部署,以提供对CloudFoundry部署的监视和警报。 ##它不是什么 包含所有配置选项的通用Sensu Client安装。 入门 CF清单片段示例 releases: - name:...

    ansibletasker:Ansible极其简单的管理面板

    作为示例,它配置为设置BOSH / Cloud Foundry / Redis和虚拟剧本。 通过小的增强,您可以根据自己的需要进行更改,但是由于Ansible的免费产品很多,因此没有理由这样做。 随时发布建议/错误。 项目页面演示版要求该...

Global site tag (gtag.js) - Google Analytics