python + docker, 实现天气数据 从FTP获取以及持久化(五)-- 利用 Docker 容器化 Python 程序
背景
不知不觉中,我们已经完成了所有的编程工作。接下来,我们需要把 Python 程序 做 容器化 (Docker)部署。

思考
考虑到项目的实际情况,“持久化天气”的功能将会是一个独立的功能模块发布(用户可选)。因此,个人觉得没有必要放到项目总体的 docker-compose 里面去统一处理, 那么我们可以将它作为一个单独的 docker container 来部署:通过 docker run 的方式运行 docker container; 并启动 python 程序。
Python 程序 容器化
我们将通过2中不同的方式来部署我们的python程序。
我们首先需要了解 docker run 命令, 更为详细的说明请参考官网:https://docs.docker.com/engine/reference/run/
$ docker run [OPTIONS] IMAGE[:TAG|@DIGEST] [COMMAND] [ARG...]
关于OPTION部分,我们要做到以下几个方面:
1. 容器的运行方式:前台进程或后台进程
为了方便演示,我选择了前台方式运行,这样能直接看到程序输出的log. (也可以 以后台形式运行 -d, 然后运行其他docker命令来查看log信息)
# foreground
docker run -it # background
docker run -itd
2. 挂载点
根据业务需要,我们在读取FTP上面的每个文件后,需要在本地做一个备份。然而,docker容器的大小默认为:10GB。 考虑到日后的维护(文件过多导致container size 超限),我们通过建立 volumn, 将文件保存在本地硬盘上,以防止容器的大小超过限制。
# docker run -it --name myweather -v /home/ct/WeatherDocker:/usr/src/app
3. 启动python程序: CMD or ENTRYPOINT
3.1 以 CMD 的方式启动 python 程序
# docker run -it --name myweather -v /home/ct/WeatherDocker:/usr/src/app algtest:v1. /bin/bash -c "python /usr/src/app/MainEntry.py current"
3.2 以 ENTRYPOINT 的方式启动 python 程序
docker run -it --name myweather -v /home/ct/WeatherDocker:/usr/src/app --entrypoint /bin/bash algtest:v1.
-c "python /usr/src/app/MainEntry.py query 201807010000 201808010000"
请注意: 这里 ENTRYPOINT 只是指定的是运行python的terminal (/bin/bash), python 的参数则是由 CMD 传递的!! docker官方的说明如下:
The ENTRYPOINT of an image is similar to a COMMAND because it specifies what executable to run when the container starts, but it is (purposely) more difficult to override. The ENTRYPOINT gives a container its default nature or behavior, so that when you set anENTRYPOINT you can run the container as if it were that binary, complete with default options, and you can pass in more options via the COMMAND.
如上所示,我们在 container 里面启动了查询数据的python程序,结果如下:

总结
补充一个地方:以 docker container 启动 python 程序时,链接数据库的IP和Port 不再是本机IP(127.0.0.1)和 默认端口(3306),应该是 docker 网络中 的 IP与 Port 设置.。。。 文字描述有点拗口,请大家看截图

我们可以看到,我这里的 containers, 都在docker 默认的网络 bridge中。 test- MySQL 是 MySQL数据库;myweather 是 承载 python 程序的 容器。
那么,我们要链接MySQL数据库是的IP和Port 应该是什么呢?

从上图中,我们其实已经可以看到,docker container之间的通信在默认情况下走的是bridge网络,因此,MySQL数据库的IP应该是172.17.0.2 或者 “本机真实IP”,端口为3307(LZ自己启动MySQL数据库是时修改的)
~~OK,感谢大家的收看,欢迎积极留言讨论!!
关于容器与宿主局的时间同步
由于在制作 docker image 的时候没有注意时区,所以到时 docker container 里面的时区是默认值(UTC)。
解决办法是在 docker run 的时候, 设置 --env TZ=Asia/Shanghai
# docker run -it --name myweather --env TZ=Asia/Shanghai -v /home/ct/Siemens/WeatherDocker:/usr/src/app algtest:v1. /bin/bash -c "python /usr/src/app/MainEntry.py current"
python + docker, 实现天气数据 从FTP获取以及持久化(五)-- 利用 Docker 容器化 Python 程序的更多相关文章
- python + docker, 实现天气数据 从FTP获取以及持久化(一)
前情提要 最近项目需要天气数据(预报和历史数据)来作为算法程序的输入. 项目的甲方已经购买了天气数据, 依照他们的约定,天气数据的供应商会将数据以"文本" (.TXT)的方式发到F ...
- python + docker, 实现天气数据 从FTP获取以及持久化(二)-- python操作MySQL数据库
前言 在这一节中,我们主要介绍如何使用python操作MySQL数据库. 准备 MySQL数据库使用的是上一节中的docker容器 “test-mysql”. Python 操作 MySQL 我们使用 ...
- python + docker, 实现天气数据 从FTP获取以及持久化(四)-- 数据准备
前情提要 在之前的文章里,我们已经掌握从FTP上面下载天气数据然后插入到数据库中. 但是如何将我们已有的数据放到生产环境中呢? 思考 首先,我们先简单的理一理现在的情况. 目前: FTP上面已有半个月 ...
- python + docker, 实现天气数据 从FTP获取以及持久化(三)-- python获取FTP数据
前言 经过前面两个小节的介绍,我们已经完成了MySQL数据库的搭建和数据库操作的事宜. 在本小节中,我们需要完成的任务是:使用python从FTP服务其上面获取文本文件. 搭建测试FTP服务器 LZ的 ...
- 毕设之Python爬取天气数据及可视化分析
写在前面的一些P话:(https://jq.qq.com/?_wv=1027&k=RFkfeU8j) 天气预报我们每天都会关注,我们可以根据未来的天气增减衣物.安排出行,每天的气温.风速风向. ...
- docker容器化python服务部署(supervisor-gunicorn-flask)
docker容器化python服务部署(supervisor-gunicorn-flask) 本文系作者原创,转载请注明出处: https://www.cnblogs.com/further-furt ...
- C# 解析百度天气数据,Rss解析百度新闻以及根据IP获取所在城市
百度天气 接口地址:http://api.map.baidu.com/telematics/v3/weather?location=上海&output=json&ak=hXWAgbsC ...
- 使用腾讯云无服务器云函数(SCF)分析天气数据
欢迎大家前往云+社区,获取更多腾讯海量技术实践干货哦~ 作者:李想 无服务器云函数(SCF)是腾讯云提供的Serverless执行环境,也是国内首款FaaS(Function as a Service ...
- Docker最全教程——数据库容器化之持久保存数据(十一)
上一节我们讲述了SQL Server容器化实践(注意,SQL Server现在也支持跨平台),本节将讲述如何持久保存数据,并且接下来将逐步讲解其他数据库(MySql.Redis.Mongodb等等)的 ...
随机推荐
- NodeJS 难点(网络,文件)的 核心 stream 四: writable
什么是可写流 白板 可写流是对数据流向设备的抽象,用来 消费 上游流过来的数据 通过可写流程序可以把数据写入设备, 常见的是 本地磁盘文件或者 TCP.HTTP 等网络响应. 看一个之前用过的例子 ...
- 无监督︱异常、离群点检测 一分类——OneClassSVM
OneClassSVM两个功能:异常值检测.解决极度不平衡数据 因为之前一直在做非平衡样本分类的问题,其中如果有一类比例严重失调,就可以直接用这个方式来做:OneClassSVM:OneClassSV ...
- Locust 其他协议
Locust 是基于HTTP作为主要目标构建的,但是他同样可以扩展其他的协议,接受请求与获得返回.在编写的客户端的时候,我们就要使用到最常使用的 request_success 和 request_f ...
- final版——爱阅APP功能说明书
爱阅APP功能说明书 一.引言 以下内容是final版的功能说明书. 新增功能: 1.WiFi传书 2.书友群跳转 3.网址内部打开 4.设置-->关于爱阅 5.设置-->TXT文本的翻页 ...
- magento开发中文手册
Magento开发 第一章 手册简介Introduction 对一个开发人员来说,电子商务开发也许是现今最具创造性的工作.在这个瞬息万变的网络世界,为了保持始终领先竞争对手一步,无论是对你自己还是你的 ...
- linux下源码安装jdk1.8和tomcat8.5
Java是目前可移植性较高的语言,相当火热,tomcat运行就需要Java语言环境 0.java简介 1)tomcat运行需要对应的Java环境,Java环境通过安装jdk来获得2)为了防止兼容性问题 ...
- M端错误提醒 -- pop 使用
JS: window.pop = {/*alert提示框 *@param title 提示的标题 *@param desc 提示的描述 *@param btnNum 按钮的数量,假如为1,则无视e2, ...
- HihoCoder - 1051:补提交卡
时间限制:2000ms 单点时限:1000ms 内存限制:256MB 描述 小Ho给自己定了一个宏伟的目标:连续100天每天坚持在hihoCoder上提交一个程序.100天过去了,小Ho查看自己的提交 ...
- Almost Union-Find 并查集(脱离原来的树)
h: 0px; "> I hope you know the beautiful Union-Find structure. In this problem, you’re to im ...
- Microsoft - Find Biggest Node
public Node findBiggest (Node n1, Node n2){ Node c1 = n1; Node c2 = n2; boolean isPositive = false; ...