java - 从Java Web应用程序控制C应用程序

标签 java c tcp middleware

我有C应用程序,它将在不同站点的多台计算机上运行。
现在我想控制和监视这些C应用程序。为此,我正在考虑使用servlet /JSP的Java Web应用程序。
我认为C应用程序将通过TCP连接到Java Web应用程序。在我的Web应用程序中,我正在考虑实现Manager,它通过TCP与C应用程序通信。当Web应用程序作为单独的线程启动时,我将启动Manager。管理器将通过上下文和会话与servlet请求通信。因此,每当用户在浏览器上做一些事情时,我都希望使用服务器上管理器的功能,其中servetcontext是一个会话作为接口。
所以这就是我的想法。所以,我想知道是有更好的方法,还是我做错了什么?有人能给我推荐更好的解决方案吗?
编辑
当前工作流程:每当我需要启动/停止c应用程序时,我必须ssh远程机器putty终端,键入长命令,并启动/停止它。每当出现问题时,我必须滚动长日志文件。还有其他一些事情,比如应用程序每秒正在做/处理所有事情的实时状态,我不能总是在日志文件中记录。
所以我觉得这些工作流程很困难。还有一些我无法监控的事情。
现在,我想拥有它的Web应用程序界面。我可以修改我的c应用程序并从头开始实现web应用程序。
要实现的新工作流:我要从网页启动/停止C应用程序。我想在网页上查看日志和实时状态报告/实时图形(监视C应用程序正在做什么)。我还想在网页上监视机器状态。
我想用JSP/Servlet来设计Java的Web界面。
因此,我将修改我的C应用程序,以便它可以与Web应用程序通信。
问题:
只需要制定新工作流程的指导方针/最佳实践。
编辑2
抱歉,控制器或管理器之间出现混淆。两者都是一样的。
我的想法:
系统将由运行在不同站点的C应用程序、Java控制器和Java Web应用程序在Tomcat服务器中并行运行,以及DB组成。
1)C应用程序将通过TCP连接到控制器。所以,这里的控制器变成了服务器和C应用程序客户端。
2)C应用程序将是多线程的,将从控制器接收任务,并生成新的线程来执行该任务。当控制器告诉停止任务时,C应用程序将停止该任务的线程。此外,C应用程序将每秒向控制器发送工作进度(日志)。
3)控制器接收来自Web应用程序的任务命令(两者在Tomcat服务器上并行运行,在JVM上处于同一个实例中),Web应用程序通过HTTP接收来自用户的命令。
4)每秒从C应用程序接收到的工作进度(日志)到控制器,控制器将在DB中插入日志供以后分析(需要考虑MySQL RDBMS中是否有好的插入日志,可能需要做大量的插入,可能每秒100或1000个,永远)。web应用程序还可以从控制器请求最近5分钟的日志,并通过http发送给用户。如果用户正在监视日志,那么Web应用程序将必须每秒从控制器检索日志并通过HTTP发送给用户。
5)用户监控C应用任务,会看到进度图,每秒更新一次。此外,在C应用程序中偶尔会发生的信息/错误事件日志的文本行。
6)c应用程序将是每台机器,它将执行用户从web浏览器发送的任何任务。C应用程序将作为服务在机器中运行,它将在机器启动时启动,连接到服务器,并将永远保持与服务器的连接。如果没有要执行的任务,则可以空闲运行。

最佳答案

这是一种有效的方法,我相信sockets是大多数分布式系统通信的方式,甚至比同一个盒子上的不同服务更经常这样通信。我相信你对Java Web服务的建议是非常典型的,并且会很好地工作(它可能会比你现在想的更复杂,但是你描述的原型是一个很好的开始)。
如果使您的C服务也独立于管理系统运行,那么您可能希望反转它并让管理系统连接到服务(除非防火墙阻止它)。
您当然需要一个小的、定义良好的协议。如果你发送了很多字段,你甚至可以生成你发送的所有json或xml,因为它们已经有解析器来验证格式。
注意安全!在C端,确保您不会得到任何缓冲区溢出,如果您自己解析信息,请严格要求丢弃(和日志记录!)数据看起来不对。在Java上,缓冲区溢出不是一个问题,但要确保您记录的数据包不适合您的协议,以准确地检测错误和入侵。
您可能会考虑的另一个解决方案——您的系统都共享一个数据库,您可以通过数据库发送命令和响应(假设命令/响应不会太频繁发生)。我们并不完全这样做,但我们共享一个变量表,其中放置了表示系统性能和配置不同方面的名称/值对(它是双向的),这可能不是最优的,但却非常灵活,因为它允许我们在运行时重新配置系统(它是e值缓存在每个服务的本地,每30秒重新读取/更新一次)。
如果我知道更多关于您期望做什么的细节,我可能会给您提供更多的信息——例如,您的浏览器多久更新一次它的字段,发送什么类型的命令信号或数据请求,以及您希望返回什么类型的数据?虽然你当然不必在这里发布这些东西,但你必须考虑一下——我建议你先模拟一下你的浏览器页面。
基于评论的编辑:
听起来不错,只是几个评论:
2)任何一个好的数据库都应该能够处理该卷数据进行日志记录,但您可能希望在数据库之上使用一个好的缓存。
5)您可能需要一个Web框架来呈现图形和管理更新。有很多,而且大多数人都能很容易地做到你所说的,但是在没有某种框架的情况下试着自己去做可能是很困难的。我这么说只是因为你没提。
6)确保可以处理掉的连接和重新连接。测试时,拔下服务器上的插头(至少是网络电缆)并将其保留10分钟,然后确保当您将其重新插入时,获得预期的结果(客户端是否应自动重新连接)?它是应该抓住原木还是扔掉它们?它能保存多长时间?
您可能希望构建一种方式来“重新启动”您的C服务。因为它们是作为服务启动的,所以只要发送一个命令,告诉它们终止/退出,就可以正常工作,因为系统将重新启动它们。您可能还需要一个小的监控循环,在特定的条件下重新启动它们(比如,它们已经有n分钟没有从服务器收到命令)。当你上午10点在加利福尼亚州,试着凌晨2点在澳大利亚的C服务中心工作时,这个方法会很有用。
另外,考虑攻击者可以将自己插入到客户端和服务器之间。如果您使用的是一个SSL套接字,那么您应该很好,但是如果它是一个原始套接字,那么您必须非常小心。
更正:
将这么多记录放入mysql数据库时可能会遇到问题。如果它没有被索引,并且您最小化了对它的查询,那么您可能会没事的。您可以通过将所有日志的最后5分钟保存在内存中来实现这一点,这样就不必为数据库编制索引,也不必对插入进行分组,或者拥有一个经过很好调整的缓存。
一个更好的方法可能是放弃数据库,只使用预先筛选到单个用户可能希望看到的平面日志文件,因此,如果用户要求从一台计算机获取最后5分钟的“warn”和“debug”消息,则可以将该计算机中的日志文件读入内存,跳过除wa之外的所有日志文件。RN/DEBUG消息,并显示这些消息。这有它自己的问题,但应该比索引数据库更具伸缩性。这还允许您压缩较旧的数据(用户不想再查询这些数据),从而节省70-90%的磁盘空间。

关于java - 从Java Web应用程序控制C应用程序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26881013/

相关文章:

java - 哈希独特的空间

perl - 使用 perl 模块 Log::Syslog::Fast - 无法捕获异常

java - 如何使用输入流java的markSupported特性

c - c-sel函数中的scandir实现

c++ - 结构字段后的 ': number' 是什么意思?

c - 为什么这个素数算法有效?

sockets - 使用 read_to_string 时如何停止在新行上?

java - 在循环 JDBC 结果集时,如果我们失去网络会发生什么?

java - 当按钮具有特定的当前文本时如何更改按钮上的文本(Android Studio/Java XML)

java - 如何在 mule MEL 表达式中使用属性变量?