使用 Docker 部署 Django 容器栈

使用 Docker 部署 Django 应用程序
本次实验环境:腾讯云服务器 CentOS 6.7 x86_64
由于 Docker Hub 的镜像在国内下载速度非常慢,所以此次使用的都是 daocloud 提供的镜像。Docker 的基本操作可以参考 http://www.tianfeiyu.com/?cat=159.

Docker 部署 Django 应用可以通过两种方式来完成:迭代构建和容器互联。以下使用容器互联的方式搭建 Django 容器栈。

所需镜像
Docker version 1.7.1
daocloud.io/nginx:1.11
daocloud.io/python:2.7
daocloud.io/mysql:5.6
daocloud.io/django:1.9
容器创建的顺序:

mysql --> redis --> django --> nginx
架构图

构建镜像前请先下载好所有所需的镜像。
1. 创建 mysql 容器
首先创建一个用于构建容器的目录:

    # mkdir /docker
    # cd /docker/
然后创建好以下几个目录用于存放相应的文件:

├── mysql 
│   ├── conf.d   
│   │   ├── jianshu.sql       ---对应的 django 数据库文件,需要手动导入
│   │   ├── character.cnf  ---设定字符集
│   │   └── my.cnf         ---额外配置
│   ├── data               ---挂载数据库文件的目录
│   └── start.sh           ---容器启动脚本
以下是 mysql 容器的启动脚本:

    #!/bin/bash
    #
   
    echo "---------------start mysql image-------------------"
    docker run --name mysql \
    -v $(pwd)/conf.d:/etc/mysql/conf.d \
    -v $(pwd)/data:/var/lib/mysql \
    -e MYSQL_ROOT_PASSWORD=123456 \
    -p 3307:3306 \
    -d daocloud.io/mysql:5.6.30
上述脚本创建一个名为 mysql 的容器,挂载容器的配置文件目录与数据目录并且初始化 mysql 的密码。

2. 创建 redis 容器
使用 redis 缓存后端数据。
redis 容器不需要特别的处理。

├── redis
│   └── start.sh
启动脚本:

    #!/bin/bash
    #
   
    docker run --name redis -d daocloud.io/redis:3.0.7
3. 创建 django 容器
要创建 django 容器,首先需要一个 django 镜像,即在 daocloud.io/python:2.7 镜像中安装 django 所需的环境。再将 django 容器与 mysql 和 redis 容器进行互联。

└── web
    ├── jianshu.tar.gz       ---app 打包文件
    ├── Dockerfile          ---构建 django 镜像所使用的 Dockerfile
    ├── requirements.txt  ---app 依赖的库
    ├── start.sh          ---启动脚本
    └── stop.sh             
以下为 Dockerfile 文件信息:

    # 基础镜像
    FROM daocloud.io/python:2.7
   
    # 维护者信息
    MAINTAINER tianfeiyu <www.tianfeiyu.com>
   
    ADD blog.tar.gz /usr/src/
   
    # app 所在目录
    WORKDIR /usr/src/jianshu
   
    # 安装 app 所需依赖
    RUN pip install --no-cache-dir -r requirements.txt -i http://mirrors.aliyun.com/pypi/simple/ --trusted-host mirrors.aliyun.com
启动脚本:

    #!/bin/bash
    #
    docker exec -d mysql mysql -uroot -p123456 -e "create database blog;"
    docker build -t feiyu/django-app .
    docker run --name django \
    -v /usr/src/jianshu \
    -v /usr/src/jianshu/static \                                                                                        
    --link mysql:mysql \
    --link redis:redis \
    -p 12000:8000 \
    -d feiyu/django-app /usr/local/bin/uwsgi --http :8000 --chdir /usr/src/jianshu -w jianshu.wsgi
上面使用 –link 选项来能够进行容器间安全的交互通信,使用格式 name:alias,可在一个 docker run 命令中重复使用该参数,使用 –link 时,连接通过容器名来确定容器,建议启动容器时自定义容器名。

通过 –link 选项来建立容器间连接,不但可以避免容器的 IP 和端口暴露到外网所导致的安全问题,还可以防止容器在重启后 IP 地址变化导致的访问失效,它的原理类似于 DNS 服务器的域名和地址映射。当容器的 IP 地址发生变化时,Docker 将自动维护映射关系中 IP 地址。

Docker 通过 2 种方式为容器公开连接信息:环境变量和更新 /etc/hosts 文件。
依旧使用 uwsgi来启动 django 应用程序,也可以使用 gunicorn 来启动。

4. 创建 nginx 容器
nginx 容器的创建比较简单,先在构建镜像时将 nginx 的配置文件复制到镜像,再将 nginx 容器与 django 容器进行互联并且挂载 django 容器中的数据卷。

├── nginx
│   ├── Dockerfile                 ---构建 nginx 镜像的 Dockerfile
│   ├── nginx-conf                   
│   │   └── django_project.conf       ---提供的 nginx 配置文件
│   ├── restart.sh
│   ├── start.sh
│   └── stop.sh
Dockerfile 文件:

    FROM daocloud.io/nginx
    
    MAINTAINER tianfeiyu <www.tianfeiyu.com>                                                                           
    
    RUN rm /etc/nginx/conf.d/default.conf
    ADD nginx-conf/ /etc/nginx/conf.d/
 
启动脚本:

    #!/bin/bash
    #                                                                                                                  
    docker build -t nginx .       
    docker run --name nginx-server \
    --link django:web \           
    -v /www/static \              
    --volumes-from django \       
    -p 8888:80 \
    -d nginx
到此,所有容器的创建过程都已经了解清楚,所有文件的目录树如下所示:

目录树

5. 启动容器栈
为了方便测试,每个需要创建的容器下面都会有一个启动脚本,并且有一个控制所有容器的启动脚本与停止脚本:

    #!/bin/bash
    #
    cd mysql                                                                                                           
    echo "start mysql----------------"
    ./start.sh
    
    cd ../redis 
    echo "start redis---------------------"
    ./start.sh
    
    cd ../web
    echo "start web ---------------------"
    ./start.sh
    
    cd ../nginx
    echo "start nginx-------------------"
    ./start.sh
启动完成

然后进入到 mysql 容器中将 django 数据库文件导入:

    # docker inspect --format "{{.State.Pid}}" mysql
    12674
    # nsenter --target 12674 --mount --uts --ipc --net --pid
    root@91308514f209:/# cd /etc/mysql/conf.d/
    root@91308514f209:/etc/mysql/conf.d# mysql -uroot -p jianshu < jianshu.sql

时间: 2024-11-18 03:10:17

使用 Docker 部署 Django 容器栈的相关文章

OpenStack Magnum如何部署Docker Swarm等容器

OpenStack Magnum通常用于部署和监控容器--如Docker Swarm.Google Kubernetes 和 Apache Mesos等,但是除此之外这个项目还有一些其他有用工具. 易于部署,并且体积要比hypervisor小很多,这些都是容器技术日益流行的原因,此外,单个容器只需要完成特定任务.现在最为常见的三种容器是Docker Swarm.Google Kubernetes和Apache Mesos. 使用容器技术,管理员能够部署完整应用或者是应用的重要组成部分,并且其体积

阿里云部署Docker(7)----将容器连接起来

路遥知马力,日久见人心.恩.该坚持的还是要坚持. 今天看到一个迅雷的师弟去了阿里,祝福他,哎,虽然老是被人家捧着叫大牛,我说不定通过不了人家的面试呢,哎,心有羞愧.  本文为本人原创,转载请表明来源:http://blog.csdn.net/minimicall 我们在阿里云上部署Docker服务系列教程已经到了第7节, 需要回顾的同学可以翻看我的博客. 今天,我们学习一下怎么将docker里面的容器连接起来.例如我是一个web服务,我需要用到mysql服务,如果它们属于不同的容器内,如果连接.

将代码从Git自动部署到容器

本文讲的是将代码从Git自动部署到容器[编者的话]将您的代码从您的Git仓库转移到您的容器可能是一件痛苦的工作.本文介绍了如何实现自动化部署. [烧脑式Kubernetes实战训练营]本次培训理论结合实践,主要包括:Kubernetes架构和资源调度原理.Kubernetes DNS与服务发现.基于Kubernetes和Jenkins的持续部署方案 .Kubernetes网络部署实践.监控.日志.Kubernetes与云原生应用.在CentOS中部署Kubernetes集群.Kubernetes

如何使用Docker部署一个Go Web应用程序

本文讲的是如何使用Docker部署一个Go Web应用程序,[编者的话]这是国外轻量级CJ厂商Semaphore发布的教程,旨在让开发人员如何借助于Docker让Go应用程序的编译及发动实现自动化,提升开发效率的同时也能保证软件部署的可靠性. 熟悉Docker如何提升你在构建.测试并部署Go Web应用程序的方式,并且理解如何使用Semaphore来持续部署. 简介 大多数情况下Go应用程序被编译成单个二进制文件,web应用程序则会包括模版和配置文件.而当一个项目中有很多文件的时候,由于很多文件

Docker部署WordPress LNMP(Nginx PHP MySQL)环境实践

Docker基于LXC实现了把软件封装到一个完整的文件系统,可以在docker容器中运行所需的一切代码,运行环境,系统工具和系统库.由于docker使用独立于主机的文件系统,可以确保软件在不同的主机环境中仍然保持运行环境不变.docker与主机共用一个操作系统内核,使用docker容器具有轻量级的特点,能占用更少的内存快速启动容器. 下面我们学习使用docker来部署目前非常流行的博客系统wordpress的运行环境nginx php mysql(作者wordpress博客www.centos.

手把手教你用Docker部署一个MongoDB集群

本文讲的是手把手教你用Docker部署一个MongoDB集群,[编者的话]MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中最像关系数据库的.支持类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引.本文介绍了如何使用Docker搭建MongoDB集群. 本文我会向大家介绍如何使用Docker部署一个MongoDB集群,具体如下: 2.6.5版本的MongoDB 有3个节点的副本集(Replica set) 身份验证 持

使用Docker部署Python应用的一些最佳实践

问题描述 本篇文章源自作者团队在长期开发过程中总结的宝贵经验,其中Supervisor.Gunicorn以及Nginx更是在使用Python开发Web应用时最常用的软件,因此对于打算使用Docker部署Python应用的读者而言,这些最佳实践是很有参考价值.同时希望各位在日常实践过程中,也能将各自踩到过的"坑"以及宝贵的经验分享出来,大家共同进步!我们可以使用Docker简单而高效的部署Python应用,同时,也有一些最佳实践来帮助我们愉快的完成部署.当然,也不是说这些最佳实践就是完成

专访Docker VP:容器的现状和发展趋势

本文讲的是专访Docker VP:容器的现状和发展趋势,[编者的话]Marianna Tessel有将近20年工程和领导经验,在大公司和初创公司都有工作履历.她现在领导Docker的工程师团队,直接贡献于开源项目,同时也负责Docker的商业支持.加入Docker前,他是VMware的VP,领导几百名工程师团队,负责开发多种VMware vSphere子系统.她以对多种技术生态系统推动而知名,被选为2013年最佳25位技术领域最有内在能力的女工程师.此文中,她对Docker现状,安全问题,以及与

Docker 手动配置容器网络实例详解_docker

Docker 手动配置容器网络   docker容器的网络是net命名空间与虚拟设备的结合,容器在启动时会创建一对虚拟接口veth pair,这一对接口分别放到本地和容器中,在本地的veth会被分配类似vethxxxx的名称并被桥接到指定网桥的上(默认为docker0),可以通过brctl show命令查看网桥上挂载的接口,在容器中的veth会从网桥获取一个未使用地址,该veth的名称会被更改为eth0并配置默认路由到vethxxxx,docker允许在启动容器的时候通过--net参数指定不同的