首页 > 后端开发 > Golang > 正文

docker compose healthcheck 未退出并出现错误无法启动

WBOY
发布: 2024-02-06 08:50:03
转载
1295人浏览过

docker compose healthcheck 未退出并出现错误无法启动

问题内容

我有这个撰写文件:

version: "3"
services:
  app:
    build: .
    ports:
      - 8080:8080
    volumes:
      - "./:/src"
    healthcheck:
      test: ["CMD-SHELL", "curl -f http://localhost:8080/fail-health-check || exit 1"]
      interval: 5s
      timeout: 5s
      retries: 1
    command: ["go", "run", "main.go"]
登录后复制

Dockerfile:

FROM golang:1.21 as builder

WORKDIR /src

COPY go.mod go.sum ./
RUN go mod download
登录后复制

当我运行 docker compose 时,应用程序的运行状况检查继续运行。我希望容器退出并出现错误无法启动容器。

golang代码main.go

package main

import (
    "fmt"
    "log"

    "github.com/labstack/echo/v4"
    "github.com/labstack/echo/v4/middleware"
)

func main() {
  r := echo.New()
  r.Use(middleware.Logger())
  
  fmt.Println("start http server on port 8080")
  if err := r.Start(":8080"); err != nil {
    log.Fatal(err)
  }
}
登录后复制

这里是登录应用程序:

test_healthcheck_go_app-app-1  | {"time":"2023-11-14T04:08:42.450751594Z","id":"","remote_ip":"127.0.0.1","host":"localhost:8080","method":"GET","uri":"/fail-health-check","user_agent":"curl/7.88.1","status":404,"error":"code=404, message=Not Found","latency":26375,"latency_human":"26.375µs","bytes_in":0,"bytes_out":24}
登录后复制

docker ps 输出

Find JSON Path Online
Find JSON Path Online

Easily find JSON paths within JSON objects using our intuitive Json Path Finder

Find JSON Path Online 193
查看详情 Find JSON Path Online
CONTAINER ID   IMAGE                         COMMAND            CREATED          STATUS                      PORTS                    NAMES
ff389f13ab1d   test_healthcheck_go_app-app   "go run main.go"   48 seconds ago   Up 46 seconds (unhealthy)   0.0.0.0:8080->8080/tcp   test_healthcheck_go_app-app-1
登录后复制

正确答案


  1. 您的应用程序不知道它正在容器中运行。
  2. 您的主进程(go run main.go)正在以 PID 1 运行,您需要停止该进程才能退出容器,并且该进程受到保护。

了解了这两个事实,您就有了几种可能性:

  1. 在容器内安装 docker cli。然后将 docker 套接字映射到容器中并运行 docker stop。将套接字映射到容器中意味着安全问题——请小心操作。

  2. 运行 ps -afx | 等命令grep 去 | awk '{print $1}' | xargs Kill -9 (对这个答案表示敬意),即特别是在您的 healthcheck 中,它可能看起来像 curl -f http:// /本地主机:8080/失败健康检查 || (ps -afx | grep go | awk '{print $1}' | xargs Kill -9)

  3. 但在我看来,您真正需要的是容器编排系统,例如 Kubernetes。这个建议可能有点过分,也可能不是。取决于您的项目计划。无论如何,它将帮助您更稳健地管理正在运行的容器。

如果您想产生错误,则取决于您使用的日志驱动程序。使用 syslog 驱动程序,Docker 容器将日志写入 /var/log/syslog。因此,在退出之前,您可能需要 echo "Error text"/var/log/syslog

以上就是docker compose healthcheck 未退出并出现错误无法启动的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:stackoverflow网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号