基于ubuntu的docker容器中的python argparse

问题描述

我正在努力寻找一种基于docker containerubuntu内将参数传递给python脚本的方法。我正在与docker-compose.yml合作。

请在下面找到示例!

docker-compose.yml

version: "3"
services:
   bcp:
      image: ubuntu:18.04
      restart: always
      tty: true
      entrypoint: ["/bin/bash","/ingestion/bcp-entrypoint.sh"]
      volumes:
          - ./services/bcp:/ingestion/services/bcp
          - ./bcp-entrypoint.sh:/ingestion/bcp-entrypoint.sh

bcp-entrypoint.sh

apt-get update
apt-get upgrade -y
apt-get clean -y
apt-get install -y python3-pip
...

python脚本

required_args.add_argument("--database",Metavar="str",type=str,help="database from where to extract",required=True)

在容器和主机上,我调用脚本的方式是python3 -m services.bcp --database foo,它的工作原理非常完美。问题是,如何在Docker容器上的主机上实现相同的目标?

基本上,我正在寻找类似docker-compose exec services.bcp --database foo的东西。

我不想使用dockerfile!理想情况下,所有内容都基于docker-compose

解决方法

这是针对docker和docker的解决方案,包括如何解析docker容器内的参数:

python脚本

#!/usr/bin/env python
import argparse

parser = argparse.ArgumentParser()
parser.add_argument("name",help="Name of person to greet")

args = parser.parse_args()

print(f"Hello there,{args.name}!")

带有自定义的dockerfile (对于这种情况,似乎最简单):

FROM python:3.8

COPY main.py .

ENTRYPOINT ["./main.py"]

然后构建并运行容器化的cli:

# Should make the script executable to invoke directly
$ chmod +x main.py

$ docker build -t dockerized-cli .
$ docker run -it --rm dockerized-cli -h
usage: main.py [-h] name

positional arguments:
  name        Name of person to greet

optional arguments:
  -h,--help  show this help message and exit
$ docker run -it --rm dockerized-cli Jeff
Hello there,Jeff!

仅用docker-compose (原始问题)

version: "3"
services:
  app:
    image: python:3.8
    volumes:
      - .:/opt/app
    entrypoint: ["/opt/app/main.py"]

然后运行

$ docker-compose run app Jeff
Hello there,Jeff!

如果您需要使用ubuntu:18.04映像,但仍然无法从该映像构建您自己的映像(在入口点之外安装python),那么您需要做已做的事情具有一个创建入口点脚本的程序,其中您首先安装python,然后调用您的脚本。需要注意的是,现在您的入口点是入口点脚本本身,而不是python CLI,因此您需要将所有参数从shell脚本传播到python脚本。下面是一个简单的示例,请注意-bash变量“ $ @”:

entrypoint.sh

#!/bin/bash

# install python here...

python print_args.py $@

print_args.py

import sys
print(sys.argv)