- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
这将是一个网络应用程序,它将始终(或尽可能接近我所能管理的)在给定端口上进行监听。
我对 Java 还很陌生,对非网络服务器端编程也很陌生,所以我想从社区获得关于我的假设和初步计划的反馈。
我读过有关 jsvc ( http://commons.apache.org/daemon/jsvc.html ) 的文章,目前我的假设是这是用 java 为 linux box(可能运行 centOS)编写守护进程的“最佳”方式。
nagios 是否可以配置为监视我的守护进程是否正在运行,并在未运行时提醒我或系统管理员? (我想是的,但我不是一个非常有才华的系统管理员类型)
这将是一个 SMPP 客户端应用程序(或者我猜是 ESME 应用程序),这就是我选择 Java 的原因,因为它似乎是一个非常成熟的 SMPP 平台。但是,我知道用 C/C++ 编写守护进程更为“传统”。使用现代 Java 执行相当简单的任务,我是否可能遇到任何重大缺点?
管理新版本部署的最佳方式是什么?只是停止守护进程并尽快替换二进制文件并重新启动?
任何其他输入将不胜感激。
最佳答案
How to write a Java daemon that has 24/7 uptime...
我们在我们的 Linux 服务器上运行许多 24/365 应用程序,这些应用程序只调用如下所示的 Java——不需要任何 C 包装器:
nohup java -D... -X... -jar something.jar ... < /dev/null > output.log 2>&1 &
这将使 jar 在后台运行(nohup ... &
),没有输入(< /dev/null
),输出(stdout 和 stderr)重定向到日志文件(> output.log 2>&1
)。我们有分布式日志记录基础设施,但仍然需要一些控制台输出(例如线程转储)。这些应用程序可以运行数月,直到我们对其进行升级。
Can nagios be configured to monitor whether or not my daemon is running, and to alert me or the sys admin when it isn't?
在监控方面,您可以做很多事情。 Nagios 看起来有一个 JMX plugin用于测试 jconsole
的信息显示。还有很多 native JMX 日志记录和监视实用程序。我们有内部绿色/黄色/红色指示器,可以使用 JMX 拉起并轻松检查。我还导出了一个 simple JMX/HTTP service从每个应用程序提供状态信息,使第 3 方监控工具可以轻松检测故障。
This will be an SMPP client app (or ESME app I guess) which is why I've chosen Java as it seems to be a very mature platform for SMPP.
我假设你的意思是 SMPP ?如果是这样,那么我看不出 Java 没有理由做得不好。我们的应用程序实时执行各种 HTTP、UDP、SMTP、JDBC、LDAP 和其他协议(protocol)。我们使用 Jgroups at lot 在 Java 中完成了一个完整的经过身份验证、加密的网络堆栈。
What's the best way to manage deployment of new builds? Just stop the daemon and replace the binary as quickly as possible and restart?
就动态替换正在运行的二进制文件而言,它更复杂。我们有VIPs预先并在我们空闲时替换二进制文件。我们的内部协议(protocol)旨在进行故障转移。如果您没有 VIP,那么需要考虑的一件事是有序交接。您启动新 jar,当它准备好绑定(bind)到新端口时,它会与运行旧 jar 的应用程序对话。然后旧应用程序解除绑定(bind),新应用程序随后立即绑定(bind)。诸如此类。
希望这对您有所帮助。
关于java - 如何编写 Java 守护进程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7814222/
一 点睛 线程可以设置为守护线程,ThreadGroup 也可以设置为守护 ThreadGroup,但是若将一个 ThreadGroup 设置为 deamon,也并不会影响线程的 daemon 属性,
我有一个 python 脚本需要在启动时作为守护进程运行。进程从 tty(和 pdb)分离,但代码不运行。 我已经将它缩小到一个最小的例子 import daemon from time import
reactjs isMounted API 的文档提到: You can use this method to guard asynchronous calls to setState() or fo
我正在开发一个需要嵌入 HTTP 服务器的守护进程。我正在尝试使用 BaseHTTPServer 来完成它,当我在前台运行它时,它工作正常,但是当我尝试将守护进程 fork 到后台时,它停止工作。我的
我正在尝试使用 Apache Commons Daemon 使用 Daemon 接口(interface)来守护我的应用程序。 Java 应用程序本身不执行任何操作,只是写入 stout。 我编译了j
我正在使用 Bootle Python Web Framework 在 Ubuntu 上开发网络应用程序。是否有任何有效的方法来守护启动默认 bottlepy 网络服务器的脚本? 谢谢。 UPD:现在
我一直使用 bluepill成功地守护简单的 Ruby 脚本。然而这一次,我有一个脚本,它也在加载 Rails 环境,因此我可以访问 Rails 应用程序及其各自模型的数据库连接。我使用的 bluep
我试图守护一些代码,但我遇到了一些麻烦。 如果我用 tklogger() 调用代码,它运行得很好。但是,如果我在守护程序上下文中调用它,我会得到以下跟踪信息: Traceback (most rece
我打算使用 systemd 将 celery 4.3.0 作为守护进程运行,但它给了我这个错误: 它会启动 worker 但会很快停止它们。但是,我可以通过键入以下命令手动运行工作人员: celery
我是一名优秀的程序员,十分优秀!