当前位置:  开发笔记 > 编程语言 > 正文

如何在PHP和Java程序之间进行通信?

如何解决《如何在PHP和Java程序之间进行通信?》经验,为你挑选了1个好方法。

我正在开发一个Web应用程序,它经常需要运行计算密集型查询,其结果存储在一个单独的表中.使用MySQL,此查询大约需要500毫秒(尽可能优化,相信我).为了消除这个瓶颈,我创建了一个Java程序,它将相关的DB数据加载到内存中并执行查询本身; 它需要大约8 毫秒(我有点自豪).我想使用这个Java程序来获取结果,如果它失败或不可用,则故障转移到PHP运行MySQL查询.

由于将数据加载到Java应用程序需要一些时间,因此它将加载一次并继续作为后台进程运行. 现在,问题是我如何通过PHP与这个Java应用程序进行通信?

记住:

多个PHP实例可能需要同时与此Java进程通信.

如果找不到Java实例(例如:由于某种原因它崩溃),PHP应该通过使用较旧和较慢的MySQL方法来进行.

可以接受诸如Memcache之类的中间过程.

理想情况下,该解决方案可以承受竞争条件.

我最好不要使用MySQL作为中介.

我打算使用Memcache,其中PHP将写入已知密钥并轮询,直到该密钥更改为"已完成",同时Java将轮询该密钥,并且一旦发现某些内容执行该作业并将其设置为"已完成".但是,由于两个原因,这不起作用.首先,PHP和Java使用序列化对象读取/写入Memcache,并且没有办法改变它,我不希望Java反序列化PHP对象,反之亦然 - 它太乱了.其次,这不符合ACID - 如果在那里建立的队列将存在竞争条件.

就目前而言,我坚持轮询MySQL"选择"以查看作业是否已脱离队列,这远非最佳解决方案,因为轮询时间需要较慢,因此MySQL不会过于频繁.我需要更好的解决方案!

谢谢.

编辑:Duh.看起来我将在Java中使用某种SocketServer,我对此并不熟悉.一个例子可能有帮助:)



1> Sambo..:

我在Java端使用套接字服务器,在PHP端使用PHP套接字.效果很好.

没有必要使用PHP/Java桥接过度复杂化,也不需要创建Web服务器的开销.

套接字工作得很好,我实际上有点惭愧我甚至提出问题开始工作.

推荐阅读
贴进你的心聆听你的世界
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有