`
marlonyao
  • 浏览: 253548 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

startup java fast

    博客分类:
  • java
阅读更多
据我所知,有不少人鄙视java,认为它笨重而缓慢,笨重倒是事实,但慢其实是站不脚的,据专业网站的测评,Java和C/C++的性能平均差距不到两倍,在某些情况下甚至比C/C++还快。为什么Java给人的印象很慢?主要是在于java的启动速度特别慢,在我的机器上运行HelloWorld的时间需要平均0.35秒,这只是有短暂延时,但第一次启动可能需要2秒或者更长,这种进步得益于Class Data Sharing技术。一个python版的hello程序大概需要0.05秒,这可以说是“立即”。一个C程序需要5毫秒,仍然是“立即”,对人来说,python和c一样快,java就明显要慢多了。运行一个helloworld的scala脚本就更慢了,最快也要2.5秒,第一次启动时要7秒。总的来说,Java的慢主要体现在启动上,对于一个HelloWorld程序,98%以上的时间花在启动上,真正执行时间只需要4毫秒。

要提高Java的启动速度,一种方法就是让jvm常驻内存,这样就不用每次启动时都去加载一次jvm了,我不知道该怎么做,但肯定不简单,不然的话sun(现在是oracle)早就这么做了。印象中.net的启动速度似乎要比java快,不知是否采用了这种方法,毕竟那是MS自家的产品,优化起来也容易一些。我这里要说的是另外一种解决方法,用Java实现一个服务器,在一个固定端口监听客户端请求,来执行给定的Java程序,客户端并不直接执行Java程序,只是将要执行的程序路径告诉服务器,实际服务器来执行,这样只需要服务器一次启动jvm,客户端并不需要启动jvm,速度就会很快。客户端可以用C甚至用python来实现。fsc利用的就是这个思想,fsc类似scalac,但它比scalac快多了,fsc并不直接编译,只是连接编译deamon进程,让它去编译。

通过这种方式来执行java,最有名的解决方案是nailgun。但我并不喜欢它,因为它并不像我期望那样的工作,它对用户不透明。例如你在当前文件夹下有个HelloWorld的class,你执行"ng HelloWorld",结果它会说找不到HelloWorld类,因为服务器启动时HelloWorld类所在的目录并不是classpath。nailgun可以通过命令行来动态修改classpath路径,因此你可以在运行HelloWorld之前先将HelloWorld所在路径添加到nailgun服务器的classpath路径中去,添加时要指定绝对路径,"."实际上代表的是服务器启动时的路径。我觉得这些麻烦是不必要的,应当向客户端屏蔽“它实际上是在服务器端运行”这一事实,就好像它完全在本地启动jvm并执行一样。nailgun提供了一些额外的特性,包括给类起个别名,支持特定于nailgun的main启动方法,在这其中可以传递环境变量,我觉得这些都是没有必要的。

由于我不喜欢nailgun,并且我自认为找到了更好的实现方式(后来证明是错的),所以我就自己写了个startup-java-fast。nailgun对每个客户端是使用一个单独的线程去运行,由于线程在同一个进程空间运行,不可能完全隔离各个客户端,另外在同一个进程中意味所有客户端共享环境变量。我最初的想法是使用fork()系统调用,fork()会创建一个新的子进程,由于fork的实现方式都是copy-on-write,开销很低。fork的主要缺点在于java本身不提供对其的支持,我不得不借助jni来实现fork调用。我写了一个小程序来验证,证明行得通。另一个缺点就是fork只在unix下才有,在windows下没有相应的api,因为我基本不用windows,因此至少对我来说这不是问题。可是最终在实现时碰到很灵异的问题,这个问题在我之前写的验证程序中不存在。这是由于fork出来的子进程只会复制父进程中一个线程的内容,由于jvm明显使用了多线程(至少还有一个GC线程),这就导致子进程中的jvm工作不正常,出错时甚至没有任何错误提示。

由于使用进程方式失败,我只能使用线程模型,基本上走的是nailgun的路子,不同的是我致力于达到客户端的透明性。但由于线程模型的固有缺点,这个目标没有达到,我想到的主要有几点:
  1. 使用相对路径创建的文件是相对服务器端路径。虽然我设置了user.dir系统属性为客户端的当前路径,当由于创建文件是使用native调用,不理会user.dir系统属性。getAbsoluteFile()可以将相对路径转为绝对路径,它使用user.dir系统属性,这是用户所期望的,因此可以使用这种方式来绕过此问题。
  2. 不能再调用System的setIn/setOut/setErr/setProperties方法,因为我已经将这些值设置为ThreadLocal,这样每个客户端才会有独立的值。
  3. 调用多线程的客户端可能会有问题,尤其是当有个后台线程在运行时,这时客户主线程退出了,后台线程并不会退出,这会导致一些资源不能释放。我想到一种方法能够部分跟踪客户线程创建的其它线程,这样在主线程退出时可以回收这些线程,但我还没有实现。


startup-java-fast可以从这里下载,先执行服务器,默认监听端口是0x2304:
$ java -jar sjfserver.jar


客户端我有两种实现,分别是C和python的,因为使用了对文件描述符的select,应该都不支持windows:
$ time sjf java HelloWorld
Hello World

real    0m0.017s
user    0m0.001s
sys     0m0.003s

对比python的hello程序:
$ time python hello.py
Hello World

real    0m0.045s
user    0m0.026s
sys     0m0.016s

可以看到用sjf来执行HelloWorld要比python快大约2倍。

0
4
分享到:
评论

相关推荐

    VB控制计算机并口示例(含完整可以运行源代码)

    VB控制计算机并口示例(含完整可以运行源代码) 可以通过并口直接控制MCU,做SW控制不错,关键还可以学习并口硬件控制学习。含详细源代码哦

    python毕业设计基于PyTorch的手语识别系统源码+数据集(完整项目代码)

    python毕业设计基于PyTorch的手语识别系统源码+数据集(完整项目代码),本资源中的源码都是经过本地编译过可运行的,评审分达到98分,资源项目的难度比较适中,内容都是经过助教老师审定过的能够满足学习、毕业设计、期末大作业和课程设计使用需求,如果有需要的话可以放心下载使用。 python毕业设计基于PyTorch的手语识别系统源码+数据集(完整项目代码)python毕业设计基于PyTorch的手语识别系统源码+数据集(完整项目代码)python毕业设计基于PyTorch的手语识别系统源码+数据集(完整项目代码)python毕业设计基于PyTorch的手语识别系统源码+数据集(完整项目代码)python毕业设计基于PyTorch的手语识别系统源码+数据集(完整项目代码)python毕业设计基于PyTorch的手语识别系统源码+数据集(完整项目代码)python毕业设计基于PyTorch的手语识别系统源码+数据集(完整项目代码)python毕业设计基于PyTorch的手语识别系统源码+数据集(完整项目代码)python毕业设计基于PyTorch的手语识别系统源码+数据集(完整项目代

    基于Unet的树种分别识别模型

    基于Unet的树种分别识别模型

    精选毕设项目-富文本解析,折线图,MD5,bluebird.zip

    精选毕设项目-富文本解析,折线图,MD5,bluebird

    图书管理系统(基于ASP .NET)

    《图书管理系统(基于ASP .NET)》是一款专为学习者设计的应用程序,旨在提供一个全面的图书管理平台。系统的设计采用ASP .NET技术,这是一款由微软开发的用于构建动态网站、web应用和web服务的强大工具。ASP .NET框架以其高效、安全和易于维护的特点,深受开发者的喜爱。 该系统包含了多个核心模块,这些模块覆盖了图书管理的主要功能。有图书录入模块,它允许管理员录入图书的基本信息,如书名、作者、出版社、ISBN号、分类等。图书查询模块提供给用户方便快捷的搜索功能,用户可以根据书名、作者、关键词等条件进行检索。此外,借阅与归还模块确保图书的流通管理,记录图书的借阅状态,提醒用户按时归还,并处理超期罚款等事务。 系统还具备用户管理模块,允许用户注册、登录、修改个人信息。对于权限管理,后台有专门的管理员角色,他们可以对用户进行操作,如分配权限、冻结或解冻账户。同时,系统的统计分析模块能够生成各类报表,如图书借阅量、热门书籍、用户活跃度等,这些数据对于图书馆运营决策有着重要参考价值。 在。内容来源于网络分享,如有侵权请联系我删除。另外如果没有积分的同学需要下载,请私信我。

    精选毕设项目-查拼音.zip

    精选毕设项目-查拼音

    精选毕设项目-音乐在线歌词搜索.zip

    精选毕设项目-音乐在线歌词搜索

    思维导图制作-会计初级知识重难点-会计务实-所有者权益

    本专刊的主要目的是帮助初学者系统化和结构化地掌握会计知识。我们采用思维导图的形式,将复杂的会计概念和流程进行有效的简化,旨在让学习者能够更清晰地理解这些内容,并增强记忆效果。通过视觉化的方式,读者不仅能够感受到会计知识的关联性,还能轻松掌握关键点,提升学习效率。无论是在学习新知识还是复习旧知识时,这种方法都能够为学习者提供极大的便利和帮助。

    配网两阶段鲁棒优化调度模型 关键词:两阶段鲁棒优化,CCG算法,储能 仿真算例采用33节点,采用matlab+yalmip+cplex编写,两阶段模型采用CCG算法求解 模型中一阶段变量主要包括01

    配网两阶段鲁棒优化调度模型 关键词:两阶段鲁棒优化,CCG算法,储能 仿真算例采用33节点,采用matlab+yalmip+cplex编写,两阶段模型采用CCG算法求解。 模型中一阶段变量主要包括01变量和无功优化变量,核心变量主要存在于二阶段,因此在叠加二阶段变量优化过程中更容易得到最优解,所以有限次迭代即得到收敛的结果。 模型以网损为目标,包括功率平衡、网络潮流、电压电流、蓄电池出力以及无功设备出力等约束。 复现《两阶段鲁棒优化的主动配电网动态无功优化》-熊壮壮,具体内容可自行下载了解。

    1..1行列式的定义.ppt

    1..1行列式的定义.ppt

    精选毕设项目-地图定位.zip

    精选毕设项目-地图定位

    MMC整流器平均值模型simulink仿真,19电平,采用交流电流内环,直流电压外环控制,双二阶广义积分器锁相环,PI解耦环流抑制器,调制方式为最近电平逼近调制,完美运行 波形一二为直流侧电压电流

    MMC整流器平均值模型simulink仿真,19电平,采用交流电流内环,直流电压外环控制,双二阶广义积分器锁相环,PI解耦环流抑制器,调制方式为最近电平逼近调制,完美运行。 波形一二为直流侧电压电流,波形三四分别为主控制器及环流抑制器输出调制信号。

    疫苗发布和接种预约系统-springboot毕业项目,适合计算机毕-设、实训项目、大作业学习.zip

    Spring Boot是Spring框架的一个模块,它简化了基于Spring应用程序的创建和部署过程。Spring Boot提供了快速启动Spring应用程序的能力,通过自动配置、微服务支持和独立运行的特性,使得开发者能够专注于业务逻辑,而不是配置细节。Spring Boot的核心思想是约定优于配置,它通过自动配置机制,根据项目中添加的依赖自动配置Spring应用。这大大减少了配置文件的编写,提高了开发效率。Spring Boot还支持嵌入式服务器,如Tomcat、Jetty和Undertow,使得开发者无需部署WAR文件到外部服务器即可运行Spring应用。 Java是一种广泛使用的高级编程语言,由Sun Microsystems公司(现为Oracle公司的一部分)在1995年首次发布。Java以其“编写一次,到处运行”(WORA)的特性而闻名,这一特性得益于Java虚拟机(JVM)的使用,它允许Java程序在任何安装了相应JVM的平台上运行,而无需重新编译。Java语言设计之初就是为了跨平台,同时具备面向对象、并发、安全和健壮性等特点。 Java语言广泛应用于企业级应用、移动应用、桌面应用、游戏开发、云计算和物联网等领域。它的语法结构清晰,易于学习和使用,同时提供了丰富的API库,支持多种编程范式,包括面向对象、命令式、函数式和并发编程。Java的强类型系统和自动内存管理减少了程序错误和内存泄漏的风险。随着Java的不断更新和发展,它已经成为一个成熟的生态系统,拥有庞大的开发者社区和持续的技术创新。Java 8引入了Lambda表达式,进一步简化了并发编程和函数式编程的实现。Java 9及以后的版本继续在模块化、性能和安全性方面进行改进,确保Java语言能够适应不断变化的技术需求和市场趋势。 MySQL是一个关系型数据库管理系统(RDBMS),它基于结构化查询语言(SQL)来管理和存储数据。MySQL由瑞典MySQL AB公司开发,并于2008年被Sun Microsystems收购,随后在2010年,Oracle公司收购了Sun Microsystems,从而获得了MySQL的所有权。MySQL以其高性能、可靠性和易用性而闻名,它提供了多种特性来满足不同规模应用程序的需求。作为一个开源解决方案,MySQL拥有一个活跃的社区,不断为其发展和改进做出贡献。它的多线程功能允许同时处理多个查询,而其优化器则可以高效地执行复杂的查询操作。 随着互联网和Web应用的快速发展,MySQL已成为许多开发者和公司的首选数据库之一。它的可扩展性和灵活性使其能够处理从小规模应用到大规模企业级应用的各种需求。通过各种存储引擎,MySQL能够适应不同的数据存储和检索需求,从而为用户提供了高度的定制性和性能优化的可能性。

    jQuery实现左右切换全屏轮播图特效源码.zip

    这是一种全屏轮播风格的特效,使用HTML、CSS和Javript编写。轮播图包含多张图片和对应的文本介绍,通过自动滑动和手动切换两种方式,展示出不同的内容。该轮播图在网页头部或者特定板块上使用,能够为用户提供直观的视觉体验和丰富的内容呈现。而且,该轮播图可以灵活地设置大小、位置、动画等属性,便于根据实际需求进行个性化定制。

    精选毕设项目-图片预览带后端.zip

    精选毕设项目-图片预览带后端

    精选毕设项目-番茄时钟.zip

    精选毕设项目-番茄时钟

    精选毕设项目-简单的商城小应用.zip

    精选毕设项目-简单的商城小应用

    精选毕设项目-仿zcool站酷.zip

    精选毕设项目-仿zcool站酷

    精选毕设项目-录音机.zip

    精选毕设项目-录音机

    南京理工大学毕业论文overleaf LaTex模板,微调版

    南京理工大学毕业论文overleaf LaTex模板,按照我个人的写作需求修改后的版本

Global site tag (gtag.js) - Google Analytics