冬季实战营第四期:零基础容器技术实战

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 第三期主要进行了5次实验,分别是:《阿里云容器服务Kubernetes版快速入门》、《Docker镜像管理快速入门》、《Chaos带你快速上手混沌工程》、《使用阿里云容器服务和容器网络文件系统搭建WordPress网站》、《基于PTS&AHAS完成线上应用最佳状态》。

一、导语

第三期主要进行了5次实验,分别是:《阿里云容器服务Kubernetes版快速入门》、《Docker镜像管理快速入门》、《Chaos带你快速上手混沌工程》、《使用阿里云容器服务和容器网络文件系统搭建WordPress网站》、《基于PTS&AHAS完成线上应用最佳状态》。

二、阿里云容器服务Kubernetes版快速入门

1. 部署并公开应用

1)访问容器服务管理控制台。

https://cs.console.aliyun.com/

a.在集群列表页面中,单击目标集群名称

image.png

b.在集群管理页左侧导航栏中,选择工作负载>无状态

image.png

c.在无状态页面中,单击使用镜像创建

image.png

d.在应用基本信息页签,设置应用名称,例如ack-cube,单击下一步

image.png

e.在容器配置页签,依次设置镜像名称镜像Tag资源限制所需资源端口,单击下一步

参数说明:

  • 镜像名称:输入registry.cn-hangzhou.aliyuncs.com/acr-toolkit/ack-cube
  • 镜像Tag:单击选择镜像Tag选择镜像的版本。若不指定,默认为最新版。示例:1.0。
  • 资源限制:设置CPU为1 Core,内存为1024 MiB。
  • 所需资源:设置CPU为0.25 Core,内存为512 MiB。
  • 端口:设置容器的端口,输入名称ack-cube,容器端口80

image.png

f.在高级配置页签,单击服务(Service)右侧的创建

image.png

g.在创建服务对话框中,设置服务的相关参数,单击创建,以通过该服务公开应用。

参数说明:

  • 名称:输入服务的名称。示例:ack-cube-svc。
  • 类型选择负载均衡>公网访问>新建SLB
  • 服务端口设置服务端口为80
  • 容器端口:设置服务端口为80

image.png

h.在高级配置页签,单击页面右下角的创建

image.png

返回如下页面,表示应用创建成功,单击查看应用详情

image.png

i.在应用详情页面,可以查看应用的容器组、访问方式、事件、容器伸缩、历史版本、日志和触发器等信息。

image.png

2) 测试应用

a.切换回容器服务管理控制台页签。在左侧导航栏中,选择网络>服务

b.在服务列表页面,找到新创建的服务(即ack-cube-svc),记录外部端点列的IP地址。

image.png

c.打开本机的浏览器,在地址栏中输入并访问外部端点列的IP地址,即可体验魔方游戏。


3) 监控应用

a.切换回容器服务管理控制台页签。在左侧导航栏中,选择运维管理>Prometheus监控

b.在Prometheus监控页面,单击无状态应用监控

image.png

c.在无状态应用监控页签,选择namespacedefault,选择deployment为ack-cube

可以查看应用的资源使用情况,包括创建应用时所设置的资源阈值,所需资源(对应图中request)和资源限制(对应图中limit)。

image.png

d.在无状态应用监控页签,单击右侧图标>集群Pod监控

image.png

e.在集群Pod监控页签,选择namespace为default,选择Pod为待监控的Pod,可以查看单个Pod的资源使用情况。

三、Docker镜像管理快速入门

1. 搭建Docker服务

Docker 是一个开源的容器引擎,用于创建、管理和编排容器,可以轻松为任何应用创建一个轻量级、可移植、自给自足的容器。本步骤将在ECS上部署一个Docker服务,并配置DockerHub的镜像加速器。

1) 在控制台输入以下命令,安装Docker的依赖库。

yum install -y yum-utils device-mapper-persistent-data lvm2

2) 添加Docker CE的软件源信息。

yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

3)安装Docker CE。

yum makecache fast && yum -y install docker-ce

4)启动Docker服务。

systemctl start docker

5 配置DockerHub镜像加速器。

tee /etc/docker/daemon.json <<-'EOF' {   "registry-mirrors": ["https://registry.docker-cn.com"] } EOF

6)重启Docker服务。

systemctl restart docker

2. 准备应用代码和Dockerfile

本步骤操作将在工作空间下创建一个基于Golang的HelloWorld代码文件和一个用来构建运行Hello代码所需环境镜像的Dockerfile文件

1 创建工作空间。

mkdir -p /tmp/demo && cd /tmp/demo

2 在工作空间下创建HelloWorld代码文件,用来在容器环境中监听HTTP服务,输出HelloWorld字符串。

cat > /tmp/demo/main.go << EOF package main import (         "fmt"         "net/http" ) func main() {         http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {                 fmt.Fprintf(w, "Hello! World\n")         })         fmt.Println("start to serve...")         http.ListenAndServe(":80", nil) } EOF

3在工作空间下创建Dockerfile文件。

cat > /tmp/demo/Dockerfile << EOF FROM golang:1.12-alpine # change current working dir WORKDIR /go/src/app # copy main.go into /go/src/app COPY . . # go build and install the app RUN go install -v ./... # run the app by default CMD ["app"] EOF

3. 本地构建镜像并运行镜像

本步骤将指导您使用Docker基本命令构建和运行镜

1 使用docker build命令构建镜像。

docker build . -t demo:v1

说明:

  • 参数.表示指定当前路径作为构建上下文,即Dockerfile所在的本地路径。
  • 参数-t demo:v1指定镜像名称和标签。

2使用docker run命令运行镜像。

docker run -d -p 8000:80 demo:v1

说明:

  • 参数-d设置容器运行模式为后台运行。
  • 参数-p 8000:80将容器内部使用的网络端口映射到主机上,其中8000为主机端口,80为容器内部使用端口。

3)使用curl工具访问容器中的HelloWorld服务。

curl localhost:8000

4) 使用docker rm命令删除容器。

docker rm -f $(docker ps -a | grep "demo:v1" | awk '{print $1}')

4. 创建远程镜像仓库

可以使用自己的阿里云账号开通容器镜像服务并创建镜像仓库。阿里云容器镜像服务默认实例版可免费使用。

1. 使用自己的阿里云主账号登录容器镜像服务控制台

2. 单击【前往开通】。

3. 单击【设置Registry登录密码】 。

4. 设置阿里云Docker Registry登录密码,然后单击 【确定】 。

5. 在容器镜像服务控制台,依次单击 【个人实例】 > 【命名空间】 > 【创建命名空间】,在 【创建命名空间】 弹框中填写命令空间名称,然后单击 【确定】 。

6. 选择 【镜像仓库】 > 【创建镜像仓库】,在 【创建镜像仓库】 弹框中选择 【命名空间】 ,填写 仓库名称 和 摘要 ,然后单击 【下一步】 。

7. 单击 【本地仓库】 > 【创建镜像仓库】 。

8. 在镜像仓库列表,选择上一步创建的镜像仓库,单击 【管理】 ,查看镜像仓库详情。

5. 推送镜像

本步骤操作将本地镜像推送到远程仓库中,并运行远程仓库中的指定版本镜像。将本步骤命令中涉及的远程镜像地址替换为步骤五中创建的镜像仓库的公网地址。

1.执行以下命令登录到阿里云Docker Registry。

docker login --username="用户名" registry.cn-hangzhou.aliyuncs.com

说明: 将下面命令中的用户名替换为自己的阿里云账号全名,回车后输入远程镜像仓库密码,密码为步骤六开通服务时设置的密码。

可以登录阿里云用户中心查看自己的主账号用户名称。

2标记本地镜像,将其归入远程仓库。

docker tag demo:v1 registry.cn-hangzhou.aliyuncs.com/space_test/demo:v1

3 将本地镜像推送到远程仓库。

docker push registry.cn-hangzhou.aliyuncs.com/space_test/demo:v1

4拉取指定版本的远程镜像。

docker pull registry.cn-hangzhou.aliyuncs.com/space_test/demo:v1

5 运行拉取的远程镜像。

docker run -d -p 8000:80 registry.cn-hangzhou.aliyuncs.com/space_test/demo:v1

6 访问HelloWorld服务。

curl localhost:8000





相关实践学习
通过workbench远程登录ECS,快速搭建Docker环境
本教程指导用户体验通过workbench远程登录ECS,完成搭建Docker环境的快速搭建,并使用Docker部署一个Nginx服务。
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。 &nbsp; &nbsp; 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
目录
相关文章
|
16小时前
|
运维 Kubernetes Devops
构建高效稳定的云基础设施:DevOps与容器技术的融合
【5月更文挑战第14天】 在当今快速发展的云计算时代,企业和组织面临着不断变化的市场需求和技术挑战。为了保持竞争力,越来越多的企业转向DevOps实践和容器技术来构建高效、灵活且稳定的云基础设施。本文将探讨如何通过整合DevOps文化和容器化技术,实现自动化运维流程,提高部署速度,减少系统故障,并确保可扩展性和高可用性。我们将分析实际案例,展示这种融合如何在现实世界中为企业带来显著的业务价值。
3 0
|
1天前
|
运维 Kubernetes 持续交付
构建高效自动化运维体系:基于容器技术的持续集成与部署实践
【5月更文挑战第13天】 在现代软件开发周期中,持续集成(CI)和持续部署(CD)已成为提升开发效率、保障产品质量的关键环节。随着云计算和微服务架构的普及,容器技术如Docker和Kubernetes为运维领域带来了革命性的变革。本文旨在探讨如何利用容器技术构建一个高效、可靠的自动化运维体系,实现从代码提交到产品发布的全过程自动化管理。通过深入分析容器化技术的核心原理,结合实际案例,我们将阐述如何优化持续集成流程、确保自动化测试的覆盖率、以及实现无缝的持续部署。
14 2
|
2天前
|
运维 Kubernetes 测试技术
容器技术:优化软件测试流程的利器
本文介绍了容器技术的概念、优势和历史发展,对比了容器与虚拟机的区别,并提及了Docker和Kubernetes等常见容器技术。容器作为轻量级虚拟化工具,提供高效、灵活的应用部署方式,广泛应用于软件开发、云计算和微服务架构。随着技术演进,容器将在边缘计算、人工智能等领域发挥更大作用,推动行业变革。
12 3
|
2天前
|
运维 Kubernetes Devops
构建高效稳定的云基础设施:DevOps与容器技术的结合
【5月更文挑战第12天】 在当今快速发展的信息技术时代,企业需要灵活、快速地响应市场变化并持续交付高质量的软件产品。本文将探讨如何通过结合DevOps文化和容器技术来构建一个高效且稳定的云基础设施。我们将讨论DevOps的核心概念及其如何加速开发周期,以及容器技术如Docker和Kubernetes如何提供一致性、可移植性和扩展性。最后,文章将介绍实际案例,展示这种结合如何在现代运维实践中实现自动化部署、持续集成和微服务架构管理。
|
6天前
|
Kubernetes Java 调度
Java容器技术:Docker与Kubernetes
Java容器技术:Docker与Kubernetes
17 0
|
6天前
|
存储 缓存 监控
【Docker 专栏】Docker 容器性能调优实战
【5月更文挑战第8天】本文探讨了Docker容器的性能调优技巧,包括理解容器性能指标(如CPU、内存、网络和磁盘I/O)并进行相应调优。重点讲述了CPU和内存的限制设置,网络配置优化以及磁盘I/O性能提升方法。通过实例展示了如何解决高CPU使用率问题,强调了根据应用需求进行调优的重要性,以实现更高效、稳定的容器运行。
【Docker 专栏】Docker 容器性能调优实战
|
7天前
|
前端开发 API 数据库
【Docker专栏】Docker Compose实战:编排多容器应用
【5月更文挑战第7天】Docker Compose是Docker的多容器管理工具,通过YAML文件简化多容器应用部署。它能一键启动、停止服务,保证开发、测试和生产环境的一致性。安装后,创建`docker-compose.yml`文件定义服务,如示例中的web和db服务。使用`docker-compose up -d`启动服务,通过`docker-compose ps`、`stop`、`down`和`logs`命令管理服务。
【Docker专栏】Docker Compose实战:编排多容器应用
|
7天前
|
运维 Linux Docker
Docker详解(十一)——Docker容器CPU资源限额实战Docker详解
Docker详解(十一)——Docker容器CPU资源限额实战
26 5
|
14天前
|
敏捷开发 运维 测试技术
构建高效自动化运维体系:基于容器技术的持续集成与持续部署实践
【4月更文挑战第30天】在数字化转型的浪潮中,企业对软件交付速度和质量的要求日益提高。自动化运维作为提升效率、确保稳定性的关键手段,其重要性不言而喻。本文将探讨如何利用容器技术构建一个高效的自动化运维体系,实现从代码提交到产品上线的持续集成(CI)与持续部署(CD)。通过分析现代容器技术与传统虚拟化的差异,阐述容器化带来的轻量化、快速部署及易于管理的优势,并结合实例讲解如何在实际环境中搭建起一套完善的CI/CD流程。
|
14天前
|
Linux 开发者 Docker
Docker容器化技术详解
【4月更文挑战第30天】Docker,一个开源的容器化平台,助力开发者通过轻量级容器打包应用及依赖,实现跨平台快速部署。核心概念包括:容器(可执行的软件包)、镜像(只读模板)、Dockerfile(构建镜像的指令文件)和仓库(存储镜像的地方)。Docker利用Linux内核功能隔离容器,采用联合文件系统构建镜像。广泛应用包括开发测试一致性、微服务部署、CI/CD以及本地到远程部署。通过安装Docker,编写Dockerfile,构建&运行容器,可实现高效灵活的应用管理。随着容器技术进步,Docker在云计算和DevOps中的角色日益重要。