《云计算技术》实验-Docker部署

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: 安装Docker(Linux)部署一个简单的Python应用部署c++应用

安装Docker(Linux)

运行以下命令安装docker

sudo apt update
sudo apt install apt-transport-https ca-certificates curl software-properties-common
curl -fsSL https://mirrors.aliyun.com/docker-ce/linux/ubuntu/gpg | sudo apt-key add -
sudo add-apt-repository "deb [arch=amd64] https://mirrors.aliyun.com/docker-ce/linux/ubuntu $(lsb_release -cs) stable"
sudo apt install docker-ce

查看是否安装成功:

docker --version

运行Hello World

为了测试Docker是否能正常使用,我们先拉取(pull)一个hello-world镜像运行。

输入命令:

docker run hello-world

若Docker安装成功,则会输出下图所示信息。

从输出信息可以了解到,Docker未能在本地找到hello-world镜像后,在Docker Hub中拉取(pull)了hello-world的最新镜像,并创建了容器,在容器中运行程序,产生输出。

部署一个简单的Python应用

第一步:创建一个自定义的镜像

在本地建立一个命名为“Dockerfile.txt”的文件。输入如下命令。

# Use an official Python runtime as a parent image
FROM python:3.7-alpine
# Set the working directory to /app
WORKDIR /app
# Copy the current directory contents into the container at /app
ADD . /app
# Install any needed packages specified in requirements.txt
RUN pip install -r requirements.txt
# Make port 80 available to the world outside this container
EXPOSE 80
# Define environment variable
ENV NAME World
# Run app.py when the container launches
CMD ["python", "app.py"]

第二步:建立应用程序文件app.py和文本文件requirements.txt

app.py文件、requirements.txt文件应该与Dockerfile.txt文件放在同一个文件夹下。

以下是app.py这个python源代码文件的内容

from flask import Flask
from redis import Redis, RedisError
import os
import socket
# Connect to Redis
redis = Redis(host="redis", db=0, socket_connect_timeout=2,
socket_timeout=2)
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)

上述代码输出环境变量NAME,并通过调用socket.gethostname()获取当前主机的hostname。

以下是 requirements.txt 这个文件的内容

Flask
Redis

Flask 和 Redis 都是在requirements.txt 文件中指定的python的包,docker会按照requirements.txt中的内容下载必要的python包。

理解Dokerfile文件

•FROM命令指定了基础镜像。
•WORKDIR命令配置了工作目录。
•ADD命令会将app.py拷贝到容器中。
•RUN pip install -r requirements.txt命令导入了Python的Flask和Redis标准库。
•EXPOSE命令指定容器需要映射到宿主机器的端口。
•ENV命令用于设置环境变量。
•CMD用于container启动时指定的操作。该操作可以是执行自定义脚本,也可以是执行系统命令。
该指令只能在文件中存在一次,如果有多个,则只执行最后一条。

第三步:构建应用

输入如下命令:

docker build -t docker-whale -f ./Dockerfile.txt .

注意在上述命令行的最后,有一个英文句点,不要遗漏。

其中,-t指定了生成镜像的仓库名,-f指定Dockerfile文本文件。

通过 docker image ls 命令可以查看本地的所有镜像。可以看到刚刚创建的自定义镜像docker-whale。

第四步:运行应用

注意:如果在阿里云ECS上安装部署这个docker应用,在自己的个人电脑上使用浏览器访问这个docker应用的话,还需要去ECS的安全配置中打开4000端口方能访问,否则无法看到下述效果。

1) 启动容器实例运行应用

输入如下命令:

docker run -p 4000:80 docker-whale

其中,-p将容器的端口号80映射到宿主机器的端口号4000,从而使得app.py的程序输出可以通过HTTP协议输出到浏览器。

2) 访问容器实例,查看运行结果

在浏览器中输入URL:http://a.b.c.d:4000 即可看到应用的输出结果。其中a.b.c.d是部署了docker应用的主机ip地址。

注意:如果在阿里云ECS主机上部署并启动容器实例,可以开启第二个终端窗口连接阿里云ECS主机。

随后在命令行执行:

curl  localhost:4000

即可看到类似如下的输出:

<h3>Hello World!</h3><b>Hostname:</b> dbc3d903eca0<br/>
<b>Visits:</b> <i>cannot connect to Redis, counter d

部署c++应用

将C/C++代码运行在容器内的最简方法,就是将编译指令写入Dockerfile 中,然后使用此Dockerfile构建自定义镜像,最后直接运行此镜像,即可启动程序。

FROM gcc:4.9
# Set the working directory to /myapp
WORKDIR /myapp
# Copy the current directory contents into the container at /myapp
ADD . /myapp
# Make port 80 available to the world outside this container
EXPOSE 80
RUN gcc -o myapp main.c 
# Run app.py when the container launches
CMD ["./myapp"]

编辑main.c,内容如下:

#include<stdio.h> 
int main() 
{ 
    printf("Hello World\n"); 
    return 0; 
}

现在,就可以使用Dockerfile来构建镜像my-gcc-app:

docker build -t gcc-image . -f Dockerfile.txt

创建并运行此容器,会编译并运行程序,输出Hello World语句。

docker run -it --rm --name gcc-container gcc-image

Hello World

相关实践学习
2分钟自动化部署人生模拟器
本场景将带你借助云效流水线Flow实现人生模拟器小游戏的自动化部署
7天玩转云服务器
云服务器ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,可降低 IT 成本,提升运维效率。本课程手把手带你了解ECS、掌握基本操作、动手实操快照管理、镜像管理等。了解产品详情:&nbsp;https://www.aliyun.com/product/ecs
目录
相关文章
|
15天前
|
消息中间件 监控 RocketMQ
Docker部署RocketMQ5.2.0集群
本文详细介绍了如何使用Docker和Docker Compose部署RocketMQ 5.2.0集群。通过创建配置文件、启动集群和验证容器状态,您可以快速搭建起一个RocketMQ集群环境。希望本文能够帮助您更好地理解和应用RocketMQ,提高消息中间件的部署和管理效率。
186 91
|
16天前
|
存储 NoSQL Redis
Docker 部署 Redis
在使用 Docker 部署 Redis 时,为实现数据持久化,需正确挂载容器内的数据目录到宿主机。推荐命令如下: ``` docker run -d --name redis -v /mnt/data/redis:/data -p 6379:6379 redis ``` 该命令将宿主机的 `/mnt/data/redis` 目录挂载到容器的 `/data` 目录,确保 Redis 数据持久化。此路径更通用,适合大多数场景。避免使用不匹配的挂载路径,如 `/var/lib/redis` 或 `/mnt/data/redis` 到非默认目录,以防止数据无法正确持久化。
|
30天前
|
存储 关系型数据库 MySQL
美团面试:MySQL为什么 不用 Docker部署?
45岁老架构师尼恩在读者交流群中分享了关于“MySQL为什么不推荐使用Docker部署”的深入分析。通过系统化的梳理,尼恩帮助读者理解为何大型MySQL数据库通常不使用Docker部署,主要涉及性能、管理复杂度和稳定性等方面的考量。文章详细解释了有状态容器的特点、Docker的资源隔离问题以及磁盘IO性能损耗,并提供了小型MySQL使用Docker的最佳实践。此外,尼恩还介绍了Share Nothing架构的优势及其应用场景,强调了配置管理和数据持久化的挑战。最后,尼恩建议读者参考《尼恩Java面试宝典PDF》以提升技术能力,更好地应对面试中的难题。
|
6天前
|
人工智能 文字识别 安全
Stirling-PDF:51.4K Star!用Docker部署私有PDF工作站,支持50多种PDF操作,从此告别在线工具
Stirling-PDF 是一款基于 Docker 的本地化 PDF 编辑工具,支持 50 多种 PDF 操作,包括合并、拆分、转换、压缩等,同时提供多语言支持和企业级功能,满足个人和企业用户的多样化需求。
54 6
Stirling-PDF:51.4K Star!用Docker部署私有PDF工作站,支持50多种PDF操作,从此告别在线工具
|
23天前
|
JavaScript 前端开发 Docker
如何通过pm2以cluster模式多进程部署next.js(包括docker下的部署)
通过这些步骤,可以确保您的Next.js应用在多核服务器上高效运行,并且在Docker环境中实现高效的容器化管理。
99 44
|
3天前
|
中间件 关系型数据库 数据库
docker快速部署OS web中间件 数据库 编程应用
通过Docker,可以轻松地部署操作系统、Web中间件、数据库和编程应用。本文详细介绍了使用Docker部署这些组件的基本步骤和命令,展示了如何通过Docker Compose编排多容器应用。希望本文能帮助开发者更高效地使用Docker进行应用部署和管理。
33 19
|
24天前
|
消息中间件 Linux 数据中心
Docker核心技术:Docker原理之Namespace
通过以上内容,您可以深入了解Docker中的Namespace机制及其在资源隔离中的应用,从而更好地理解和应用Docker技术。
68 25
|
1月前
|
监控 Java 应用服务中间件
tomcat相关概念与部署tomcat多实例-zabbix监控(docker部署)
通过上述步骤,您可以在Ubuntu系统上成功编译并安装OpenCV 4.8。这种方法不仅使您能够定制OpenCV的功能,还可以优化性能以满足特定需求。确保按照每一步进行操作,以避免常见的编译问题。
61 23
|
1月前
|
SQL Java Maven
docker部署apollo
docker部署apollo步骤
|
1月前
|
监控 Java 应用服务中间件
tomcat相关概念与部署tomcat多实例-zabbix监控(docker部署)
通过上述步骤,您可以在Ubuntu系统上成功编译并安装OpenCV 4.8。这种方法不仅使您能够定制OpenCV的功能,还可以优化性能以满足特定需求。确保按照每一步进行操作,以避免常见的编译问题。
53 22