虚拟化Java应用程序:最佳实践(JavaOne 2011)

贾斯汀·穆雷(Justin Murray)早五分钟就开始了他的演讲[“虚拟化Java应用程序:最佳实践”(21860)],并说虚拟化已经到了人们不再需要担心利用虚拟化的地步。 他说他的演讲大约有一年的历史,是一个团队的工作。

相对较小的房间(Nikko Carmel I / II)挤满了人,似乎只靠近站立的房间(坐席帮助每个人就座)。 早上的策略性主题演讲稍有结束,人们在试图离开时陷入了宴会厅,而本次演讲的提早开始导致很多人迟到,这有些分散注意力。 我不怪演讲者提早开始,因为他有很多很好的信息要讲。 最大的问题是后勤延迟迫使人们离开已经超过计划的结束时间的主题演讲。

Muray具有七个虚拟化最佳实践,只有前两个(虚拟机内存和虚拟CPU /物理CPU /线程)是Java特有的。 大多数人在存储区域而不是处理/ CPU区域犯了虚拟化错误。 Murray指出,Java开发人员无需执行任何操作即可使用虚拟化。 他们不需要更改任何代码,也不需要更改任何设置。

  1. 虚拟机内存
  2. 中央处理器
  3. 磁盘I / O
  4. 网络I / O
  5. 计时表
  6. 微观基准
  7. 监控与管理

一个易于理解的虚拟化Java应用程序的初始最佳实践是:“ Java堆需要始终保持在物理内存中。” 他还建议使用大内存页。 不要将那么多虚拟机塞入物理内存,以使每个VM的总最大堆空间使用的内存多于物理内存中可用的内存。

默里的第一个正式最佳实践是“ 1。 虚拟机内存:调整虚拟机的内存大小以留出足够的空间。” 他指出,有一个公式可以计算要使用的内存量,以考虑该内存的许多需求。 他说,此公式已记录在白皮书和同事的书中。 Murray说,虽然对于一个小型应用程序可能有太多的JVM内存,但他通常赞成为JVM分配大量的内存以用于虚拟化。 Murray还建议使用VMware Distributed Resource Scheduler(DRS) 。 他的另一个广告宣传是针对Java的vFabric弹性内存(EM4J),它与VMware的称为“ tc服务器 ”的“ Tomcat之味”一起提供。 Murray表示,尽管在大多数情况下都担心Java中内存的过度使用,但在使用tc服务器和EM4J时并不需要。 Murray还使用了esxtop 。

解决了内存问题后,Murray转向了主要的CPU。 他从对线程和虚拟CPU的观察开始本节。 他的幻灯片中写道:“ Java线程可随时在一个vCPU上执行”,而“ vCPU则可随时在一个物理CPU上调度。” Murray补充说,他与之合作的大多数客户正在使用四个虚拟CPU,但现在最多支持32个虚拟CPU。线程通常在监视器或套接字上等待释放,并且Murray认为大多数Java应用程序并未完全使用theads。 通常,Murray倾向于使用“对您的应用程序来说实用的虚拟CPU数量最少”。 Murray表示,使用命令行选项-Xgcthreads等同于说:“我比JVM更了解。”

Murray表示虚拟化不再害怕I / O。 他说,从Java虚拟化的角度来看,网络I / O比磁盘I / O更重要。 Murray指出,交换对物理机上的VM不利,对于虚拟机上的VM同样不利。

Murray提供的一个更好的建议应该被更普遍地理解(但似乎不是),它只是对自己的应用程序进行基准测试,并且仅基于特定应用程序的基准测试来做出决策。 他补充说,使用应用程序的“代表性子集”还不够好。

为了进行监视和管理,Murray建议从每台计算机开始一个JVM进程,然后逐步扩展到虚拟机中所需的JVM数量,一次确定一个上限。 他在幻灯片上的最后一个项目符号建议使用vCenter或esxtop来查看Java应用程序的哪些部分正在消耗资源。

Murray的“简短故事”是,对于虚拟化而言,Java开发人员通常不需要调整JVM垃圾回收策略,线程池大小或JDBC连接池大小,而对于物理服务器则不需要进行任何调整。 唯一应使用的命令行选项是用于指定大页面。

Murray讨论了使用Capacity Planner进行大约30天的收集,以了解哪些候选人是虚拟化的良好候选人。 Murray指出,您不能凭空创建硬件,因此在这种情况下,虚拟化将无法​​帮助大量使用硬件。

Murray总结说:“ Java中间件和应用程序应该虚拟化。”

Murray在VMware工作,VMware 在VMware最佳实践指南上提供了企业Java应用程序 。 Murray在演讲中引用了VMware的技术白皮书 。

参考: JavaOne 2011:虚拟化Java应用程序: JCG合作伙伴的 最佳实践   实际事件启发博客中的达斯汀·马克思。


翻译自: https://www.javacodegeeks.com/2012/02/virtualizing-your-java-applications.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/373541.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

linux里hba状态_Windows和Linux系统查看HBA卡wwn号的方法 | 系统之家官网

一、windows 系统在windows系统中,可以使用fc hba卡厂家提供的管理软件查看光纤适配器的wwn号码,具体如下:qlogic:sansurferemulex:hbanyware二、suse linux 9查看 /proc/scsi/qla2xxx/* ,并以 adapter-por…

”二柱子“个人项目

”二柱子“个人项目 关于二柱子的个人项目,据说……是这么发生的…… 二柱子因为懒(,,• ₃ •,,),要给他上小学的儿子编写个能够出小学四则运算题目的程序。老师上课的时候又添加了条件: 1、打印至少30道题 2、除了整数之外,还要…

phpstorm9 增加对.vue的支持

1、安装vue.js插件 2、设置javascript version为ECMAScript 6 3、 <script type"text/ecmascript-6"> </script>转载于:https://www.cnblogs.com/lobtao/articles/6044378.html

Eclipse中的集成Git插件删除线上远程分支

Eclipse 的忠实党,在使用Git 多人协作以分支的形式开发应用时分支合并到主干后往往再没什么用(我的做法是保留一两周再干掉),在此记录使用Eclipse的Git 插件来删除无用的分支。 操作步骤: 项目右键 — Team — Remote — Push — Next — Finesh 1,下拉框选择你要删除的远程分支…

mysql 查询系统_使用select和show命令查看mysql数据库系统信息

(1).select显示当前日期和时间mysql> select now();---------------------| now() |---------------------| 2019-06-05 13:46:20 |---------------------1 row in set (0.00 sec)显示当前日期mysql> select curdate();------------| curdate() |------------| 2019-06-0…

从MongoDB GridFS流式传输文件

不久前&#xff0c;我在Twitter上发布了自己的最新作品&#xff0c;即从MongoDB GridFS传输文件进行下载&#xff08;而不是将整个文件存储到内存中然后提供服务&#xff09;&#xff0c;这是我取得的一个小胜利。 我答应就此事写博客&#xff0c;但不幸的是&#xff0c;我的特…

0. 洗好虾和锅 1. 放水放老姜&#xff0c;烧开&#xff0c;放盐 2. 放入虾&#xff0c;沸腾后&#xff0c;尝咸淡 3. 放香葱&#xff0c;乘起来转载于:https://www.cnblogs.com/gary-tao/p/5248139.html

读字库遇到坑爹的问题

转载请注明出处&#xff1a;http://blog.csdn.net/qq_26093511/article/details/53099262 最近在做一个led显示屏的项目&#xff0c; 我想显示 “常”&#xff0c;“州”&#xff0c;“大”&#xff0c;“学”这几个字&#xff0c;但是只能显示 “常” 和 “大”&#xff0c;…

如果–否则为编码风格最佳实践

下面的帖子将是一个高级花括号讨论&#xff0c;没有对与错的答案&#xff0c;只是更多的“品味”。 它是关于是否将“ else”&#xff08;以及其他关键字&#xff0c;例如“ catch”&#xff0c;“ finally”&#xff09;放在换行符上。 有些人可能会写 if (something) {doIt(…

MongoDB 去重(distinct)查询后求总数(count)

在使用MonoDB 做报表汇总经常的有去重统计总数的需求,在此总结一下实现方式: 1, 直接使用distinct 语句查询, 这种查询会将所有查询出来的数据返回给用户, 然后对查询出来的结果集求总数(耗内存,耗时一些) var len db.student.distinct("name",{"age" :…

adobe premiere pro cc2015.0已停止工作 解决办法

adobe premiere pro cc2015.0已停止工作 一直报错 解决办法就是&#xff1a; 删除【我的电脑】- 【我的文档】下的 Adobe 下的Premiere Pro文件夹 现象就是怎么重新安装都不管用Premiere 参考路径 &#xff1a;C:\Users\xxx\Documents\Adobe\Premiere Pro 转载于:https://…

java mysql 语句解析器_几种基于Java的SQL解析工具的比较与调用

1、sqlparserhttp://www.sqlparser.com/优点&#xff1a;支持的数据库最多&#xff0c;除了传统数据库外还支持hive和greenplum一类比较新的数据库&#xff0c;调用比较方便&#xff0c;功能不错缺点&#xff1a;收费&#xff0c;500$起2、Apache Calcite一个构建JDBC或者ODBC访…

Css Sprites 多张图片整合在一张图片上

CSS Sprites原理&#xff1a; CSS Sprites其实就是把网页中一些背景图片整合到一张图片文件中&#xff0c;再利用CSS的“background-image”&#xff0c;“background- repeat”&#xff0c;“background-position”的组合进行背景定位&#xff0c;background-position可以用数…

MongoDB 分析查询性能

cursor.explain(“executionStats”)和 db.collection.explain(“executionStats”) 方法提供关于查询性能的相关信息。这些信息可用于衡量查询是否使用了索引以及如何使用索引。 db.collection.explain() 还提供有关其他操作的执行信息。例如 db.collection.update()。 有关详…

无需复杂插件即可从Eclipse启动和调试Tomcat

像Eclipse这样的现代IDE提供了各种插件来简化Web开发。 但是&#xff0c;我相信将Tomcat作为“常规” Java应用程序启动仍然可以提供最佳的调试体验。 大多数情况下&#xff0c;这是因为这些工具将Tomcat或任何其他servlet容器作为外部进程启动&#xff0c;然后在其上附加一个远…

flutter 国际化_Flutter 开发实战资源推荐

开工第一天&#xff0c;来点轻松的资源推荐。这是一篇实战类资源推荐&#xff0c;其实Flutter的入门资料官方已经做得很好了&#xff0c;如果你是零基础&#xff0c;还是建议先啃一遍官方的教程&#xff0c;然后再看以下实战资源&#xff0c;相信在你看官方课程中涉及到的一些疑…

2-5-666:放苹果

描述把M个同样的苹果放在N个同样的盘子里&#xff0c;允许有的盘子空着不放&#xff0c;问共有多少种不同的分法&#xff1f;&#xff08;用K表示&#xff09;5&#xff0c;1&#xff0c;1和1&#xff0c;5&#xff0c;1 是同一种分法。输入第一行是测试数据的数目t&#xff08…

JSF和“立即”属性–命令组件

JSF中的即时属性通常被误解。 如果您不相信我&#xff0c;请查看Stack Overflow 。 造成这种混乱的部分原因可能是输入&#xff08;即<h&#xff1a;inputText />&#xff09;和命令&#xff08;即<h&#xff1a;commandButton />&#xff09;组件都立即可用&#…

通过joystick遥感和按键控制机器人--11

原创博客&#xff1a;转载请表明出处&#xff1a;http://www.cnblogs.com/zxouxuewei/ 1.首先安装joystick遥控器驱动&#xff1a; sudo apt-get install ros-indigo-joystick-drivers ros-indigo-turtlebot-teleop 2.运行tulterbot机器人&#xff1a; roslaunch rbx1_bringup …

php mysql 线程安全_PHP 线程安全与非线程安全版本的区别深入解析

从2000年10月20日发布的第一个Windows版的PHP3.0.17开始的都是线程安全的版本&#xff0c;这是由于与Linux/Unix系统是采用多进程的工作方式不同的是Windows系统是采用多线程的工作方式。如果在IIS下以CGI方式运行PHP会非常慢&#xff0c;这是由于CGI模式是建立在多进程的基础之…