升级docker并构建自己的app

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介: 版权声明:您好,转载请留下本人博客的地址,谢谢 https://blog.csdn.net/hongbochen1223/article/details/70880786 现在docker已经升级了很多版本了,而我目前的docker版本仍然是1.12.5,比较老的版本,所以现在我们需要升级我们的docker版本,首先是如何查看我们系统中的docker版本呢?运行命令docker --version即可查看。
版权声明:您好,转载请留下本人博客的地址,谢谢 https://blog.csdn.net/hongbochen1223/article/details/70880786

现在docker已经升级了很多版本了,而我目前的docker版本仍然是1.12.5,比较老的版本,所以现在我们需要升级我们的docker版本,首先是如何查看我们系统中的docker版本呢?

运行命令docker --version即可查看。

(一)、Docker新版本介绍及安装

目前,Docker分为了两个可用的版本,分别为Docker企业版Docker社区版,故名思议,Docker EE,即Docker企业版是专门为企业开发和IT团队构建,部署商业应用所设计的,而Docker CE,即Docker社区本是为开发者和刚开始使用Docker的小团队开发设计的。在这里我们使用Docker CE

卸载老版本

Docker的老版本被称为docker或者是docker engine,如果安装过,先把他们卸载掉。


 sudo apt-get remove docker docker-engine

如果卸载成功,apt-get将会报出没有安装包被安装。

位于目录/var/lib/docker/中的镜像,容器,卷和网络被保留。Docker CE包现在被称为docker-ce,Docker EE包现在被称为docker-ee

为Trusty 14.04推荐的额外的包

如果没有其他原因,推荐您安装linux-image-extra-*这些包,这些允许Docker使用aufs存储驱动。


$ sudo apt-get update

$ sudo apt-get install \
    linux-image-extra-$(uname -r) \
    linux-image-extra-virtual

安装Docker

有两种安装方式,一个是通过仓库安装,一个是通过包安装,在这里我们选择使用包安装。

我们需要下载.deb文件来安装docker。这里有一个麻烦的地方就是,每次我们想要更新docker的话,就需要下载一个新的文件,无所谓了,我们选择包安装。

Docker CEDocker EE的安装步骤也是不一样的,我们只关注Docker CE。进入下载地址

,选择我们的ubuntu版本,浏览pool/stable,选择amd64或者是armhf,然后下载相应你想要安装的的.deb文件。

下载完成之后,使用下面的命令来安装你所下载的安装包。


dpkg -i /path/to/package.deb

安装完成之后,我们通过运行hello-world镜像来验证Docker CE是否安装完成。

卸载Docker

我们可以使用下面的命令来卸载Docker包。


sudo apt-get purge docker-ce

但是镜像,容器,卷或者是定制的配置文件将不会自动被删除,我们可以通过下面的命令来移走:


sudo rm -rf /var/lib/docker

(二)、构建新的app

你的新的开发环境

在过去,如果你想要开始编写一个Python应用,第一步工作便是在你的机器上安装一个Python运行时环境,但是这样便会导致一个问题是,如果想要你的应用如期运行你的机器环境在哪里,还有运行你的应用的app在哪里。

使用Docker,你仅仅需要抓取一个轻便的Python运行时作为一个镜像,不必安装。然后,你的构建需要包括基本的Python镜像和你的app代码,确保你的app,他的依赖和运行时都在一块。

这些轻便的镜像被定义称为Dockerfile

使用Dockerfile定义一个容器

Dockerfile将会定义在你的容器环境中什么将会运行。访问的资源例如网络接口和磁盘驱动在环境中都被虚拟出来了,这个是和你系统中的其他事物隔离的,所以你必须映射端口到外面的世界,并且必须要指定那些文件你想要复制到那个环境中。然后,完成那些操作之后,你可能希望定义在这个Dockerfile中的app的构建在任何地方运行都一样的。

Dockerfile

创建一个空的目录然后把这个名称为Dockerfile的文件放进去。注意每一行的注释。


# 使用一个官方的Python运行时作为一个镜像
FROM python:2.7-slim

# 设置工作目录到/app
WORKDIR /app

# 复制当前目录内容到/app的容器中
ADD . /app

# 安装指定在requirements.txt文件中的所有的包
RUN pip install -r requirements.txt

# 使80端口在容器外能够被访问
EXPOSE 80

# 定义环境变量
ENV NAME World

# 当容器启动的时候运行app.py
CMD ["python", "app.py"]

这个Dockerfile引用了一些我们没有创建的文件,app.pyrequirements.txt。在下面我们获取这些文件。

app本身

获取这两个文件并放到和Dockerfile相同的目录中。这样就完成了我们的app,看上去是很简单的。当上述的Dockerfile被构建进入镜像的时候,app.pyrequirements.txt也将会存在,因为DockerfileADD命令,app.py的输出将通过HTTP被访问,因为EXPOSE命令。

requirements.txt


Flask
Redis

app.py


from flask import Flask
from redis import Redis, RedisError
import os
import socket

# Connect to Redis
redis = Redis(host="redis", db=0)

app = Flask(__name__)

@app.route("/")
def hello():
    try:
        visits = redis.incr('counter')
    except RedisError:
        visits = "<i>cannot connect to Redis, counter disabled</i>"

    html = "<h3>Hello {name}!</h3>" \
           "<b>Hostname:</b> {hostname}<br/>" \
           "<b>Visits:</b> {visits}"
    return html.format(name=os.getenv('NAME', "world"), hostname=socket.gethostname(), visits=visits)

if __name__ == "__main__":
    app.run(host='0.0.0.0', port=80)

现在我们可以看到pip install requirements.txt安装了Flask和Redis库,并且app打印出了环境变量NAME,和socker.gethoustname()调用后的输出是一样的。最后,因为Redis并没有运行(因为我们仅仅安装了Python库,而不是Redis本身),所以我们得到的结果将会是尝试使用它但是失败了,并且产生一个错误信息。

构建app

就是这样,在你的系统中,你不需要Python或者是requirements.txt文件中的任何东西,你也不需要构建或者是运行这个景象安装到你的系统中。看上去好像是你设置了Python或者是Flask的环境变量,实际上并没有。下面是ls应该显示的:


$ ls
Dockerfile      app.py          requirements.txt

现在运行build命令。这将会创建一个Docker镜像,该镜像我们使用-t选项来标记他,这样他就有了一个友好的名称。


docker build -t friendlyhello .

你构建的镜像在哪呢?他在你的机器的本地Docker镜像条目中。


$ docker images

REPOSITORY            TAG                 IMAGE ID
friendlyhello         latest              326387cea398

运行app

运行app,使用-p选项映射你的机器的端口4000到容器的EXPOSE的端口80。


docker run -p 4000:80 friendlyhello

你应该看到一个提醒,Python正在http://0.0.0.0:80服务你的app。但是那个信息是来自内部容器的,他并不知道你映射了端口80到4000了,使得当前的URL http://localhost:4000 。到这里,你将会看到Hello World文本,容器ID和Redis错误信息。

注意:这个端口映射`4000:80`是为了证明在`Dockerfile`中你的`EXPOSE`和你使用`docker run -p`发布的不同的。在后面的步骤中,我们仅仅映射端口80到端口80,这样就可以使用`http://localhost`。

在你的终端中使用CTRL+C来退出。

现在我们在后台运行该app,使用分离的模式:


docker run -d -p 4000:80 friendlyhello

你获取到了一个长得容器ID并且然后被踢回到你的终端中。你的容器正在后台运行。你可以使用docker ps来看到一个简便的容器ID.


$ docker ps
CONTAINER ID        IMAGE               COMMAND             CREATED
1fa4ab2cf395        friendlyhello       "python app.py"     28 seconds ago

你将看到CONTAINER IDhttp://localhost:4000中的是相匹配的。

现在使用docker stop来结束进程,使用CONTAINER ID,就像下面这样:


docker stop 1fa4ab2cf395

共享你的镜像

后面我们学习如何共享我们的镜像。


docker login
docker tag friendlyhello username/repository:tag
docker push username/repository:tag
docker run -p 4000:80 username/repository:tag
相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
1月前
|
存储 运维 安全
构建高效自动化运维体系:Ansible与Docker的完美结合
【2月更文挑战第31天】 随着云计算和微服务架构的兴起,自动化运维成为保障系统稳定性和提升部署效率的关键手段。本文将详细探讨如何通过Ansible和Docker的结合来构建一个高效、可靠且易于管理的自动化运维体系。首先,介绍自动化运维的必要性及其在现代IT基础设施中的作用;然后,分别阐述Ansible和Docker的技术特点及优势;最后,提供一个基于Ansible和Docker结合使用的实践案例,以及实施过程中遇到的挑战和解决方案。
|
1月前
|
运维 Kubernetes 监控
构建高效自动化运维体系:基于Docker和Kubernetes的实践指南
【2月更文挑战第30天】 在当今快速发展的云计算时代,传统的IT运维模式已难以满足业务的敏捷性和稳定性需求。本文深入探讨了如何通过Docker容器化技术和Kubernetes集群管理工具构建一个高效、可靠的自动化运维体系。文章首先概述了容器化技术和微服务架构的基本概念,随后详细阐述了基于Docker的应用打包、部署流程,以及Kubernetes在自动化部署、扩展和管理容器化应用中的关键作用。最后,文中通过案例分析,展示了如何在实际场景中利用这些技术优化运维流程,提高系统的整体效率和可靠性。
|
1月前
|
运维 安全 网络安全
构建高效自动化运维体系:Ansible与Docker的完美融合
【2月更文挑战第30天】在当今快速迭代和持续部署的软件发展环境中,自动化运维成为确保效率和稳定性的关键。本文将探讨如何通过结合Ansible和Docker技术,构建一个高效的自动化运维体系。我们将分析Ansible的配置管理功能和Docker容器化的优势,并展示它们如何协同工作以简化部署流程,增强应用的可移植性,并提供一致性的系统环境。此外,文章还将介绍一些最佳实践,帮助读者在真实环境中实现这一整合方案。
|
2月前
|
机器学习/深度学习 算法 数据可视化
基于Google Earth Engine云平台构建的多源遥感数据森林地上生物量AGB估算模型含生物量模型应用APP
基于Google Earth Engine云平台构建的多源遥感数据森林地上生物量AGB估算模型含生物量模型应用APP
104 0
|
8天前
|
存储 运维 监控
构建高效稳定的Docker容器监控体系
【4月更文挑战第18天】 在现代微服务架构中,Docker容器已成为部署和运行应用的标准环境。随之而来的挑战是如何有效监控这些容器的性能与健康状况,确保系统的稳定性和可靠性。本文将探讨构建一个高效稳定的Docker容器监控体系的关键技术和方法,包括日志管理、性能指标收集以及异常检测机制,旨在为运维人员提供实用的指导和建议。
13 0
|
27天前
|
运维 Kubernetes 持续交付
构建高效自动化运维体系:基于Docker和Kubernetes的最佳实践
在现代云计算环境中,自动化运维成为保障系统稳定性与提升效率的关键。本文深入探讨了如何利用Docker容器化技术和Kubernetes容器编排工具构建一个高效、可靠的自动化运维体系。文中不仅介绍了相关的技术原理,还结合具体案例分析了实施过程中的常见问题及解决方案,为读者提供了一套行之有效的最佳实践指南。
|
29天前
|
运维 监控 云计算
构建高效稳定的Docker容器监控体系
随着微服务架构的普及,Docker容器作为其核心承载单元,在系统运维中扮演着日益重要的角色。本文旨在探讨如何构建一个高效且稳定的Docker容器监控体系,以确保容器运行的可靠性和系统的高可用性。文章首先分析了容器监控的必要性,接着详细介绍了监控体系的设计理念和组件选择,最后提供了实施过程中的关键步骤与最佳实践。通过本文,读者将掌握构建和维护Docker容器监控体系的有效方法。
|
1月前
|
Kubernetes 开发者 Docker
构建高效微服务架构:Docker与Kubernetes的完美搭档
【2月更文挑战第29天】在当今快速发展的软件开发领域,微服务架构已成为提高系统可维护性、扩展性和敏捷性的关键解决方案。本文将深入探讨如何利用Docker容器化技术和Kubernetes集群管理工具,共同构建一个既高效又可靠的微服务环境。我们将分析Docker和Kubernetes的核心功能,并展示它们如何协同工作以简化部署流程、增强服务发现机制以及实现无缝的服务伸缩。通过实际案例分析,本文旨在为开发者提供一套实用的微服务架构设计和实施指南。
|
2月前
|
消息中间件 运维 应用服务中间件
容器化运维:构建高可用RabbitMQ集群的Docker Compose指南
容器化运维:构建高可用RabbitMQ集群的Docker Compose指南
178 0
|
2月前
|
消息中间件 Docker 容器
docker构建rabbitmq并配置延迟队列插件
docker构建rabbitmq并配置延迟队列插件
35 0