runit-docker中管理多个服务

这篇具有很好参考价值的文章主要介绍了runit-docker中管理多个服务。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

介绍

runit 是一个轻量级的、稳定的、跨平台的服务管理器。它由 Bruce Guenter 开发,目前由 Laurent Bercot 维护。runit 的设计简单明了,易于使用和扩展,非常适合用于运行服务的守护进程。

runit 提供了一种简单的方式来管理系统服务。与传统的 init 系统不同,runit 不使用脚本文件或者其他复杂的配置来管理服务,而是直接操作系统的进程表,以及通过一个指定的目录来管理服务的运行状态。

runit 将所有服务都视为独立的进程,它们可以通过 shell 脚本或者其他语言来启动。当服务启动时,runit 将会监视它的运行状态,并在服务崩溃或退出时重新启动它。

在 ruanit 中,每个服务都由一个单独的目录表示。该目录包含了所有服务所需的信息,例如启动脚本、环境变量等。runit 非常灵活,可以根据需要添加或删除服务,修改配置文件等。

官方文档:http://smarden.org/runit/

Runit, systemctl和supervisor是三种不同的服务管理工具区别

Runit:
Runit是一种轻量级的、跨平台的服务管理工具,用于管理和监控系统服务。它采用简单的文件夹结构和脚本,以监视、启动、停止和重启服务。Runit专注于可靠性和高效性,并支持服务间的依赖关系。每个服务都由一个独立的runit服务目录表示,其中包含run脚本用于启动服务。Runit不依赖于Linux特有的系统功能,因此也可以在其他UNIX系统上运行。

Systemd:
Systemd是Linux系统中最常见的服务管理工具,用于管理守护进程和系统服务。它是现代Linux系统的默认初始化系统,具有强大的功能和广泛的支持。Systemd使用单一的配置文件(.service文件)来定义和管理服务。它可以并行启动多个服务,支持服务依赖关系,并提供更多高级特性,如socket激活、资源限制等。Systemd也可以管理和监控它所启动的进程。

Supervisor:
Supervisor是一个进程管理工具,主要用于管理守护进程或后台任务。它不同于systemd和runit,它不是一个完整的初始化系统,而是专注于管理单个进程。Supervisor允许你定义和监控多个进程,并提供一种简单的方式来启动、停止、重启进程,并在进程意外退出时自动重新启动。

总结:

  • Runit是一个轻量级的、跨平台的服务管理工具,适用于管理系统服务和服务间的依赖关系。
  • Systemd是Linux系统的默认初始化系统,支持并行启动和管理多个服务,提供更多高级特性。
  • Supervisor是一个进程管理工具,用于管理守护进程或后台任务,而不是一个完整的初始化系统。

选择哪种工具取决于特定的需求和系统环境。

  • 对于Linux系统,通常使用默认的systemd;
  • 对于跨平台需求或简单的服务管理,例如容器中多个服务的监管,可以考虑使用runit。
  • Supervisor通常用于管理单个后台进程或守护进程。

runit优点

  • 易于配置和使用:runit 的配置简单明了,使用起来非常容易。它采用纯文本配置文件,不需要复杂的脚本或配置语言,使得用户可以快速理解和定义服务的启动和监控规则。

  • 快速启动和低资源消耗:runit 启动速度非常快,因为它仅关注服务的启动和管理,没有其他冗余功能。此外,runit 的内存和CPU消耗非常低,适合在资源受限的环境中运行。

  • 可靠性和稳定性:runit 以稳定性著称,它经过多年的发展和广泛应用,被广泛认可为一个可靠的服务监控工具。它采用简洁的设计和模块化架构,有助于降低故障风险。

  • 支持并行启动:runit 支持并行启动多个服务,这意味着可以在系统启动时同时启动多个服务,提高了系统启动速度。

  • 适用于各种系统:runit 可以运行在多种操作系统上,包括各种Linux发行版、FreeBSD等,这使得它成为一个跨平台的选择。

  • 容错和健壮性:runit 具有容错机制,能够处理服务异常退出和重启,并且可以在服务崩溃时采取自动恢复措施。

程序构成

  • runsvdir:每 5 秒扫描一次目录。如果有新的子目录,它会自动创建一个 runsv 进程来维护 service。
  • runsv:用于管理 service 的 daemon 进程,可以通过 sv 命令来操作 service。
  • sv:用户操作 service 用的 CLI 工具。
  • svlogd:用于收集 service 日志的 daemon 进程。每个 service 都会启动一个 svlogd 进程。

快速开始

服务监控:监控程序的二进制文件

conf/runit-sv/php-fpm/run

#!/bin/bash
exec /usr/sbin/php-fpm8.2 --fpm-config /etc/php/8.2/fpm/php-fpm.conf -R

conf/runit-sv/nginx/run

#!/bin/bash
exec /usr/sbin/nginx

Dockerfile

FROM ubuntu:18.04

RUN apt-get install -y runit \
    &&  mkdir -p /etc/service/nginx/  /etc/sv/nginx/ /etc/sv/php-fpm/

COPY conf/runit-sv/nginx/run /etc/service/nginx/run
RUN chmod 755  /etc/service/nginx/run

COPY conf/runit-sv/php-fpm/run /etc/service/php-fpm/run
RUN chmod 755  /etc/service/php-fpm/run

RUN  chmod 755  /etc/sv/nginx/run \
	&& chmod 755  /etc/sv/php-fpm/run \
	&& ln -s /etc/sv/charon /etc/service/  \
	&& ln -s /etc/sv/php-fpm/ /etc/service/  \
	&& ln -s /etc/sv/nginx/ /etc/service/

# 启动GAD
CMD ["/bin/docker-entrypoint.sh"]

/bin/docker-entrypoint.sh

exec runsvdir /etc/service &

runit实现服务退出执行指定操作

runit使用 trap 命令来捕获 TERM 和 INT 信号,当使用 runit 自身会接收到 TERM 信号时停止服务,有时会不生效,可以使用自定义捕获 TERM 和 INT 信号

#!/bin/bash

stop_task() {
  killall nginx
  exit 0

}

trap stop_task TERM INT

/bin/sh -c 'trap stop_task TERM INT; /usr/sbin/nginx 2>&1 | /usr/bin/logger -n 127.0.0.1 -P 514 -t NGINX -d --rfc5424 '  &

wait $!

runit监管服务打印日志到syslog

#!/bin/bash
exec /usr/sbin/nginx  | /usr/bin/logger -n 127.0.0.1 -P 514 -t NGINX -d --rfc5424   2>&1

runit监管服务后台运行

在runit中,run脚本是一个阻塞式的命令,直到服务退出才会退出脚本。如果您、需要在服务启动后执行其他任务,可以尝试以下几种方法:在run脚本中使用后台进程来启动服务

方式一:在run脚本中使用&符号来将服务启动命令放到后台进程中执行。

例如:


#!/bin/sh

# Start the service in the background
/usr/bin/my-service &

这样启动的服务会在后台运行,而不会阻塞脚本,这样您就可以在脚本中执行其他任务了。

方式二:在run脚本中使用nohup命令
nohup命令可以将命令放到后台进程中执行,并将输出重定向到指定文件中。例如:

#!/bin/sh

# Start the service in the background with nohup
nohup /usr/bin/my-service > /var/log/my-service.log 2>&1 &

# Other tasks to execute after the service starts
echo "My service has started."

方式三:在run脚本中使用wait命令

wait命令可以等待指定的进程结束,并在进程结束后继续执行脚本中的其他命令。例如:

#!/bin/sh

# Start the service and wait for it to finish
/usr/bin/my-service &
wait $!

# Other tasks to execute after the service finishes
echo "My service has finished."

在这个例子中,wait命令会等待my-service进程结束,并返回my-service的退出状态码。在my-service进程结束后,脚本会继续执行其他命令。

runit监管服务一些错误总结

注意:通过apt-get安装的 文件,需要手动关闭他的daemon,不然会通过sysinit进行托管,在

daemon

php-fpm 进程默认是以 daemon 方式启动的,使用 runit 监护进程时,被监护的进程不能是守护进程。
我们需要关闭 php-fpm 的进程守护,编辑 /usr/local/php/etc/php-fpm.conf,查找 daemonize 修改为 no。

继续锁定 ERROR,先查看 php-fpm 日志:

[01-Sep-2018 11:20:21] ERROR: unable to bind listening socket for address '127.0.0.1:9000': Address already in use (98)
[01-Sep-2018 11:20:21] ERROR: FPM initialization failed
[01-Sep-2018 11:20:23] ERROR: unable to bind listening socket for address '127.0.0.1:9000': Address already in use (98)
[01-Sep-2018 11:20:23] ERROR: FPM initialization failed
[01-Sep-2018 11:20:24] ERROR: unable to bind listening socket for address '127.0.0.1:9000': Address already in use (98)
[01-Sep-2018 11:20:24] ERROR: FPM initialization failed
[01-Sep-2018 11:20:25] ERROR: unable to bind listening socket for address '127.0.0.1:9000': Address already in use (98)
[01-Sep-2018 11:20:25] ERROR: FPM initialization failed

所以在runit监管服务时,如果有类似在通过apt-get安装以后,默认使用susinit监管程序,需要把服务的默认启动方式关了,将其二进制通过runit进行监管文章来源地址https://www.toymoban.com/news/detail-632253.html

到了这里,关于runit-docker中管理多个服务的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 体验感极好,docker爱好者福音,1Panel服务器运维管理面板使用引导功能介绍

    目录 一.介绍 二.特点 1.服务器管理便捷高效 2.资源实时监控 3.日志管理 4.远程终端访问 5.防护性较强 6.功能强大 三.与1Panel交流讨论 1.官网主页 2.微信公众号 3.哔哩哔哩账户 四.获取1Panel 1.进入官网,已提供安装方式 2.按提示安装 3.部署完成后之后要查看入口和用户密码信息

    2024年02月04日
    浏览(54)
  • Docker 数据管理[文件互访] 端口映射[暴露端口提供服务] 容器互联[指定容器名防止IP变动]

    管理 Docker 容器中数据主要有两种方式:数据卷(Data Volumes)和数据卷容器(DataVolumes Containers)。 数据卷是一个供容器使用的特殊目录,位于容器中。可将宿主机的目录挂载到数据卷上,对数据卷的修改操作立刻可见,并且更新数据不会影响镜像,从而实现数据在宿主机与容

    2024年02月15日
    浏览(51)
  • docker多个容器内部通信

    docker很方便的给我们用容器的方式解决了服务隔离运行,同时也产生了一个需要内部网络多个容器之间发生通讯,其实比较简单就可以实现,方式为:创建一个网络组、然后需要内部通讯的容器都加入到这个网络组中,然后这写加入的容器都是同一个网段,就可以通讯了。

    2024年02月11日
    浏览(41)
  • Docker启动多个mysql容器

    原有镜像mysql5.7.41,已启动mysql容器端口3306,再启动一个端口号为3400的容器。指定用户名root,mima ,密码123456 命令: docker run --name zjfz-mysql -e MYSQL_ROOT_PASSWORD=123456 -p 3400:3306 -d mysql 名字:zjfz-mysql 端口号:3400 效果:使用navicat连接刚指定端口的mysql,连接成功。 1、创建其他用户

    2024年02月06日
    浏览(51)
  • 【服务平台】Rancher运行和管理Docker和Kubernetes,提供管理生产中的容器所需的整个软件堆栈

    Rancher是一个开源软件平台,使组织能够在生产中运行和管理Docker和Kubernetes。使用Rancher,组织不再需要使用一套独特的开源技术从头开始构建容器服务平台。Rancher提供了管理生产中的容器所需的整个软件堆栈。 Rancher是供采用容器的团队使用的完整软件堆栈。它解决了在任何

    2024年02月13日
    浏览(62)
  • 第七次作业 运维高级 docker容器进级版

    1、使用mysql:5.6和 owncloud 镜像,构建一个个人网盘。 (1)拉取相应镜像 (2)运行mysql:5.6容器 (3)运行owncloud容器 (4)查看并验证 之后在浏览器中输入ipaddress:8080 2、安装搭建私有仓库 Harbor (1)下载好harbor和docker-compose (2)上传到Linux服务器 (3)复制docker-compose并修改权限 (4)解压harbor (

    2024年02月12日
    浏览(54)
  • 【Docker】Docker容器实战部署多个Nginx实现负载均衡和高可用

    前言 Docker下部署多个Nginx进行负载均衡,我这次实操的思路是使用三个Nginx。其中一个Nginx起负载均衡的作用,叫做 nginx-lb ,单独一个配置文件。另外2个Nginx起真正的转发作用,叫做 nginx1 和 nginx2 ,他们共享同一个配置文件,思路图如下。 接下来我们直接进行实操演示。 下载

    2024年01月16日
    浏览(40)
  • Docker容器运行多个php,一个正常另一个报502

    问题是解决了,但是并不知道问题出在哪儿 docker-compse.yml 文件并没有什么改动 在解决这个问题的过程中多次重新打包镜像配置运行容器,没有任何效果,最多就是原本正常的站点也变得不可用 我在看nginx的配置时,发现可以在 location 里面将多个版本的php都配置上路径 我想是

    2024年01月20日
    浏览(60)
  • K8S自动化运维容器化(Docker)集群程序

    1.什么是K8S K8S全程为Kubernetes,由于K到S直接有8个字母简称为K8S。 版本:目前一般是1.18~1.2.0,后续可能会到1.24-1.26,1.24版本后丢弃了docker(如需要使用需要第三方插件配合),目前最新版本是1.27 官网:https://kubernetes.io GitHub:GitHub - kubernetes/kubernetes: Production-Grade Container Schedul

    2024年02月10日
    浏览(64)
  • Docker宿主机复制(单个文件夹/多个文件/单个文件)到容器

    我的JPEGImages里面包含了多张图片,下面的指令将宿主机JPEGImages目录下的所有文件和子目录复制到7a7608e0bf84容器的/home/PaddleSeg/input/目录下 使用多行docker cp指令 docker cp 容器ID或名称:容器源路径 宿主机目标路径 docker cp 宿主机目标路径 容器ID或名称:容器源路径

    2024年02月08日
    浏览(51)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包