使用Docker构建服务

简介: 使用Docker构建服务

要构建的是使用Jekyll框架的自定义网站.会构建两个镜像.

  • 一个镜像安装了Jekyll及其他用于构建Jekyll网站必要的软件包
  • 一个镜像通过Apache来让Jekyll网站工作起来.
    在启动容器时,通过创建一个新的Jekyll网站来实现自服务.工作流程:
  • 创建Jekyll基础镜像和Apache镜像
  • 从Jekyll镜像创建一个容器,这个容器存放通过卷挂载的网站源码
  • 从Apache镜像创建一个容器,这个容器利用包含编译后的网站的卷,并为其服务.
  • 在网站需要更新时,清理并重复上面的步骤.
    可以把这个例子看做是创建一个多主机站点最简单的方法.

一. Jekyll基础镜像

    1. 创建Jekyll Dockerfile
mkdir jekyll
cd jekyll
vi Dockerfile 
    1. Dockerfile 内容:
FROM ubuntu:18.04
MAINTAINER hiekay "hikay5230@gmail.com"
ENV REFRESHED_AT 2018-11-8
RUN apt-get -yqq update
RUN apt-get -yqq install ruby ruby-dev gcc g++ make nodejs
RUN gem install --no-rdoc --no-ri jekyll

VOLUME /data
VOLUME /var/www/html
WORKDIR /data
ENTRYPOINT [ "jekyll", "build", "--destination=/var/www/html"  ]

该镜像基于Ubuntu,并安装了ruby 和支持jekyll的包,然后用VOLUME命令创建了两个卷

  • /data/ 用来存放网站的源代码
  • /var/www/html 用来放编译后的jekyll网站码
    工作目录设置为/data ,最后用ENTRYPOINT 指令自动构建命令,将工作目录/data/中的所有jekyll网站代码构建到 /var/www/html 目录中.

二 . 构建Jekyll基础镜像

  • 1.构建Jekyll镜像
$ sudo docker build -t hiekay/jekyll .
  • 2.查看Jekyll基础镜像
$ sudo docker images 

三 . Apache镜像

接下来构建第二个镜像, 一个用来架构新网站的Apache服务器.

  • 1.创建Apache Dockerfile
mkdir apche 
cd apache 
vi Dockerfile 
  • 2 Jekyll Apache 的Dockerfile 内容
FROM ubuntu:18.04
MAINTAINER hiekay "hikay5230@gmail.com"
ENV REFRESHED_AT 2018-11-8
RUN apt-get -yqq update
RUN apt-get -yqq install apache2

ENV APACHE_RUN_USER www-data 
ENV APACHE_RUN_GROUP www-data 
ENV APACHE_LOG_DIR /var/log/apache2 
ENV APACHE_PID_FILE /var/run/apache2.pid 
ENV APACHE_RUN_DIR /var/run/apache2 
ENV APACHE_LOCK_DIR /var/lock/apach2 

RUN  mkdir -p $APACHE_RUN_DIR $APACHE_LOCK_DIR $APACHE_LOG_DIR 
EXPOSE 80
ENTRYPOINT [ "/usr/sbin/apache2" ]
CMD ["-D", "FOREGROUND"]

该镜像基于Ubuntu , 并安装了Apache, 然后使用VOLUME指令创建一个卷/var/www/html 用来存放编译后的Jekyll网站, 然后将 /var/www/html 设为工作目录
然后使用ENV指令设置了一些必要的环境变量, 创建了必要目录,并使用EXPOSE公开了80端口 ,最后指定了ENTRYPOINT和CMD指令组合来在容器启动时默认运行Apache.

四 . 构建Jekyll Apache镜像

  • 1.构建Jekyll Apache镜像
 $ sudo docker build -t hiekay/apache .
  • 2.查看新的Jekyll Apache镜像
$ sudo docker images 

五 . 启动Jekyll 网站

现在已经有了两个镜像

  • jekyll:安装了Ruby及其他必备软件包的Jekyll镜像
  • Apache:通过Apache Web服务器来让Jekyll网站工作起来的镜像
  • 1.创建实例Jekyll博客
cd $HOME
git clone https://github.com/hiekay/james_blog.git
  • 2.创建Jekyll容器
$ sudo docker run -v /home/hiekay/james_blog:/data/ --name hiekay_blog hiekay/jekyll 
//输出:
Configuration file: /data/_config.yml
            Source: /data
       Destination: /var/www/html
 Incremental build: disabled. Enable with --incremental
      Generating... 
                    done in 0.074 seconds.
 Auto-regeneration: disabled. Use --watch to enable.

创建了一个hiekay_blog 的新容器,把本地james_blog目录作为/data/卷挂载到容器里.容器拿到网站的源代码,并将其构建到已编译的网站,存放到/var/www/html目录.

  • 注意: 卷在Docker宿主机的 /var/lib/docker/volumes 目录中.可以通过 命令查看
docker inspect -f "{{.Volumes}}"
    1. 创建Apache容器
$ sudo docker run -d -P --volumes-from hiekay_blog hiekay/apache

用了一个新标志 --volumes-from : 把指定容器里的所有卷都加入新创建的容器里. 这意味着, apache 容器可以访问之前创建的hiekay_blog容器里面/var/www/html 卷中存放编译后的Jekyll网站. 即便hiekay_blog容器没有运行. apache也可以访问这个卷.如果 docker rm 命令删除了hiekay_blog 容器,卷就不存在了.

    1. 查看apache容器的端口
$ sudo docker ps -l                                             
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                   NAMES
429b7880af28        hiekay/apache       "/usr/sbin/apache2 -…"   3 minutes ago       Up 3 minutes        0.0.0.0:32772->80/tcp   gallant_cori

$ sudo docker port  429b7880af28  80 

0.0.0.0:32772

浏览器访问:
image.png
成功运行起来了 !

六 . 更新Jekyll 网站

如果要更新网站的数据,可以直接修改 $/james_blog /_config.yml文件来修改博客名字.

  • 1.编辑Jekyll 博客
$ vi _config.yml
修改内容:
将title修改为:
hiekay' Dynamic Docker-Driven Blog

更新网站只需要再次启动容器

    1. 再次启动hiekay_blog容器
$ sudo docker start hiekay_blog      

hiekay_blog
  • 3.查看hiekay_blog 容器 日志
$ sudo docker logs hiekay_blog     

//输出   
Configuration file: /data/_config.yml
            Source: /data
       Destination: /var/www/html
 Incremental build: disabled. Enable with --incremental
      Generating... 
                    done in 0.074 seconds.
 Auto-regeneration: disabled. Use --watch to enable.
Configuration file: /data/_config.yml
            Source: /data
       Destination: /var/www/html
 Incremental build: disabled. Enable with --incremental
      Generating... 
                    done in 0.065 seconds.
 Auto-regeneration: disabled. Use --watch to enable.

看到Jekyll编译过程第二次被运行,并且网站更新了.刷新即可.
image.png
由于共享的卷会自动更新,这一切都不需要更新或者重启Apache容器.

七 . 备份Jekyll 卷

我们新建一个容器,用来备份/var/www/html卷

  • 1.备份 /var/www/html 卷
$ sudo docker run --rm --volumes-from hiekay_blog -v $(pwd):/backup ubuntu tar cvf /backup/hiekay_blog_backup.tar /var/www/html

运行了一个已有的Ubuntu容器,并把heikay_blog的卷挂载到这个容器了里,在该容器里创建/var/www/html目录, 用-v标志 把当前目录($(pwd))挂载到容器的/backup目录, 最后运行备份命令.
其中指定--rm标志, 是针对只用一次的容器,用完即扔.
其中备份命令:

tar cvf /backup/hiekay_blog_backup.tar /var/www/html
目录
相关文章
|
26天前
|
存储 运维 安全
构建高效自动化运维体系:Ansible与Docker的完美结合
【2月更文挑战第31天】 随着云计算和微服务架构的兴起,自动化运维成为保障系统稳定性和提升部署效率的关键手段。本文将详细探讨如何通过Ansible和Docker的结合来构建一个高效、可靠且易于管理的自动化运维体系。首先,介绍自动化运维的必要性及其在现代IT基础设施中的作用;然后,分别阐述Ansible和Docker的技术特点及优势;最后,提供一个基于Ansible和Docker结合使用的实践案例,以及实施过程中遇到的挑战和解决方案。
|
27天前
|
运维 Kubernetes 监控
构建高效自动化运维体系:基于Docker和Kubernetes的实践指南
【2月更文挑战第30天】 在当今快速发展的云计算时代,传统的IT运维模式已难以满足业务的敏捷性和稳定性需求。本文深入探讨了如何通过Docker容器化技术和Kubernetes集群管理工具构建一个高效、可靠的自动化运维体系。文章首先概述了容器化技术和微服务架构的基本概念,随后详细阐述了基于Docker的应用打包、部署流程,以及Kubernetes在自动化部署、扩展和管理容器化应用中的关键作用。最后,文中通过案例分析,展示了如何在实际场景中利用这些技术优化运维流程,提高系统的整体效率和可靠性。
|
28天前
|
运维 安全 网络安全
构建高效自动化运维体系:Ansible与Docker的完美融合
【2月更文挑战第30天】在当今快速迭代和持续部署的软件发展环境中,自动化运维成为确保效率和稳定性的关键。本文将探讨如何通过结合Ansible和Docker技术,构建一个高效的自动化运维体系。我们将分析Ansible的配置管理功能和Docker容器化的优势,并展示它们如何协同工作以简化部署流程,增强应用的可移植性,并提供一致性的系统环境。此外,文章还将介绍一些最佳实践,帮助读者在真实环境中实现这一整合方案。
|
1月前
|
前端开发 关系型数据库 MySQL
IDEA集成Docker插件打包服务镜像与运行【附Docker命令汇总】
IDEA集成Docker插件打包服务镜像与运行【附Docker命令汇总】
|
1月前
|
存储 Linux 数据安全/隐私保护
如何在本地Docker中部署MinIO服务并实现远程访问管理界面
如何在本地Docker中部署MinIO服务并实现远程访问管理界面
179 0
|
1月前
|
弹性计算 关系型数据库 MySQL
阿里云ECS使用docker搭建mysql服务
阿里云ECS使用docker搭建mysql服务
150 1
|
19天前
|
运维 Kubernetes 持续交付
构建高效自动化运维体系:基于Docker和Kubernetes的最佳实践
在现代云计算环境中,自动化运维成为保障系统稳定性与提升效率的关键。本文深入探讨了如何利用Docker容器化技术和Kubernetes容器编排工具构建一个高效、可靠的自动化运维体系。文中不仅介绍了相关的技术原理,还结合具体案例分析了实施过程中的常见问题及解决方案,为读者提供了一套行之有效的最佳实践指南。
|
19天前
|
关系型数据库 MySQL Nacos
【深入浅出Nacos原理及调优】「实战开发专题」采用Docker容器进行部署和搭建Nacos服务以及“坑点”
【深入浅出Nacos原理及调优】「实战开发专题」采用Docker容器进行部署和搭建Nacos服务以及“坑点”
44 1
|
23天前
|
关系型数据库 MySQL 数据库
使用Docker搭建MySQL数据库服务
本文介绍了如何使用Docker搭建MySQL数据库服务。首先,通过`docker pull mysql:5.7`命令拉取MySQL 5.7镜像,然后运行`docker run`命令创建并启动容器。接着,使用`docker exec`进入容器并创建MySQL用户及授权。最后,通过MySQL客户端如Navicat测试连接,验证安装成功。Docker简化了MySQL的部署和管理,确保环境一致性。
36 0
|
28天前
|
Kubernetes 开发者 Docker
构建高效微服务架构:Docker与Kubernetes的完美搭档
【2月更文挑战第29天】在当今快速发展的软件开发领域,微服务架构已成为提高系统可维护性、扩展性和敏捷性的关键解决方案。本文将深入探讨如何利用Docker容器化技术和Kubernetes集群管理工具,共同构建一个既高效又可靠的微服务环境。我们将分析Docker和Kubernetes的核心功能,并展示它们如何协同工作以简化部署流程、增强服务发现机制以及实现无缝的服务伸缩。通过实际案例分析,本文旨在为开发者提供一套实用的微服务架构设计和实施指南。