此容器镜像包含Python 2.7,作为构建和运行Python 2.7应用程序的https://github.com/openshift/source-to-image%E5%9F%BA%E7%A1%80%E9%95%9C%E5%83%8F%E3%80%82%E7%94%A8%E6%88%B7%E5%8F%AF%E9%80%89%E6%8B%A9%E5%9F%BA%E4%BA%8ERHEL%E6%88%96CentOS%E7%9A%84%E6%9E%84%E5%BB%BA%E5%99%A8%E9%95%9C%E5%83%8F%EF%BC%9ARHEL%E9%95%9C%E5%83%8F%E5%8F%AF%E5%9C%A8Red Hat容器目录获取,CentOS镜像可在Quay.io获取,Fedora镜像可在Fedora Registry获取。生成的镜像可使用https://github.com/containers/libpod%E6%88%96http://docker.io%E8%BF%90%E8%A1%8C%E3%80%82
注意:尽管本README中的示例使用
podman命令,但所有此类命令均可替换为docker,参数保持不变。
Python 2.7容器镜像是构建和运行各类Python 2.7应用程序及框架的基础平台。Python是一种易于学习、功能强大的编程语言,具有高效的高级数据结构和简洁而有效的面向对象编程方法。其优雅的语法、动态类型以及解释型特性,使其成为多数平台上众多领域中脚本编写和快速应用开发的理想选择。
此容器镜像包含npm工具(参见https://github.com/sclorg/s2i-base-container/tree/master/base%EF%BC%89%EF%BC%8C%E7%94%A8%E6%88%B7%E5%8F%AF%E4%BD%BF%E7%94%A8%E5%AE%83%E4%B8%BAWeb%E5%BA%94%E7%94%A8%E7%A8%8B%E5%BA%8F%E5%AE%89%E8%A3%85JavaScript%E6%A8%A1%E5%9D%97%E3%80%82%E9%95%9C%E5%83%8F%E4%B8%AD%E5%8C%85%E5%90%AB%E7%9A%84npm%E6%88%96nodejs%E7%89%88%E6%9C%AC%E4%B8%8D%E5%81%9A%E4%BB%BB%E4%BD%95%E4%BF%9D%E8%AF%81%EF%BC%8C%E8%BF%99%E4%BA%9B%E7%89%88%E6%9C%AC%E5%8F%AF%E8%83%BD%E9%9A%8F%E6%97%B6%E5%8F%98%E6%9B%B4%EF%BC%8Cnodejs%E4%BB%85%E4%B8%BA%E6%94%AF%E6%8C%81npm%E5%8A%9F%E8%83%BD%E8%80%8C%E5%8C%85%E5%90%AB%E3%80%82
assemble和run脚本自动化应用构建与运行流程假设使用OpenShift中标签为python:2.7的支持镜像,构建简单https://github.com/sclorg/django-ex.git%E5%BA%94%E7%94%A8%E5%8F%AF%E9%80%9A%E8%BF%87%E4%BB%A5%E4%B8%8B%E6%AD%A5%E9%AA%A4%EF%BC%9A
bashoc new-app python:2.7~https://github.com/sclorg/django-ex.git
访问应用:
bash$ oc get pods $ oc exec <pod> -- curl 127.0.0.1:8080
此镜像支持OpenShift的源到镜像(S2I)框架。S2I是一种OpenShift框架,可轻松构建接收应用源代码作为输入、使用构建器镜像(如本Python容器镜像)并生成运行应用的新镜像。
为支持S2I框架,构建器镜像中包含以下重要脚本:
/usr/libexec/s2i/assemble:用于生成包含应用制品的新镜像。该脚本接收应用源代码并将其放置到镜像内的适当目录,利用Python应用开发中的常见模式(参见下文环境变量部分)。
/usr/libexec/s2i/run:作为生成的容器镜像(包含应用制品的新镜像)的默认命令。它根据APP_MODULE、APP_FILE或APP_SCRIPT环境变量的设置运行应用,或自动检测最佳运行方式。
与S2I策略相比,使用Dockerfile是构建包含应用的Python容器镜像的更灵活方式。当S2I不够灵活或在OpenShift环境外构建时,可使用Dockerfile。
按照以下步骤在Dockerfile中使用Python镜像:
1. 拉取基础构建器镜像
bashpodman pull registry.access.redhat.com/ubi8/python-27
2. 获取应用代码
此处使用示例应用https://github.com/sclorg/django-ex.git%E3%80%82%E5%8F%AF%E5%85%8B%E9%9A%86%E8%AF%A5%E4%BB%93%E5%BA%93%E8%BF%9B%E8%A1%8C%E5%AE%9E%E9%AA%8C%EF%BC%8C%E4%B9%9F%E5%8F%AF%E6%9F%A5%E7%9C%8Bs2i-python-container%E4%BB%93%E5%BA%93%E4%B8%AD%E7%9A%84%E4%BB%A3%E7%A0%81%E7%A4%BA%E4%BE%8B%EF%BC%9Ahttps://github.com/sclorg/s2i-python-container/tree/master/examples
bashgit clone https://github.com/sclorg/django-ex.git app-src
3. 在容器内准备应用
此步骤通常至少包括:
用户可在Dockerfile中显式使用python和pip命令手动完成上述所有步骤,或使用镜像中的S2I脚本。手动方式灵活性最高,但需手动处理模块、软件集合、虚拟环境等;使用S2I脚本可使Dockerfile便于未来无缝切换到更新或不同的平台。
要使用S2I脚本通过Dockerfile构建镜像,创建包含以下内容的Dockerfile:
dockerfileFROM registry.access.redhat.com/ubi8/python-27 # 将应用源代码添加到assemble脚本预期的目录,并设置权限以非root用户运行容器 USER 0 ADD app-src /tmp/src RUN chown -R 1001:0 /tmp/src USER 1001 # 安装依赖 RUN /usr/libexec/s2i/assemble # 设置生成镜像的默认命令 CMD /usr/libexec/s2i/run
4. 从准备好的Dockerfile构建新镜像
bashpodman build -t python-app .
5. 运行生成的应用镜像
bashpodman run -d python-app
可在源代码仓库的.s2i/environment文件中以键值对形式设置以下环境变量:
APP_SCRIPT
用于从脚本文件运行应用。应指定脚本文件路径(默认值为app.sh,设为null则禁用),该脚本将用于启动应用。
APP_FILE
用于从Python脚本运行应用。应指定Python文件路径(默认值为app.py,设为null则禁用),该文件将传递给Python解释器以启动应用。
APP_MODULE
用于通过Gunicorn运行应用,如文档所述。此变量指定WSGI可调用对象,格式为MODULE_NAME:VARIABLE_NAME,其中MODULE_NAME是模块的完整点分路径,VARIABLE_NAME是指定模块内的WSGI可调用对象。若未指定,Gunicorn将查找名为application的WSGI可调用对象。
若未提供APP_MODULE,run脚本将在项目中查找wsgi.py文件并使用(如果存在)。
若使用setup.py安装应用,MODULE_NAME部分可从中读取,示例参见https://github.com/sclorg/s2i-python-container/tree/master/2.7/test/setup-test-app%E3%80%82
APP_HOME
用于指定包含待运行应用的子目录。该目录需包含wsgi.py(用于Gunicorn)或manage.py(用于Django)。若未提供,assemble和run脚本将使用应用根目录。
APP_CONFIG
Gunicorn配置文件的有效Python文件路径,配置说明参见Gunicorn配置。
DISABLE_MIGRATE
设置为非空值可禁止运行生成镜像时执行manage.py migrate。仅影响Django项目。参见OpenShift博客上Django文章的"处理数据库迁移"部分([***]
DISABLE_COLLECTSTATIC
设置为非空值可禁止构建期间执行manage.py collectstatic。仅影响Django项目。
DISABLE_SETUP_PY_PROCESSING
设置为非空值可跳过setup.py脚本处理,适用于在requirements.txt中使用-e .触发处理或不希望应用安装到site-packages目录的情况。
ENABLE_PIPENV
设置此变量可使用https://github.com/pypa/pipenv%EF%BC%88%E9%AB%98%E7%BA%A7Python%E6%89%93%E5%8C%85%E5%B7%A5%E5%85%B7%EF%BC%89%E7%AE%A1%E7%90%86%E5%BA%94%E7%94%A8%E4%BE%9D%E8%B5%96%E3%80%82%E4%BB%85%E5%BD%93%E9%A1%B9%E7%9B%AE%E5%8C%85%E5%90%AB%E6%A0%BC%E5%BC%8F%E6%AD%A3%E7%A1%AE%E7%9A%84%60Pipfile%60%E5%92%8C%60Pipfile.lock%60%E6%97%B6%E4%BD%BF%E7%94%A8%E3%80%82%EF%BC%88%E9%9A%90%E5%90%AB%60UPGRADE_PIP_TO_LATEST%60%E4%BB%A5%E6%BB%A1%E8%B6%B3Pipenv%E4%BE%9D%E8%B5%96%EF%BC%89%E3%80%82
PIN_PIPENV_VERSION
与ENABLE_PIPENV一起设置,用于指定Pipenv版本。若未设置,将安装PyPI上的最新稳定版本。例如PIN_PIPENV_VERSION=2018.11.26将安装pipenv==2018.11.26。
ENABLE_INIT_WRAPPER
设置为非空值可使用init包装器。适用于无法回收僵尸进程的服务器(如Django开发服务器或Tornado)。可与APP_SCRIPT或APP_FILE一起使用。通过APP_MODULE使用Gunicorn时从不应用,因为Gunicorn可正确回收僵尸进程。
PIP_INDEX_URL
设置自定义索引URL或镜像,用于构建期间下载依赖包。影响requirements.txt中列出的包,也影响pipenv、micropipenv的安装及pip的更新。若自定义索引中未找到,容器将尝试从上游PyPI安装/更新。
UPGRADE_PIP_TO_LATEST
设置为非空值可在安装任何Python包前将pip及相关Python包(setuptools和wheel)升级到最新版本。若未设置,将使用平台为当前Python版本包含的默认版本。
WEB_CONCURRENCY
用于更改工作进程数的默认设置。默认值为可用核心数乘以2,上限为12。
现有Python项目仓库无需任何更改,但以下文件存在时将影响构建过程:
requirements.txt
需用pip安装的依赖列表,格式参见此处。
Pipfile
requirements.txt的替代方案,项目设计与开发文档参见https://github.com/pypa/pipfile%E3%80%82%E9%9C%80%E5%B0%86%60ENABLE_PIPENV%60%E7%8E%AF%E5%A2%83%E5%8F%98%E9%87%8F%E8%AE%BE%E4%B8%BAtrue%E4%BB%A5%E5%A4%84%E7%90%86%E6%AD%A4%E6%96%87%E4%BB%B6%E3%80%82
setup.py
配置项目各方面,包括依赖安装,文档参见此处。多数项目使用requirements.txt或Pipfile即可。需将DISABLE_SETUP_PY_PROCESSING环境变量设为true以跳过此文件处理。
s2i-python生成的容器镜像按以下优先级顺序执行项目:
Gunicorn
若安装了Gunicorn(通过requirements.txt或setup.py的install_requires列出),则使用Gunicorn WSGI HTTP服务器提供应用。
若仓库中存在wsgi.py文件,将用作应用入口点,可通过APP_MODULE环境变量覆盖。Django项目默认包含此文件。
若依赖中同时包含Django和Gunicorn,Django项目将自动通过Gunicorn提供服务。
Django开发服务器
若依赖中包含Django但无Gunicorn,将使用Django开发Web服务器。不建议用于生产环境。
Python脚本
通过APP_FILE环境变量指定Python脚本路径(默认查找app.py),脚本将传递给Python解释器执行以启动应用。
应用脚本文件
通过APP_SCRIPT环境变量指定可执行脚本路径(默认查找app.sh),脚本将直接执行以启动应用。
Django应用:热部署默认生效。
Gunicorn:需在仓库中包含Gunicorn配置文件,将reload选项设为true,并通过APP_CONFIG环境变量指定配置。
要在运行中的容器中更改源代码,使用podman(或docker)的https://github.com/containers/libpod/blob/master/docs/podman-exec.1.md%E5%91%BD%E4%BB%A4%EF%BC%9A
bashpodman exec -it <CONTAINER_ID> /bin/bash
进入运行中的容器后,当前目录为源代码所在的/opt/app-root/src。
Dockerfile及其他源码可在https://github.com/sclorg/s2i-python-container%E8%8E%B7%E5%8F%96%E3%80%82%E8%AF%A5%E4%BB%93%E5%BA%93%E8%BF%98%E5%8C%85%E5%90%AB%E5%85%B6%E4%BB%96Python%E7%89%88%E6%9C%AC%E7%9A%84%E7%8E%AF%E5%A2%83Dockerfile%EF%BC%9ACentOS%E7%9A%84Dockerfile%E5%90%8D%E4%B8%BA%60Dockerfile%60%EF%BC%8CRHEL7%E7%9A%84%E4%B8%BA%60Dockerfile.rhel7%60%EF%BC%8CRHEL8%E7%9A%84%E4%B8%BA%60Dockerfile.rhel8%60%EF%BC%8CFedora%E7%9A%84%E4%B8%BA%60Dockerfile.fedora%60%E3%80%82
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。

探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录认证访问私有仓库
无需登录使用专属域名
Kubernetes 集群配置 Containerd
K3s 轻量级 Kubernetes 镜像加速
VS Code Dev Containers 配置
Podman 容器引擎配置
HPC 科学计算容器配置
ghcr、Quay、nvcr 等镜像仓库
Harbor Proxy Repository 对接专属域名
Portainer Registries 加速拉取
Nexus3 Docker Proxy 内网缓存
需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单
docker search 限制
站内搜不到镜像
离线 save/load
插件要用 plugin install
WSL 拉取慢
安全与 digest
新手拉取配置
镜像合规机制
manifest unknown
no matching manifest(架构)
invalid tar header(解压)
TLS 证书失败
DNS 超时
域名连通性排查
410 Gone 排查
402 与流量用尽
401 认证失败
429 限流
D-Bus 凭证提示
413 与超大单层
来自真实用户的反馈,见证轩辕镜像的优质服务