前言:
最近由于项目需要,建立了一个基于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
相关推荐
例如,AppFog基于Cloud Foundry并增加了PHP支持,AppState建立了支持Perl和Python的私有云,而Tier 3则为Cloud Foundry添加了.NET支持。 在中国,新浪SAE宣布基于Cloud Foundry增加对Ruby的支持,盛大云的OC Luong...
Cloud Foundry 支持多种编程语言和框架,如 Java、Ruby、Node.js、Python、Go 等,允许开发者选择最适合他们需求的开发工具。此外,它还具备良好的扩展性,可以通过添加新的服务经纪人接入各种云服务,如数据库、...
1. **BOSH**: 是一个用于部署和管理分布式系统的工具,用于创建、更新和监控Cloud Foundry实例。 2. **API**: 提供RESTful接口,允许用户和系统与Cloud Foundry进行交互,包括应用程序的部署、更新和管理。 3. **...
Cloud Foundry支持多种编程语言和框架,比如Java、Python、Ruby和Node.js,以及提供多种服务,如数据库、消息队列、大数据服务等,其中还包括了对Hadoop的支持。 在私有云环境中安装Cloud Foundry涉及多个步骤,...
1. **多语言支持**:Cloud Foundry支持多种编程语言,包括Java、Ruby、Node.js、Python、Go等,这使得它具有广泛的开发者基础。 2. **容器化**:Cloud Foundry使用Docker容器作为应用程序的运行环境,确保应用程序...
Python Buildpack则是Cloud Foundry支持Python应用程序的关键组件,它自动识别、配置并优化Python应用的运行环境,确保代码能够顺利运行。 BOSH(Blockchain Operations System Hadoop)是Cloud Foundry团队开发的...
1. 自动化部署:Cloud Foundry支持多种编程语言,如Java、Node.js、Python、Ruby等,通过简单的命令行工具,可以快速将应用程序部署到云环境中。 2. 持续交付:平台提供了持续集成和持续交付的能力,允许开发者频繁...
Cloud Foundry支持水平扩展,可以根据应用需求动态添加或减少实例。Diego组件的健康检查机制确保在故障发生时自动恢复应用,保持高可用性。 **5. 安全性** Cloud Foundry遵循安全最佳实践,提供角色基础的访问控制...
当前支持的CloudFoundry职位是: GoRouter 此版本的目的是与一起部署,以提供对CloudFoundry部署的监视和警报。 ##它不是什么 包含所有配置选项的通用Sensu Client安装。 入门 CF清单片段示例 releases: - name:...
作为示例,它配置为设置BOSH / Cloud Foundry / Redis和虚拟剧本。 通过小的增强,您可以根据自己的需要进行更改,但是由于Ansible的免费产品很多,因此没有理由这样做。 随时发布建议/错误。 项目页面演示版要求该...