- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
出于性能原因,我需要运行一个应用程序的多个实例,固定到 CPU,监听不同的端口。一个 HAProxy TCP 负载平衡器位于它们前面以分配流量。
这样做是为了防止任何线程上下文切换并强制执行无共享设计(因此在应用程序中不需要任何类型的锁,假设它是单线程的)。
这意味着在具有 64 个 CPU 的服务器上,我可能将 HAProxy 固定到 CPU 0,然后我的应用程序的 63 个实例分别固定到单独的 CPU (1-63)。
显然,在启动、重启、关闭等方面管理起来相当复杂。
我想知道是否有任何方法可以使用 systemd 来为我处理这种复杂性。
我知道如果我将 HAProxy 定义为一个单元然后声明它需要它需要与之通信的其他应用程序,它可以解决启动问题,例如
Require=app1,app2,.....,app63
我能做到
systemctl start myhaproxy
它会首先启动它需要的 63 个实例(假设它们中的每一个在应用程序安装期间都被定义为一个单独的 systemd 单元)。
但是,我想知道是否有办法让它也适用于重启和关机。
如果我这样做:
systemctl stop myhaproxy
我希望它自动关闭所有 63 个与之对话的应用程序实例。
如果我这样做
systemctl restart myhaproxy
然后我希望它在最后重新启动自己之前首先重新启动 Require 中列出的所有服务。
这可能吗?或者这是否超出了 systemd 所能提供的范围?
最佳答案
我建议您创建一个目标(例如app-all.target
)并且您所有的应用程序单元都将具有WantedBy=app-all.target
对它的依赖。这将确保如果您启动目标,它将启动您的所有应用程序单元。但是,这不适用于停止和重新启动。为此,您需要为每个应用程序单元添加 PartOf=app-all.target
依赖项。
此外,我建议您为您的应用程序创建一个模板单元,然后创建它的 63 个实例 - 这将使管理更容易(只有 1 个配置文件,其中包含 63 个符号链接(symbolic link))。这是一个tutorial关于模板和 systemd 的一般信息。
来自man systemd.unit
(缩写):
WantedBy=
A symbolic link is created in the .wants/ or .requires/ directory of each of the listed units when this unit is installed by systemctl enable. The primary result is that the current unit will be started when the listed unit is started.
PartOf=
Configures dependencies similar to Requires=, but limited to stopping and restarting of units. When systemd stops or restarts the units listed here, the action is propagated to this unit. Note that this is a one-way dependency -- changes to this unit do not affect the listed units.
关于linux - systemd 能否自动重启/停止依赖服务?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38112638/
我在 gobject 上阅读了一个维基百科页面,上面写着, Depending only on GLib and libc, GObject is a cornerstone of GNOME and
如何注册一个依赖属性,其值是使用另一个依赖属性的值计算的? 由于 .NET 属性包装器在运行时被 WPF 绕过,因此不应在 getter 和 setter 中包含逻辑。解决方案通常是使用 Proper
我一直在尝试将 ActionbarSherlock maven 依赖项添加到我的项目中 com.actionbarsherlock library 4.2.0 在我的 po
http://tutorials.jenkov.com/ood/understanding-dependencies.html#whatis说(强调我的): Whenever a class A us
我对所有这些魔法有点不清楚。 据我了解,依赖属性是从 DependencyObject 继承的,因此存储值: 如果分配了值(在本地字典中),则在实例本身中 或者如果未指定值,则从指向父元素的链接中获取
我刚刚更新了在 ASP.NET Framework 4.5.2 版上运行的 MVC Web 应用程序。我正在使用 Twilio 发送 SMS 消息: var twilio = new TwilioRe
我刚刚发现了一件令人生畏的事情。 spring 依赖坐标有两个版本。 项目依赖于 spring mvc 和 spring flow。有两组并行的依赖项。 Spring MVC 具有以下方案的依赖项
我正在尝试包含 的 maven 依赖项 org.jacorb jacorb 2.3.1 依赖已解决,但它导致另一个依赖 picocontainer 出现问题: [ERROR
我正在尝试在 Haskell 项目中包含特定版本的库。该库是住宿加早餐型的(用于 martix 操作),但我需要特定的 0.4.3 版本,该版本修复了乘法实现的错误。 所以,我的 stack.yaml
有谁知道如何制作依赖的 UIPickerView.例如,当我选择组件一的第 2 行时,组件二的标题会发生变化吗? 我在互联网上查找过,没有真正的答案,我尝试过使用 if 和 switch 语句,但它们
我正在编写一个用于验收测试的项目,由于各种原因,这依赖于另一个打包为 WAR 的项目。我已成功使用 maven-dependency-plugin 解压 WAR,但无法让我的项目包含解压的 WEB-I
或多或少我在 session 上大量构建我的网站(特别是重定向用户等),我很好奇这是否是一种危险的做法。禁用浏览器 cookie 保存的用户的大致比例是多少?我愿意接受任何建议:) 谢谢 最佳答案 s
开始玩 Scala futures,我被依赖的 futures 困住了。 让我们举个例子。我搜索地点并获得 Future[Seq[Place]]。对于这些地点中的每一个,我搜索最近的地铁站(该服务返回
或多或少我在 session 上大量构建我的网站(特别是重定向用户等),我很好奇这是否是一种危险的做法。禁用浏览器 cookie 保存的用户的大致比例是多少?我愿意接受任何建议:) 谢谢 最佳答案 s
我有一个二进制文件,需要一些 *.so 文件才能执行。现在,当我尝试在一些旧机器上执行它时,它会显示 /lib/libc.so.6: version `GLIBC_2.4' not found 如何将
我尝试使用 Dygraph 来表示图表,我在 https://github.com/danvk/dygraphs 中找到了代码,但是它有太多的依赖文件,我觉得很烦人。是否有一个文件可以容纳所有必需的
我正在处理一个 javascript 文件,该文件 a) 声明一个具有函数的对象,并且 b) 使用它期望在外部声明的散列调用该对象的 init 函数。我的 Jasmine 规范提示它找不到哈希,因为它
最近我一直在学习 Angular 并且进展顺利,但是关于依赖注入(inject)的一些事情我仍然不清楚。 是否有任何理由在我的 app.js 文件中声明我的应用程序的其他部分(服务、 Controll
考虑一个名为 foo 的表,它有 id (PRIMARY & AUTO_INCREMENT) 列。我正在向该表中插入一行,挑战从此时开始。 $db->query("INSERT INTO `foo`
我正在使用级联下拉 jquery 插件。 (https://github.com/dnasir/jquery-cascading-dropdown) 我有两个下拉菜单。 “客户端”和“站点”。 根据您
我是一名优秀的程序员,十分优秀!