Docker Engine:应用打包工具,用于封装应用程序。 Docker Hub:用于管理云上容器应用程序的工具。
$ pip install flask
from flask import Flask
app = Flask(__name__)
@app.route("/")
def index():
return """
<h1>Python Flask in Docker!</h1>
<p>A sample web-app for running Flask inside Docker.</p>
"""
if __name__ == "__main__":
app.run(debug=True, host='0.0.0.0')
Copy
$ python app.py

Flask==1.0.2
FlaskApp
├── requirements.txt
├── Dockerfile
└── app
└── app.py
└── <other .py files>
FROM ubuntu:16.04
MAINTAINER jhao104 "j_hao104@163.com"
RUN apt-get update -y &&
apt-get install -y python3-pip python3-dev
COPY ./requirements.txt /requirements.txt
WORKDIR /
RUN pip3 install -r requirements.txt
COPY . /
ENTRYPOINT [ "python3" ]
CMD [ "app/app.py" ]
-
FROM:所有Dockerfile的第一个指令都必须是FROM ,用于指定一个构建镜像的基础源镜像,如果本地没有就会从公共库中拉取,没有指定镜像的标签会使用默认的latest标签,如果需要在一个Dockerfile中构建多个镜像,可以使用多次。
-
MAINTAINER:描述镜像的创建者,名称和邮箱。
-
RUN:RUN命令是一个常用的命令,执行完成之后会成为一个新的镜像,通常用于运行安装任务从而向镜像中添加额外的内容。在这里,我们需更新包,安装python3和pip 。在第二个RUN命令中使用pip来安装requirements.txt文件中的所有包。
-
COPY:复制本机文件或目录,添加到指定的容器目录,本例中将requirements.txt复制到镜像中。
-
WORKDIR:为RUN、CMD、ENTRYPOINT指令配置工作目录。可以使用多个WORKDIR指令,后续参数如果是相对路径,则会基于之前命令指定的路径。
-
ENTRYPOINT:在启动容器的时候提供一个默认的命令项。
-
RUN:运行app目录中的app.py。
docker build -t docker-flask:0.1 .
docker run --name flask_app -v $PWD/app:/app -p 5000:5000 docker-flask:0.1
-
基于之前构建的docker-flask镜像启动一个容器;
-
这个容器的名称被设置为flask_app 。如果没有——name选项,Docker将为容器生成一个名称。显式指定名称可以帮助我们定位容器(用来停止等操作);
-
-v选项将主机的app目录挂载到容器;
-
-p选项将容器的端口映射到主机。


#!/bin/bash
if [ ! -f /debug0 ]; then
touch /debug0
while getopts 'hd:' flag; do
case "${flag}" in
h)
echo "options:"
echo "-h show brief help"
echo "-d debug mode, no nginx or uwsgi, direct start with 'python3 app/app.py'"
exit 0
;;
d)
touch /debug1
;;
*)
break
;;
esac
done
fi
if [ -e /debug1 ]; then
echo "Running app in debug mode!"
python3 app/app.py
else
echo "Running app in production mode!"
nginx && uwsgi --ini /app.ini
fi
Copy
[uwsgi]
plugins = /usr/lib/uwsgi/plugins/python3
chdir = /app
module = app:app
uid = nginx
gid = nginx
socket = /run/uwsgiApp.sock
pidfile = /run/.pid
processes = 4
threads = 2
user nginx;
worker_processes 4;
pid /run/nginx.pid;
events {
worker_connections 20000;
}
http {
include mime.types;
sendfile on;
keepalive_timeout 65;
gzip off;
server {
listen 80;
access_log off;
error_log off;
location / { try_files $uri @flaskApp; }
location @flaskApp {
include uwsgi_params;
uwsgi_pass unix:/run/uwsgiApp.sock;
}
}
}
FROM ubuntu:16.04
MAINTAINER jhao104 "j_hao104@163.com"
RUN apt-get update -y &&
apt-get install -y python3-pip python3-dev &&
apt-get install -y nginx uwsgi uwsgi-plugin-python3
COPY ./requirements.txt /requirements.txt
COPY ./nginx.conf /etc/nginx/nginx.conf
WORKDIR /
RUN pip3 install -r requirements.txt
COPY . /
RUN adduser --disabled-password --gecos '' nginx
&& chown -R nginx:nginx /app
&& chmod 777 /run/ -R
&& chmod 777 /root/ -R
ENTRYPOINT [ "/bin/bash", "/entry-point.sh"]
docker build -t docker-flask:0.1 .
docker run -d --name flaskapp --restart=always -p 8091:80 docker-flask:0.1
docker stop flaskapp && docker rm flaskapp
docker run -it --name flaskapp -p 5000:5000 -v $PWD/app:/app docker-flask:0.1 -d debug
#!/bin/bash
if [ ! -f debug0 ]; then
touch debug0
if [ -e requirements_os.txt ]; then
apt-get install -y $(cat requirements_os.txt)
fi
if [-e requirements.txt ]; then
pip3 install -r requirements.txt
fi
while getopts 'hd:' flag; do
case "${flag}" in
h)
echo "options:"
echo "-h show brief help"
echo "-d debug mode, no nginx or uwsgi, direct start with 'python3 app/app.py'"
exit 0
;;
d)
touch debug1
;;
*)
break
;;
esac
done
fi
if [ -e debug1 ]; then
echo "Running app in debug mode!"
python3 app/app.py
else
echo "Running app in production mode!"
nginx && uwsgi --ini /app.ini
fi
-
每次启动应用程序时需要安装依赖项,这样对网络资源有要求。
-
它破坏了容器化的目标之一,即修复和测试由于部署环境的变化而不会改变的依赖关系;
-
增加了应用程序启动的额外开销,这将增加容器的启动时间;
未经允许不得转载:大自然的搬运工 » Docker部署Python项目实战演练