常规的应用,大多数可以不经过任何修改即可部署于CloudFoundry云平台之上,但是在一些特殊情况下,总是不可避免地会出现一些细小的问题,如果在应用设计之初,就考虑到针对云平台的一些特殊情况,遵守云平台的规范,就会使应用更适应云平台环境,不止是CF平台,也包括其他的云平台,下边列举几条在应用设计之初应该考虑的情况:

1、避免使用本地文件系统

部署于CloudFoundry云平台的应用,在设计之时,应该避免对本地(服务器端)文件进行读写,原因如下:

1.1 应用实例的本地文件系统是短暂存在的

应用实例的本地文件系统依赖于当前应用实例的生命周期,这就意味着,当应用实例停止、重启或者崩溃的时候,原本分配与本实例的存储空间会被平台回收刷新病重新用于分配给新的应用实例,其中的所有数据即使是应用本身对这部分做出的修改也会被清除。

1.2 应用的不同实例的文件系统是各自独立的

在CloudFoundry环境中,所有的实例都是运行在一个“信息孤岛”之中,warden组件为每个实例构造了一个完全独立的运行环境,包括本地文件系统、内存等,即使是同一应用的不同实例,也是如此;而对于客户端来说,不同的客户端可能连到了不同的实例上,这就会出现什么现象,当一个客户端在应用的本地文件系统中写入了数据,另一个客户端同步读取,也会有可能读取不到任何数据,当然,如果刚好这两个客户端是连到了同一个实例上,而且实例在写入数据后没有发生类似重启、停止、崩溃的事件,那数据的读取还是正常的。

若有需求需要存储的数据需要贯穿应用实例的不同的生命周期,或者需要在不同的应用实例之间共享,最好的选择就是使用数据库或者Blob等存储服务,例如,可以使用部署于CloudFoundry环境上的MongoDB服务来存储非结构化的数据,使用其他关系型数据库如Mysql来存储结构化数据,另外,也可以使用如 Amazon S3, Google Cloud Storage, Dropbox,Box等公共服务,如果单是需要不同实例之间进行通讯或者数据共享,可以考虑使用Redis或者RabbitMQ等。

2、HTTP Session的非持久化与不可复制性

在客户端Cookie开启的情况下,CloudFoundry完全能够通过HTTP请求支持Session的关联和绑定,如果一个应用有多个实例,那么针对于某一客户端来说,它的所有请求,都会被路由到同一个应用实例,这就不会出现Session丢失的情况,这就允许服务器端可以对每个客户端进行一些Session临时数据的存储并在有效期内共享。

CloudFoundry平台本身不提供Session数据持久化和复制,如果一个应用实例出现崩溃或者停止、重启之类的事件,临时存储在HTTPsession中的数据将会丢失,这和上一条规范“避免本地文件系统读写”是密切相关的,当客户端与崩溃或者停止后重启的应用实例重新建立连接时,目标实例已经是一个全新的实例,而不是之前的实例,所以之前的session信息也已经不存在了。

对于那些在实例重启后仍然需要可用或者说可以在不同实例之间共享的Session数据,解决办法同上上一条规范:将数据保存在CloudFoundry的其他服务如redis、mysql或者其他开放的存储服务中。

3、HTTP和HTTPS端口的局限性

运行在CloudFoundry上的应用只能通过配置的URL接收数据,端口使用标准的HTTP端口-80和HTTPS端口-443。

CloudFoundry V2版本中的Mysql、redis、mongodb等服务可以通过CloudFoundry合作伙伴提供的客户端工具直接连接,而配置连接参数和认证参数可以通过查看绑定了该服务的应用的env.log文件或者CloudFoundry API接口获得。

CloudFoundry云环境中应用的特殊设计的更多相关文章

  1. 【新书推荐】《ASP.NET Core微服务实战:在云环境中开发、测试和部署跨平台服务》 带你走近微服务开发

    <ASP.NET Core 微服务实战>译者序:https://blog.jijiechen.com/post/aspnetcore-microservices-preface-by-tr ...

  2. Docker在云环境中的应用实践初探:优势、局限性与效能评测

    作者 商之狄 发布于 2014年11月10日 本文依据笔者所在团队的一些近期开发和应用的实践,整理出一些有意义的信息,拿出来和社区分享.其中既包括在云端应用Docker与相关技术的讨论,同时也有实施过 ...

  3. 阿里云环境中配置tomcat7可能出现的问题及解决方法

    前提是安装好了tomcat,但是输入ip+端口无法访问,那么情况有一下几种 (1)可能防火墙没有关闭 systemctl stop firewalld.service #停止firewall syst ...

  4. 四种方案:将OpenStack私有云部署到Hadoop MapReduce环境中

    摘要:OpenStack与Hadoop被誉为继Linux之后最有可能获得巨大成功的开源项目.这二者如何结合成为更猛的新方案?业内给出两种答案:Hadoop跑在OpenStack上或OpenStack部 ...

  5. 云原生时代的DevOps平台设计之道

    开发人员与运维人员是 IT 领域很重要的两大人群,他们都会参与到各种业务系统的建设过程中去.DevOps 是近年间火爆起来的一种新理念,这种理念被很多人错误的解读为"由开发人员(Dev)学习 ...

  6. 【转载】如何在FPGA设计环境中添加加时序约束

    转自:http://bbs.ednchina.com/BLOG_ARTICLE_198929.HTM 如何在FPGA设计环境中加时序约束    在给FPGA做逻辑综合和布局布线时,需要在工具中设定时序 ...

  7. Azure环境中Nginx高可用性和部署架构设计

    前几篇文章介绍了Nginx的应用.动态路由.配置.在实际生产环境部署时,我们需要同时考虑Nginx的高可用性和部署架构. Nginx自身不支持集群以保证自身的高可用性,商业版本的Nginx+推荐: T ...

  8. Nginx技术研究系列7-Azure环境中Nginx高可用性和部署架构设计

    前几篇文章介绍了Nginx的应用.动态路由.配置.在实际生产环境部署时,我们需要同时考虑Nginx的高可用性和部署架构. Nginx自身不支持集群以保证自身的高可用性,商业版本的Nginx+推荐: T ...

  9. 理解Docker(6):若干企业生产环境中的容器网络方案

    本系列文章将介绍 Docker的相关知识: (1)Docker 安装及基本用法 (2)Docker 镜像 (3)Docker 容器的隔离性 - 使用 Linux namespace 隔离容器的运行环境 ...

随机推荐

  1. HDU 5105 Math Problem

    让求  f(x)=|a∗x3+b∗x2+c∗x+d|(L≤x≤R)的最大值 这个题目讨论a和b的值,如果a==0的话,那么这个方程就变成了一个一元二次方程,直接找端点和对称轴(如果对称轴在给定的区间内 ...

  2. python增删改查

    ###增删改查 names = ["zhangding","wangxu","wudong","cheng"] #增na ...

  3. 数据库 ORM框架 ORMLite

    几个ORM框架的比较 先介绍一下ORM的概念,以前也一直听说,不过没详细了解啥意思.其全称叫做对象关系映射(Object Relation Mapping),是一种程序设计技术,用于实现面向对象编程语 ...

  4. asp.net,mvc4,mysql数据库,Ef遇到问题集合

    asp.net  mvc  mysql数据库,在我一个新手自学MVC4时遇到如下的问题,一一解决掉的方法记录如下方便自己日后查看,也为了方便一些像我一样的新手遇到如下问题时,提供参考 问题一: 解决办 ...

  5. JAVA集合差异

    接口 简述 实现 操作特性 成员要求 Set 成员不能重复 HashSet 外部无序地遍历成员 成员可为任意Object子类的对象,但如果覆盖了equals方法,同时注意修改hashCode方法. T ...

  6. jQuery中的综合动画

    所谓综合动画,就是在链式表达式依次执行相关animate函数,其中的参数是以键值对的方式存在的. 如下示例,就展示了一个基本的综合动画. <!DOCTYPE html PUBLIC " ...

  7. asp.net 调用天气所遇到的问题

    由于在项目用了显示天气的功能,原有的调用方法 直接通过      <iframe name="weather_inc" src="http://i.tianqi.c ...

  8. Android 多线程:使用Thread和Handler

    当一个程序第一次启动时,Android会同时启动一个对应的主线程(Main Thread),主线程主要负责处理与UI相关的事件,如:用户的按键事件,用户接触屏幕的事件以及屏幕绘图事件,并把相关的事件分 ...

  9. fedora 安装nginx+php+mysql

    环境 fedora 最新版 20 参考:http://www.cnblogs.com/beceo/archive/2012/08/21/2648378.html ------------------- ...

  10. 如何把PPT变小|PowerPoint文档减肥的几种方法

    使用powerpoint制作幻灯片的过程中,经常出现过这样的情况,制作幻灯片时,出于内容的需要和美观的需要,添加了许多图片和Excel表或者OLE对象,成倍增大了文档的体积,结果导致: 1.页面编辑人 ...