资讯专栏INFORMATION COLUMN

使用Docker部署Nginx+Flask+Mongo的应用

fyber / 1874人阅读

摘要:应用无法连接,本文使用方式。在数据库的配置应相应写成地址一定要写你配置的的名字本地测试时改回中配置使用的代理模式,其中执行应用的,应为内网

使用Docker部署Nginx+Flask+Mongo的应用

</>复制代码

  1. Nginx做为服务器,Mongo为数据库支持,Flask为Python语言的Web框架,利用Docker的容器特性,可以简单地部署在linux服务器上
项目准备

项目主要目录如下

</>复制代码

  1. __ project-name
  2. |__ docker-file
  3. |__ ningx
  4. |__ Dockerfile
  5. |__ conf
  6. |__ nginx.conf
  7. |__ flask
  8. |__ Dockerfile
  9. |__ requirements.txt
  10. |__ mongo
  11. |__ Dockerfile
  12. |__ setup.sh
  13. |__ docker-compose.yml
  14. |__ src
  15. |__ app
  16. |__ ...
  17. |__ run.py

简要说明

docker-file目录为docker部署的配置文件

src目录为flask应用的python代码

Docker的详细配置 docker-compose配置

</>复制代码

  1. version: "2.2"
  2. services:
  3. mongo:
  4. build: ./mongo
  5. volumes:
  6. - "./mongo/db:/data/db"
  7. restart: always
  8. ports:
  9. - "27017:27017"
  10. environment:
  11. MONGO_INITDB_ROOT_USERNAME: root
  12. MONGO_INITDB_ROOT_PASSWORD: 123456
  13. flask:
  14. build: ./flask
  15. links:
  16. - mongo
  17. ports:
  18. - "5000:5000"
  19. expose:
  20. - "5000"
  21. volumes:
  22. - ../src:/home/web
  23. nginx:
  24. build: ./nginx
  25. links:
  26. - flask
  27. volumes:
  28. - "./nginx/log:/var/log/nginx"
  29. - "../:/usr/share/nginx/html"
  30. ports:
  31. - "80:80"
  32. - "8080:8080"
  33. - "443:443"
  34. restart: always
MongoDB的配置

/mongo/Dockerfile的内容如下

</>复制代码

  1. FROM mongo:3.6
  2. # 设置时区
  3. ENV TZ=Asia/Shanghai
  4. RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
  5. # 设置工作目录
  6. ENV WORKDIR /usr/local/work
  7. ENV AUTO_RUN_DIR /docker-entrypoint-initdb.d
  8. ENV INSTALL_MONGO_SHELL setup.sh
  9. RUN mkdir -p $WORKDIR
  10. # 复制数据库的初始化命令
  11. COPY ./$INSTALL_MONGO_SHELL $AUTO_RUN_DIR/
  12. RUN chmod +x $AUTO_RUN_DIR/$INSTALL_MONGO_SHELL

/mongo/setup.sh的内容如下

</>复制代码

  1. 该文件的目的是,启动MongoDB后创建一个密码为test的用户test,并赋予它数据库test的读写操作

</>复制代码

  1. #!/bin/bash
  2. mongo <
  3. Flask应用的配置
  4. /flask/Dockerfile的内容如下

  5. </>复制代码

    1. FROM python:3.6
    2. # 设置时区
    3. ENV TZ=Asia/Shanghai
    4. RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
    5. # 设置工作区
    6. RUN mkdir -p /home/web
    7. WORKDIR /home/web
    8. # 添加依赖
    9. ADD requirements.txt /home/web/requirements.txt
    10. RUN pip3 install -i https://pypi.douban.com/simple/ -r requirements.txt
    11. # 使用gunicorn启动应用
    12. CMD gunicorn -w 4 -b 0.0.0.0:5000 run:app
  6. /src/app/run.py的代码

  7. </>复制代码

    1. 此处注释了调试用的 app.run(),发布时用gunicorn启动
  8. </>复制代码

    1. from app import create_app
    2. app = create_app("default")
    3. app.debug=False
    4. # if __name__ == "__main__":
    5. # app.run()
  9. Nginx的配置
  10. /nginx/Dockerfile的内容如下

  11. </>复制代码

    1. FROM nginx:1.14
    2. # 设置时区
    3. ENV TZ=Asia/Shanghai
    4. RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
    5. # 复制配置
    6. COPY conf/nginx.conf /etc/nginx/nginx.conf
  12. /nignx/conf/nginx.conf的内容如下

  13. </>复制代码

    1. user nginx;
    2. worker_processes 1;
    3. error_log /var/log/nginx/error.log warn;
    4. pid /var/run/nginx.pid;
    5. events {
    6. worker_connections 1024;
    7. }
    8. http {
    9. include /etc/nginx/mime.types;
    10. default_type application/octet-stream;
    11. log_format main "$remote_addr - $remote_user [$time_local] "$request" "
    12. "$status $body_bytes_sent "$http_referer" "
    13. ""$http_user_agent" "$http_x_forwarded_for"";
    14. access_log /var/log/nginx/access.log main;
    15. sendfile on;
    16. #tcp_nopush on;
    17. keepalive_timeout 65;
    18. # 开启gzip
    19. gzip on;
    20. gzip_min_length 1k;
    21. gzip_buffers 4 16k;
    22. #gzip_http_version 1.0;
    23. gzip_comp_level 1;
    24. gzip_types text/plain application/x-javascript text/css application/xml text/javascript application/x-httpd-php image/jpeg image/gif image/png;
    25. gzip_vary off;
    26. gzip_disable "MSIE [1-6].";
    27. server {
    28. listen 80;
    29. server_name localhost;
    30. keepalive_timeout 5;
    31. root /usr/share/nginx/html;
    32. location /static/ {
    33. alias /usr/share/nginx/html/src/app/static/;
    34. }
    35. location / {
    36. # checks for static file, if not found proxy to app
    37. try_files $uri @flask_app;
    38. }
    39. location @flask_app {
    40. proxy_pass http://192.168.0.2:5000; # 发布在阿里云上,应填写内网IP
    41. proxy_redirect off;
    42. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    43. proxy_set_header Host $http_host;
    44. proxy_set_header X-Real-IP $remote_addr;
    45. #proxy_buffers 8 32k;
    46. #proxy_buffer_size 64k;
    47. }
    48. }
    49. }
  14. 启动部署
  15. 进入docker-flie目录 cd docker-flie

  16. 启动docker docker-compose up

  17. 查看容器状态 docker ps

  18. 本地部署浏览器输入 127.0.0.1即可

  19. 最后出现类似docker_file_nginx_1,docker_file_mongo_1, docker_file_flask_1的3个容器,说明成功!!!

  20. 踩坑吐槽
  21. 1 mongol容器中的初始化文件需要放在 docker-entrypoint-initdb.d 目录下

  22. 本人做过如下尝试,会显示 mongdb未启动。

  23. </>复制代码

    1. ADD setup.sh /data/setup.sh
    2. RUN chmod +x /data/setup.sh
    3. CMD ["/data/setup.sh"]
  24. 2 flask应用无法连接mongo,本文使用link方式。

  25. 在数据库的配置应相应写成:

  26. </>复制代码

    1. MONGODB_SETTINGS = {
    2. "db": "test",
    3. "host": "mongo", # 127.0.0.1 host地址一定要写你配置的--link的名字
    4. "username": "test",
    5. "password": "test",
    6. "port": 27017
    7. }
  27. 本地测试时改回127.0.0.1

  28. 3 nginx中配置使用的代理模式,其中执行flask应用的IP,应为内网IP

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/40387.html

相关文章

  • 使用Docker部署Nginx+Flask+Mongo应用

    摘要:应用无法连接,本文使用方式。在数据库的配置应相应写成地址一定要写你配置的的名字本地测试时改回中配置使用的代理模式,其中执行应用的,应为内网 使用Docker部署Nginx+Flask+Mongo的应用 Nginx做为服务器,Mongo为数据库支持,Flask为Python语言的Web框架,利用Docker的容器特性,可以简单地部署在linux服务器上 项目准备 项目主要目录如下 __ ...

    afishhhhh 评论0 收藏0
  • 使用Docker部署Nginx+Flask+Mongo应用

    摘要:应用无法连接,本文使用方式。在数据库的配置应相应写成地址一定要写你配置的的名字本地测试时改回中配置使用的代理模式,其中执行应用的,应为内网 使用Docker部署Nginx+Flask+Mongo的应用 Nginx做为服务器,Mongo为数据库支持,Flask为Python语言的Web框架,利用Docker的容器特性,可以简单地部署在linux服务器上 项目准备 项目主要目录如下 __ ...

    sorra 评论0 收藏0
  • Flask+python3+supervisor+redis+docker+nginx技术架构web

    摘要:总结本次镜像化大概花了一周的时间,包括测试和解决一些坑,很多知识点包括原来的项目都不是太熟悉,所以记录一下,可能回头会发现这些很,但是相信对一些人还是有用的。 背景 手里有一个web项目,代码按照前端代码库、后端代码库分别在GitHub上,分散带来的结果是,不容易持续集成,比如你可能需要很多的job去保证一个项目的正常运作,但是这个项目也不是特别大,所以尝试将代码融合,于此同时将代码d...

    susheng 评论0 收藏0
  • Flask+python3+supervisor+redis+docker+nginx技术架构web

    摘要:总结本次镜像化大概花了一周的时间,包括测试和解决一些坑,很多知识点包括原来的项目都不是太熟悉,所以记录一下,可能回头会发现这些很,但是相信对一些人还是有用的。 背景 手里有一个web项目,代码按照前端代码库、后端代码库分别在GitHub上,分散带来的结果是,不容易持续集成,比如你可能需要很多的job去保证一个项目的正常运作,但是这个项目也不是特别大,所以尝试将代码融合,于此同时将代码d...

    mo0n1andin 评论0 收藏0
  • Flask+python3+supervisor+redis+docker+nginx技术架构web

    摘要:总结本次镜像化大概花了一周的时间,包括测试和解决一些坑,很多知识点包括原来的项目都不是太熟悉,所以记录一下,可能回头会发现这些很,但是相信对一些人还是有用的。 背景 手里有一个web项目,代码按照前端代码库、后端代码库分别在GitHub上,分散带来的结果是,不容易持续集成,比如你可能需要很多的job去保证一个项目的正常运作,但是这个项目也不是特别大,所以尝试将代码融合,于此同时将代码d...

    Jioby 评论0 收藏0

发表评论

0条评论

fyber

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<