Docker如何一次查看多个容器日志

文章目录

  • 一,简要概述
  • 二,操作步骤
    • [1, 编排文件](#1, 编排文件)
    • [2, 水平扩容脚本](#2, 水平扩容脚本)
    • [3, 运行效果](#3, 运行效果)
    • [4, 查看多个容器日志](#4, 查看多个容器日志)

一,简要概述

docker本身并不提供查看多个容器日志的方法,但是我们却可以利用docker scale 命令,对服务作水平扩容,这样多个服务使用的是同一的服务名。从而借助docker-compose logs 命令来查看这批服务的日志。

二,操作步骤

在安装了dockerdocker-compose的lunix服务器上,创建编排文件和扩容脚本。

1, 编排文件

docker-compose.yml

yaml 复制代码
services:
  database-lock:
    image: registry.cn-shanghai.aliyuncs.com/00fly/database-lock:1.0.0
    deploy:
      resources:
        limits:
          cpus: '2.0'
          memory: 200M
        reservations:
          cpus: '2.0'
          memory: 200M
    environment:
      SPRING_PROFILES_ACTIVE: prod
      SPRING_DATASOURCE_URL: jdbc:h2:tcp://h2-server/mem:test;database_to_upper=false
      SPRING_DATASOURCE_DRIVERCLASSNAME: org.h2.Driver
      SPRING_DATASOURCE_USERNAME: sa
      SPRING_DATASOURCE_PASSWORD: 
    restart: on-failure
    logging:
      driver: json-file
      options:
        max-size: 5m
        max-file: '1'
  h2-server:
    image: registry.cn-shanghai.aliyuncs.com/00fly/h2:1.4.200
    deploy:
      resources:
        limits:
          cpus: '2.0'
          memory: 64M
        reservations:
          cpus: '2.0'
          memory: 64M
    restart: on-failure
    logging:
      driver: json-file
      options:
        max-size: 5m
        max-file: '1'

2, 水平扩容脚本

scale-lock.sh

bash 复制代码
#!/bin/bash
docker-compose --compatibility up -d --scale database-lock=3

3, 运行效果

执行以下脚本,启动服务

bash 复制代码
sh scale-lock.sh

docker ps

输出如下

bash 复制代码
 
[root@00fly scale]# sh scale-lock.sh 
[+] Running 5/5
 ✔ Network scale_default            Created                                                                                                                                                                   0.2s 
 ✔ Container scale_database-lock_3  Started                                                                                                                                                                   2.1s 
 ✔ Container scale_h2-server_1      Started                                                                                                                                                                   0.7s 
 ✔ Container scale_database-lock_1  Started                                                                                                                                                                   1.4s 
 ✔ Container scale_database-lock_2  Started                                                                                                                                                                   0.8s 
[root@00fly scale]# docker ps 
CONTAINER ID   IMAGE                                                         COMMAND                   CREATED          STATUS          PORTS     NAMES
8b4dd9e1f3d3   registry.cn-shanghai.aliyuncs.com/00fly/database-lock:1.0.0   "java -Djava.securit..."   13 seconds ago   Up 12 seconds             scale_database-lock_2
9459a57b39e2   registry.cn-shanghai.aliyuncs.com/00fly/h2:1.4.200            "java -Djava.securit..."   13 seconds ago   Up 12 seconds             scale_h2-server_1
02f443bd0785   registry.cn-shanghai.aliyuncs.com/00fly/database-lock:1.0.0   "java -Djava.securit..."   13 seconds ago   Up 11 seconds             scale_database-lock_1
6e156442843a   registry.cn-shanghai.aliyuncs.com/00fly/database-lock:1.0.0   "java -Djava.securit..."   13 seconds ago   Up 10 seconds             scale_database-lock_3

4, 查看多个容器日志

docker compose logs -f <服务名>

bash 复制代码
docker compose logs -f database-lock

输出如下

bash 复制代码
scale_database-lock_1  | 2026-07-03 15:32:47.332 INFO [main] c.f.BootApplication         : Starting BootApplication v1.0.0 on 02f443bd0785 with PID 1 (/app.jar started by root in /)
scale_database-lock_1  | 2026-07-03 15:32:47.340 INFO [main] c.f.BootApplication         : The following profiles are active: prod
scale_database-lock_1  | 2026-07-03 15:32:50.437 INFO [main] c.f.s.l.DataBaseLock        : init...
scale_database-lock_1  | 2026-07-03 15:32:50.609 INFO [main] c.f.c.u.SpringContextUtils  : ###### execute setApplicationContext ######
scale_database-lock_1  | 2026-07-03 15:32:50.902 INFO [main] c.f.BootApplication         : Started BootApplication in 4.794 seconds (JVM running for 8.648)
scale_database-lock_1  | 2026-07-03 15:32:50.907 INFO [main] c.f.BootApplication         : ##### JDBC URL: jdbc:h2:tcp://h2-server/mem:test;database_to_upper=false
scale_database-lock_1  | 2026-07-03 15:32:50.907 INFO [main] c.f.BootApplication         : ##### JDBC Driver: org.h2.Driver
scale_database-lock_1  | 2026-07-03 15:33:00.104 INFO [schedule-pool-1] c.f.s.j.ScheduleJob         : [MUO] 没抢到,骂骂咧咧的走了......
scale_database-lock_1  | 2026-07-03 15:33:05.123 INFO [pool-3-thread-1] c.f.s.a.RefreshAspect       : ##### version: 1
scale_database-lock_1  | 2026-07-03 15:33:30.007 INFO [schedule-pool-1] c.f.s.j.ScheduleJob         : [MUO] 没抢到,骂骂咧咧的走了......
scale_database-lock_1  | 2026-07-03 15:33:35.009 INFO [pool-3-thread-2] c.f.s.a.RefreshAspect       : ##### version: 2
scale_database-lock_1  | 2026-07-03 15:34:00.008 INFO [schedule-pool-2] c.f.s.j.ScheduleJob         : [MUO] 没抢到,骂骂咧咧的走了......
scale_database-lock_1  | 2026-07-03 15:34:05.010 INFO [pool-3-thread-1] c.f.s.a.RefreshAspect       : ##### version: 3
scale_database-lock_1  | 2026-07-03 15:34:30.009 INFO [schedule-pool-1] c.f.s.j.ScheduleJob         : [MUO] 没抢到,骂骂咧咧的走了......
scale_database-lock_1  | 2026-07-03 15:34:35.017 INFO [pool-3-thread-2] c.f.s.a.RefreshAspect       : ##### version: 4
scale_database-lock_3  | 2026-07-03 15:32:51.720 INFO [main] c.f.BootApplication         : Started BootApplication in 4.663 seconds (JVM running for 8.687)
scale_database-lock_3  | 2026-07-03 15:32:51.725 INFO [main] c.f.BootApplication         : ##### JDBC URL: jdbc:h2:tcp://h2-server/mem:test;database_to_upper=false
scale_database-lock_3  | 2026-07-03 15:32:51.726 INFO [main] c.f.BootApplication         : ##### JDBC Driver: org.h2.Driver
scale_database-lock_3  | 2026-07-03 15:33:00.142 INFO [schedule-pool-1] c.f.s.j.ScheduleJob         : [ykc] 没抢到,骂骂咧咧的走了......
scale_database-lock_3  | 2026-07-03 15:33:05.157 INFO [pool-3-thread-1] c.f.s.a.RefreshAspect       : ##### version: 1
scale_database-lock_3  | 2026-07-03 15:33:30.007 INFO [schedule-pool-1] c.f.s.j.ScheduleJob         : [ykc] 没抢到,骂骂咧咧的走了......
scale_database-lock_3  | 2026-07-03 15:33:35.009 INFO [pool-3-thread-1] c.f.s.a.RefreshAspect       : ##### version: 2
scale_database-lock_3  | 2026-07-03 15:34:00.006 INFO [schedule-pool-1] c.f.s.j.ScheduleJob         : [ykc] #### hello world ***********
scale_database-lock_3  | 2026-07-03 15:34:05.010 INFO [pool-3-thread-2] c.f.s.a.RefreshAspect       : ##### version: 3
scale_database-lock_3  | 2026-07-03 15:34:30.006 INFO [schedule-pool-1] c.f.s.j.ScheduleJob         : [ykc] #### hello world ***********
scale_database-lock_3  | 2026-07-03 15:34:35.015 INFO [pool-3-thread-1] c.f.s.a.RefreshAspect       : ##### version: 4
scale_database-lock_3  | 2026-07-03 15:35:00.011 INFO [schedule-pool-2] c.f.s.j.ScheduleJob         : [ykc] 没抢到,骂骂咧咧的走了......
scale_database-lock_2  | 2026-07-03 15:35:00.008 INFO [schedule-pool-1] c.f.s.j.ScheduleJob         : [riF] 没抢到,骂骂咧咧的走了......
scale_database-lock_1  | 2026-07-03 15:35:00.007 INFO [schedule-pool-3] c.f.s.j.ScheduleJob         : [MUO] #### hello world ***********
scale_database-lock_2  | 2026-07-03 15:35:05.011 INFO [pool-3-thread-1] c.f.s.a.RefreshAspect       : ##### version: 5
scale_database-lock_3  | 2026-07-03 15:35:05.014 INFO [pool-3-thread-2] c.f.s.a.RefreshAspect       : ##### version: 5
scale_database-lock_1  | 2026-07-03 15:35:05.019 INFO [pool-3-thread-1] c.f.s.a.RefreshAspect       : ##### version: 5
scale_database-lock_2  | 2026-07-03 15:35:30.003 INFO [schedule-pool-2] c.f.s.j.ScheduleJob         : [riF] #### hello world ***********
scale_database-lock_3  | 2026-07-03 15:35:30.005 INFO [schedule-pool-3] c.f.s.j.ScheduleJob         : [ykc] 没抢到,骂骂咧咧的走了......
scale_database-lock_1  | 2026-07-03 15:35:30.005 INFO [schedule-pool-2] c.f.s.j.ScheduleJob         : [MUO] 没抢到,骂骂咧咧的走了......
scale_database-lock_2  | 2026-07-03 15:35:35.006 INFO [pool-3-thread-2] c.f.s.a.RefreshAspect       : ##### version: 6
scale_database-lock_3  | 2026-07-03 15:35:35.018 INFO [pool-3-thread-1] c.f.s.a.RefreshAspect       : ##### version: 6
scale_database-lock_1  | 2026-07-03 15:35:35.014 INFO [pool-3-thread-2] c.f.s.a.RefreshAspect       : ##### version: 6
scale_database-lock_3  | 2026-07-03 15:36:00.015 INFO [schedule-pool-3] c.f.s.j.ScheduleJob         : [ykc] #### hello world ***********
scale_database-lock_1  | 2026-07-03 15:36:00.020 INFO [schedule-pool-2] c.f.s.j.ScheduleJob         : [MUO] 没抢到,骂骂咧咧的走了......
scale_database-lock_2  | 2026-07-03 15:36:00.014 INFO [schedule-pool-2] c.f.s.j.ScheduleJob         : [riF] 没抢到,骂骂咧咧的走了......
scale_database-lock_3  | 2026-07-03 15:36:05.020 INFO [pool-3-thread-2] c.f.s.a.RefreshAspect       : ##### version: 7
scale_database-lock_2  | 2026-07-03 15:36:05.020 INFO [pool-3-thread-1] c.f.s.a.RefreshAspect       : ##### version: 7
scale_database-lock_1  | 2026-07-03 15:36:05.031 INFO [pool-3-thread-1] c.f.s.a.RefreshAspect       : ##### version: 7

大功告成!!!


有任何问题和建议,都可以向我提问讨论,大家一起进步,谢谢!

-over-

相关推荐
WI8LbH7881 小时前
Ubuntu 部署Harbor
linux·运维·ubuntu
huainingning1 小时前
华三ACL单向TCP互通组网-通过Established状态回包实现
运维·网络·tcp/ip
蜀道山老天师1 小时前
K8s 数据存储全解析:从 EmptyDir 到 PV/PVC
云原生·容器·kubernetes
researcher-Jiang2 小时前
高性能计算之MPI:第一次MPI并行程序设计练习
linux·运维·服务器
Promise微笑2 小时前
工业微量水分监测:精密露点仪选型逻辑与行业应用实证深度报告
大数据·运维
联盟分享专家4 小时前
垂直工具型 SaaS 的增长实战:如何把用户变成推广者?
运维
江畔柳前堤4 小时前
第16章:docker企业级实战综合项目
运维·git·安全·docker·容器·eureka
Leon-Ning Liu5 小时前
【真实经验分享】OGG抽取进程报错 ORA-07445 [kgherrordmp()+986] ORA-00600 [17114]分析步骤
运维·数据库
QWEDDRFTG5 小时前
运维长期经验总结:从故障倒推服务器电源线选购标准
运维·服务器