当我们使用docker-compose.yml
文件运行docker-compose up-d
命令来运行dockers时,它开始构建映像或从注册表中提取映像。我们可以在终端上看到此命令的每一步。
我尝试从python脚本运行此命令。命令成功启动,但在命令之后,我不知道进程已经完成了多少。有没有什么方法可以监视docker-compose up -d
命令的状态,以便脚本可以让用户(使用脚本的用户)知道进程已完成多少,或者docker-compose
命令是否由于某些原因而失败。
谢谢
代码:
from pexpect import pxssh
session = pxssh.pxssh()
if not session.login(ip_address,<USERNAME>, <PASSWORD>):
print("SSH session failed on login")
print(str(session))
else:
print("SSH session login successfull")
session.sendline("sudo docker-compose up -d")
session.prompt()
resp = session.before
print(resp)
4条答案
按热度按时间sy5wg1nm1#
可以通过以下方式查看
docker compose
日志1.使用
docker compose up -d
以分离模式(-d)启动所有服务(在分离模式下看不到任何日志)1.使用
docker compose logs -f -t
将您自己附加到所有正在运行的服务的日志,而-f
意味着您遵循日志输出,-t
选项为您提供了很好的时间戳(Docs)信用证
编辑:Docker Compose现在作为核心Docker CLI的一部分提供。
docker-compose
现在仍然受支持,但我现在看到的大多数文档都将docker compose
作为标准。更多信息请参见https://docs.docker.com/compose/#compose-v2-and-the-new-docker-compose-command。zpf6vheq2#
我调试小问题的方法是运行:
这样我就可以看到单个服务的输出。如果服务有依赖关系,你总是可以启动多个服务,如下所示:
此外,我还使用:
要查看已在运行的服务的日志,或者:
请注意,上面的命令需要容器名称,而不是服务名称
通过这种方式,您可以逐个服务地确保一切都按预期运行,然后您可以按照其他答案中的建议以分离模式启动所有服务
e0bqpujr3#
我认为应该使用命令
docker-compose top
,可以检查结果,当容器运行时它不应该是空的。如果容器是stop
或exit
或Create
,它应该返回空1dkrff034#
如果需要编程方式:
docker ps
将类似于:第一个