Docker 镜像构建:Python & Node

简介: Docker 镜像构建:Python & Node

在进行 Python 开发时,建议使用 pipenv 进行包管理,使用 node 中的 pm2 进行应用监控。本文将会简述如何构建一个 Python + Node + pipenv + pm2 环境的镜像。



01


构建镜像


编写 Dockerfile 文件如下所示:


选择官方的 Python3.7 基础镜像,通过 pip3 安装 pipenv ,安装 node v10.x 稳定版本,然后通过 npm 安装 pm2 ,vim 是我常使用的工具,所以这里一起安装了。


构建镜像,命名为 python-node ,tag 为 1.0.0:

docker build -t  python-node:1.0.0 .

执行此命令需要注意的是,最后的符号 . 指向的是 Dockerfile 文件所在的目录,如果 Dockerfile 文件就在当前执行环境的目录下,那么一个 . 就可以了,如果不是则需要替换成 Dockerfile 文件的实际目录。



02


镜像仓库


上一步成功构建了一个 Python + Node + pipenv + pm2 环境的镜像,对应用程序而言,此环境完全可以是通用的,因此我们在构建具体应用的镜像时可以直接将其作为基础镜像,下面我们将这个基础镜像存放到 Docker Hub 镜像仓库中。


1、设置此基础镜像的 tag :

需要注意的是 wangying/python-node:latest 中的

  • wangying 是我的 Docker Hub 用户名。
  • python-node 是 Docker Hub 上的 repository 名称。
  • latest 是 repository 这个镜像的 tag 。


2、登录 Docker Hub:

docker login

3、将镜像推送到仓库:

执行之后就会成功将此镜像推送到仓库中,python-node 这个 repository 如果不存在则会自动创建。



03


自动化构建


上一步中构建镜像,打 tag ,然后推送到仓库都需要手动输命令,改动一次就得重来一遍这太麻烦了,我希望能够自动化去构建,正好 Docker Hub 提供了与 GitHub 相连的自动化构建方式。


1、登录 Docker Hub 进入 Account Settings -> Linked Accounts ,授权关联你的 GitHub 账户:

2、创建 GitHub 相关 repository 仓库,这里的示例命名为 docker-images 。


3、在 Docker Hub 创建 repository 时设置 Build Settings ,关联 GitHub 上的 repository :


或者在已经创建好的 Docker Hub repository 中重新设置 Build:


4、完成了 Docker Hub 与 GitHub 的自动化构建关联,只要我们本地修改完 Dockerfile 文件然后 push 到 GitHub 上这个关联的 repository,那么 Docker Hub 就会自动去拉取 GitHub 上最新的 Dockerfile 文件然后进行构建。原理也很简单,其实就是利用了 GitHub 提供的 webhook 功能。



04


构建应用镜像


构建了基础镜像并且推送到了镜像仓库中,我们就可以基于此构建具体应用程序的镜像:


指定基础镜像,设置工作目录,复制项目文件,暴露应用端口,安装项目依赖库,最后通过 CMD 指定容器启动时自动通过 pm2 部署应用服务,需要注意的是这里不能使用 pm2 而必须使用 pm2-runtime ,另外 pm2.json 是我自己的 pm2 配置文件,这个可以随便弄,一般默认是 ecosystem.config.js 。





结语


本文的内容就是这么多,其实就是解决一个问题:构建镜像。

目录
相关文章
|
6天前
|
Java Serverless 应用服务中间件
Serverless 应用引擎操作报错合集之部署python项目时,构建过程报错,怎么解决
Serverless 应用引擎(SAE)是阿里云提供的Serverless PaaS平台,支持Spring Cloud、Dubbo、HSF等主流微服务框架,简化应用的部署、运维和弹性伸缩。在使用SAE过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
|
17天前
|
缓存 自然语言处理 数据库
构建高效Python Web应用:异步编程与Tornado框架
【5月更文挑战第30天】在追求高性能Web应用开发的时代,异步编程已成为提升响应速度和处理并发请求的关键手段。本文将深入探讨Python世界中的异步编程技术,特别是Tornado框架如何利用非阻塞I/O和事件循环机制来优化Web服务的性能。我们将剖析Tornado的核心组件,并通过实例演示如何构建一个高效的Web服务。
|
2天前
|
存储 Linux Docker
python项目 以docker形式打包部署全流程
在很久很久以前,我已经听过Docker的大名,当时服务着急上线虽然考虑过用Docker来部署我的服务,但是因为赶期的原因放弃了。 这两天因为华为云服务器到期,而且阿里云服务器优惠力度特别大的原因,我要把华为云服务器里的工程迁移到阿里云。 迁移的过程中,大量的时间精力浪费在了重装python,加载依赖,迁移项目,配置端口等环境配置的工作上。 我在想,如果当时用了Docker部署,我至于受这气?
|
2天前
|
数据库 Python
Python实践:从零开始构建你的第一个Web应用
使用Python和轻量级Web框架Flask,你可以轻松创建Web应用。先确保安装了Python,然后通过`pip install Flask`安装Flask。在`app.py`中编写基本的"Hello, World!"应用,定义路由`@app.route('/')`并运行`python app.py`启动服务器。扩展应用,可添加新路由显示当前时间,展示Flask处理动态内容的能力。开始你的Web开发之旅吧!【6月更文挑战第13天】
14 2
|
2天前
|
Python 存储 数据处理
【Python数据类型的奥秘】:构建程序基石,驾驭信息之海
【Python数据类型的奥秘】:构建程序基石,驾驭信息之海
|
3天前
|
JavaScript Shell 开发者
怎样使用Nest.js快速构建高效Node.js应用?
这篇博客介绍了Nest.js,一个基于TypeScript的Node.js框架,适用于构建可维护和可扩展的服务器端应用。文章引导读者快速入门,包括安装Node.js和Nest.js CLI,创建新项目,安装依赖以及启动开发服务器。通过访问`http://localhost:3000`,可以看到"Hello World!",证明应用已成功运行。Nest.js因其模块化架构和强大的功能,成为现代Web开发的热门选择。
|
4天前
|
消息中间件 监控 调度
构建Python中的分布式系统结合Celery与RabbitMQ
在当今的软件开发中,构建高效的分布式系统是至关重要的。Python作为一种流行的编程语言,提供了许多工具和库来帮助开发人员构建分布式系统。其中,Celery和RabbitMQ是两个强大的工具,它们结合在一起可以为你的Python应用程序提供可靠的异步任务队列和消息传递机制。
|
13天前
|
存储 数据管理 测试技术
构建Python构建自动化测试框架(原理与实践)
当谈到软件质量保证时,自动化测试是一个不可或缺的步骤。Python作为一种简单易学的编程语言,具有丰富的测试框架和库,使得构建自动化测试框架变得相对简单。本文将介绍如何使用Python构建自动化测试框架,包括选择合适的测试框架、编写测试用例、执行测试和生成报告等方面。
构建Python构建自动化测试框架(原理与实践)
|
18天前
|
消息中间件 存储 JavaScript
构建一个基于Node.js的实时数据流处理系统
【5月更文挑战第30天】使用Node.js构建实时数据流处理系统,结合WebSocket实现双向通信,Kafka作为消息队列,Redis做数据存储和缓存,D3.js用于数据可视化。系统包括数据源、传输、处理、存储和可视化五个关键部分,适合高并发、低延迟的实时监控与分析需求。
|
18天前
|
Web App开发 JavaScript Cloud Native
构建高效可扩展的RESTful API:Node.js与Express框架实践指南构建未来:云原生架构在企业数字化转型中的关键作用
【5月更文挑战第29天】 在数字化时代的驱动下,后端服务架构的稳定性与效率成为企业竞争力的关键。本文深入探讨了如何利用Node.js结合Express框架构建一个高效且可扩展的RESTful API。我们将从设计理念、核心模块、中间件应用以及性能优化等方面进行系统性阐述。通过实例引导读者理解RESTful接口设计的最佳实践,并展示如何应对大规模并发请求的挑战,确保系统的高可用性与安全性。

热门文章

最新文章