浏览 4931 次
锁定老帖子 主题:关于Python和Java结合的新思路
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2008-05-04
比如原来的已有的积分结算系统,里面有很多关于结算的logic,我不想在python这边再实现一遍,不仅是重复的劳动,而且又要测试一遍,是否和原来的一致,更可怕的是当结算逻辑更改的时候,要维护两份代码!!! 首先想到的方案是让django跑在Jython上,在网上看到已经有人这样做了,不过貌似很麻烦,还有很多未解决的bug。 这样遇到了困难,转而想通过python和java通讯的方式,通过socket?这样还要自己做一套java object和python object转化的程序,麻烦,没把握能否达到想要的效果。在google上搜了一把,有很多java和python通讯的东东,不过好像没有适合我需要的。突然想起学习spring的时候,提供web service的机制中有个叫hessian的方案,基于http的二进制协议,貌似速度快,而且简单好用。hessian也提供python client访问代码。貌似可行。 那么现在要做就是把原来的代码按web service的方式,封装成一个个hessian service。比如积分结算的service。然后在django的views.py中通过hessian调用这个service就可以了。 虽然http调用会带来一定的开销,不过用hessian的话应该开销不大。大家觉得怎么样,现在的方案是python+hessian+java? 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2008-05-04
用单一的解决方案永远是TCO最低的方案。
|
|
返回顶楼 | |
发表时间:2008-05-04
用ICE嘛,python/php作前端 java/c++作后端
|
|
返回顶楼 | |
发表时间:2008-05-04
就这么个简单的功能还搞上ICE了?管道,标准IO通讯也成
|
|
返回顶楼 | |
发表时间:2008-05-04
认同楼主的意见。
如果有遗留系统,将其功能封装起来对系统新的部分提供服务,是比较稳妥的方式。 不管它看起来多么的陈旧或者丑陋,遗留系统的价值就是,它经过了测试和长时间用户使用保证没有问题。用统一的语言重新实现或许不难,可是这部分的测试工作不做可是不行的(要保证程序正常测试的工作量和时间可比些代码多多了,或许就给你的项目加了一一半的工作量)。 所以,饭一口一口吃,遗留系统的迁移以后有机会的时候再做,不要把这部分工作引入到当前的项目里面增加风险。同时变动两个部分总是比较麻烦和为危险的,一个一个来,变动A部分的时候,B部分本来是好的不动它,这样可以做为参照,比较稳妥。 |
|
返回顶楼 | |