CloudFoundry云环境中应用的特殊设计
常规的应用,大多数可以不经过任何修改即可部署于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云环境中应用的特殊设计的更多相关文章
- 【新书推荐】《ASP.NET Core微服务实战:在云环境中开发、测试和部署跨平台服务》 带你走近微服务开发
<ASP.NET Core 微服务实战>译者序:https://blog.jijiechen.com/post/aspnetcore-microservices-preface-by-tr ...
- Docker在云环境中的应用实践初探:优势、局限性与效能评测
作者 商之狄 发布于 2014年11月10日 本文依据笔者所在团队的一些近期开发和应用的实践,整理出一些有意义的信息,拿出来和社区分享.其中既包括在云端应用Docker与相关技术的讨论,同时也有实施过 ...
- 阿里云环境中配置tomcat7可能出现的问题及解决方法
前提是安装好了tomcat,但是输入ip+端口无法访问,那么情况有一下几种 (1)可能防火墙没有关闭 systemctl stop firewalld.service #停止firewall syst ...
- 四种方案:将OpenStack私有云部署到Hadoop MapReduce环境中
摘要:OpenStack与Hadoop被誉为继Linux之后最有可能获得巨大成功的开源项目.这二者如何结合成为更猛的新方案?业内给出两种答案:Hadoop跑在OpenStack上或OpenStack部 ...
- 云原生时代的DevOps平台设计之道
开发人员与运维人员是 IT 领域很重要的两大人群,他们都会参与到各种业务系统的建设过程中去.DevOps 是近年间火爆起来的一种新理念,这种理念被很多人错误的解读为"由开发人员(Dev)学习 ...
- 【转载】如何在FPGA设计环境中添加加时序约束
转自:http://bbs.ednchina.com/BLOG_ARTICLE_198929.HTM 如何在FPGA设计环境中加时序约束 在给FPGA做逻辑综合和布局布线时,需要在工具中设定时序 ...
- Azure环境中Nginx高可用性和部署架构设计
前几篇文章介绍了Nginx的应用.动态路由.配置.在实际生产环境部署时,我们需要同时考虑Nginx的高可用性和部署架构. Nginx自身不支持集群以保证自身的高可用性,商业版本的Nginx+推荐: T ...
- Nginx技术研究系列7-Azure环境中Nginx高可用性和部署架构设计
前几篇文章介绍了Nginx的应用.动态路由.配置.在实际生产环境部署时,我们需要同时考虑Nginx的高可用性和部署架构. Nginx自身不支持集群以保证自身的高可用性,商业版本的Nginx+推荐: T ...
- 理解Docker(6):若干企业生产环境中的容器网络方案
本系列文章将介绍 Docker的相关知识: (1)Docker 安装及基本用法 (2)Docker 镜像 (3)Docker 容器的隔离性 - 使用 Linux namespace 隔离容器的运行环境 ...
随机推荐
- python简单小爬虫爬取易车网图片
上代码: import requests,urllib.request from bs4 import BeautifulSoup url = 'http://photo.bitauto.com/' ...
- Python开发【第七篇】:面向对象 和 python面向对象进阶篇(下)
Python开发[第七篇]:面向对象 详见:<Python之路[第五篇]:面向对象及相关> python 面向对象(进阶篇) 上一篇<Python 面向对象(初级篇)> ...
- js页面加载事件
<body onload="myfunction()" > </body> <script type="text/javascript&qu ...
- get the text value of a selected option.
<select id="myselect"> <option value="1">Mr</option> <optio ...
- OC - 20.多图下载
效果图 常见问题及解决方法 图片重复下载 将内存保存在内存或沙盒中. 若下载的图片量较大,则会出现UI界面不流畅的现象 在子线程中执行下载操作,然后回到主线程成中进行UI界面的刷新. 由于cell的循 ...
- Swift - 33 - 返回函数类型和函数嵌套
//: Playground - noun: a place where people can play import UIKit /*---------------------------返回函数类 ...
- 重新开始学习javase_Exception
“违例”(Exception)这个词表达的是一种“例外”情况,亦即正常情况之外的一种“异常”.在问题发生的时候,我们可能不知具体该如何解决,但肯定知道已不能不顾一切地继续下去.此时,必须坚决地停下来, ...
- 全志A10_linux3.0内核编译记录
第一次尝试编译时按照 Android A10(4.0.3)系统编译详解.pdf 编译打包出来的镜像可用,但是内核没有生成Module.symvers .后来进一步研究才知道 ./build.sh 脚本 ...
- C++学习笔记4——类的封装(2)
简介: 重载的运算符是具有特殊名字的函数:它们的名字由关键字operator和其后要定义的运算符号共同组成.其中一元运算符有一个参数,二元运算符有两个参数. 可以被重载的运算符 + - * / % ^ ...
- ACCESS中类型操作(限制、转换)
ACCESS如何保留两位小数 1.可以通过修改表结构中字段的“小数位数”即可. 2.可以通过“更新查询”,将所有该字段的值更新为round(字段名,2) ACCESS如何转换类型 每个函数都可以强制将 ...