云原生系列 【轻松入门容器基础操作】

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: ​​***本文正在参加[「金石计划 . 瓜分6万现金大奖」](https://juejin.cn/post/7162096952883019783 "https://juejin.cn/post/7162096952883019783")***### **✅作者简介:**### **CSDN内容合伙人,全栈领域新星创作者,阿里云专家博主,华为云云 享专家博主,掘金后端评审团成员**### **💕前言:**### 最近云原生领域热火朝天,那么云原生是什么?何为云原生?云原生用来干什么的?今天学长通过华为的沙箱实验操作带领大家走进“云”时代~~**目录**[2.1 运行一个h

✅作者简介:

CSDN内容合伙人,全栈领域新星创作者,阿里云专家博主,华为云云 享专家博主,掘金后端评审团成员

💕前言:

最近云原生领域热火朝天,那么云原生是什么?何为云原生?云原生用来干什么的?今天学长通过华为的沙箱实验操作带领大家走进“云”时代~~

目录

2.1 运行一个httpd容器

2.2 查看容器信息

2.3 通过浏览器访问httpd容器Web服务页面。

2.4 停止容器

2.5 启动容器

2.6 删除容器

3. 容器镜像实操收起

3.1 Docker commit构建容器镜像

3.2 退出当前容器,删除本节实验所涉及到的容器

3.3 Dockerfile构建容器镜像

3.4 删除本节实验所涉及到的容器

3.5 搭建私有镜像仓库注册表

2.1 运行一个httpd容器

键入如下命令,运行httpd容器:

                                docker run -d -p 80:80 httpd
                            

运行结束后,显示未找到“httpd”镜像,下载镜像并创建“826cdd......”镜像。

img

2.2 查看容器信息

键入如下命令,查看容器信息:

                                docker container ls
                            

img

上图标红框的为该容器的容器ID。

键入如下命令,查看容器镜像信息:

                                docker image ls
                            

img

2.3 通过浏览器访问httpd容器Web服务页面。

在浏览器内输入 http:// 弹性云主机弹性公网IP地址:80。

img

2.4 停止容器

键入如下命令,停止httpd容器:

注意:请使用步骤2.2中的CONTAINER ID替换命令中的【容器ID】。

                                docker stop 容器ID
                            

刷新2.3中打开的Web服务页面,结果如下,可见已经无法正常访问。

img

2.5 启动容器

键入如下命令,启动httpd容器:

注意:请使用2.2中的CONTAINER ID替换命令中的【容器ID】。

                                docker start 容器ID
                            

刷新2.3中打开的Web服务页面,结果如下,可见已经恢复正常访问。

img

2.6 删除容器

删除容器前必须停止容器,键入如下命令,停止并删除httpd容器:

注意:请使用2.2中的容器ID替换命令中的【容器ID】。

                                docker stop 容器ID
                            
                                docker rm 容器ID
  1. 容器镜像实操收起

3.1 Docker commit构建容器镜像

(1)拉取centos7镜像:

                                docker pull centos:centos7
                            

运行 centos容器

                                docker run -t -d centos:centos7
                            

(2)进入该容器并验证vim可用性:

                                docker container ls
                            

注意:此处通过docker exec 命令进入容器,其具体使用后续章节将会涉及。使用上一行命令查询到的centos容器ID替换【容器ID】。

                                docker exec -it 容器ID bash
                            
                                vim
                            

img

(3)在容器内下载安装vim:

                                yum install -y vim
                            

注意:若出现无法下载存储库“AppStream”的元数据:无法准备内部镜像列表:镜像列表中没有 URL。请在容器内输入以下命令更换yum源,再重新安装vim。

                                cd /etc/yum.repos.d/
                            
                                sed -i 's/mirrorlist/#mirrorlist/g' /etc/yum.repos.d/CentOS-*
sed -i 's|#baseurl=http://mirror.centos.org|baseurl=http://vault.centos.org|g' /etc/yum.repos.d/CentOS-*
                            
                                yum update -y
                            
                                yum install -y vim
                            

等待安装完毕以后,再次验证vim可用性如下图所示:

                                vim --version
                            

img

④退出容器,将当前容器构建为新镜像。

                                exit
                            

注意:请使用第(2)步中查询到的centos容器ID替换命令中的【容器ID】

                                docker commit 容器ID centos-vim
                            
                                docker image ls
                            

img

说明:通过对比centos容器镜像可以发现,centos-vim容器镜像大小发生改变。 (5)删除前一个容器,并利用centos-vim镜像运行一个新容器:

                                docker container ls
                            

注意:请使用上一行命令回显的容器ID替换后续命令中的【容器ID】

                                docker stop 容器ID
                            
                                docker rm 容器ID
                            
                                docker run -d -t centos-vim
                            

img

(6)验证新容器内vim可用性:

                                docker container ls
                            

注意:请使用上一行命令查询到的容器ID替换后续命令中的【容器ID】

                                docker exec -it 容器ID bash
                            
                                vim --help
                            

img

3.2 退出当前容器,删除本节实验所涉及到的容器

退出当前容器。

                                exit
                            

查询容器ID,停止并删除。

                                docker container ls
                            
                                docker stop 容器ID
                            
                                docker rm 容器ID
                            

img

3.3 Dockerfile构建容器镜像

(1)创建Dockerfile文件在/root路径下创建一个Dockerfile文件

                                touch dockerfile
                            

(2)使用vim编辑Dockerfile文件:

                                vim dockerfile
                            

输入i,将以下代码写入Dockerfile文件中,键入wq保存退出:

                                FROM centos:centos7
MAINTAINER Iris@huawei.com
ENV HOSTNAME webserver
EXPOSE 80
RUN yum install -y httpd vi && yum clean all
VOLUME ["/var/www/html"]
CMD ["/usr/sbin/httpd","-D","FOREGROUND"]
                            

(3)使用docker build命令构建容器镜像:

                                docker build -t httpd-centos -f dockerfile /root
                            

img

④查看镜像列表,并利用新镜像运行容器。

                                docker image ls
                            
                                docker run -d -p 80:80 httpd-centos
                            

img

(5)验证该容器Web服务页面: 在个人操作终端浏览器内输入 http://EIP:80

注意:服务器的公网IP替换网址中的【EIP】。

img

3.4 删除本节实验所涉及到的容器

查询容器ID,停止并删除。

                                docker container ls
                            
                                docker stop 容器ID
                            
                                docker rm 容器ID
                            

img

3.5 搭建私有镜像仓库注册表

(1)运行私有镜像仓库注册表容器:

                                docker run -d -p 5000:5000 registry
                            

img

说明:私有镜像仓库服务监听端口为5000,此处利用-p 5000:5000将容器5000端口映射到主机5000端口。

(2)利用docker tag命令修改镜像名称:

                                docker tag httpd-centos localhost:5000/http:V1
                            

③将本地镜像上传至私有镜像仓库:

                                docker push localhost:5000/http:V1
                            

img

(4)查看私有镜像仓库registry中镜像信息。 列出所有的本地注册表仓库的镜像:

                                curl -X GET http://localhost:5000/v2/_catalog
                            
                                curl -X GET http://localhost:5000/v2/http/tags/list
                            

img

⑤删除本地容器镜像,并从私有镜像仓库下载:

注意:删除镜像前需要先删除对应容器,否则会删除失败。

                                docker rmi localhost:5000/http:V1
                            
                                docker rmi httpd-centos
                            
                                docker pull localhost:5000/http:V1
                            

img

本期分享到此为止,关注学长不迷路,叶秋带你上高速~~

相关实践学习
通过容器镜像仓库与容器服务快速部署spring-hello应用
本教程主要讲述如何将本地Java代码程序上传并在云端以容器化的构建、传输和运行。
Kubernetes极速入门
Kubernetes(K8S)是Google在2014年发布的一个开源项目,用于自动化容器化应用程序的部署、扩展和管理。Kubernetes通常结合docker容器工作,并且整合多个运行着docker容器的主机集群。 本课程从Kubernetes的简介、功能、架构,集群的概念、工具及部署等各个方面进行了详细的讲解及展示,通过对本课程的学习,可以对Kubernetes有一个较为全面的认识,并初步掌握Kubernetes相关的安装部署及使用技巧。本课程由黑马程序员提供。   相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
1月前
|
Kubernetes Cloud Native 微服务
探索云原生技术:容器化与微服务架构的融合之旅
本文将带领读者深入了解云原生技术的核心概念,特别是容器化和微服务架构如何相辅相成,共同构建现代软件系统。我们将通过实际代码示例,探讨如何在云平台上部署和管理微服务,以及如何使用容器编排工具来自动化这一过程。文章旨在为开发者和技术决策者提供实用的指导,帮助他们在云原生时代中更好地设计、部署和维护应用。
|
28天前
|
存储 Kubernetes 开发者
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
Docker 是一种开源的应用容器引擎,允许开发者将应用程序及其依赖打包成可移植的镜像,并在任何支持 Docker 的平台上运行。其核心概念包括镜像、容器和仓库。镜像是只读的文件系统,容器是镜像的运行实例,仓库用于存储和分发镜像。Kubernetes(k8s)则是容器集群管理系统,提供自动化部署、扩展和维护等功能,支持服务发现、负载均衡、自动伸缩等特性。两者结合使用,可以实现高效的容器化应用管理和运维。Docker 主要用于单主机上的容器管理,而 Kubernetes 则专注于跨多主机的容器编排与调度。尽管 k8s 逐渐减少了对 Docker 作为容器运行时的支持,但 Doc
134 5
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
|
20天前
|
存储 人工智能 调度
容器服务:智算时代云原生操作系统及月之暗面Kimi、深势科技实践分享
容器技术已经发展成为云计算操作系统的关键组成部分,向下高效调度多样化异构算力,向上提供统一编程接口,支持多样化工作负载。阿里云容器服务在2024年巴黎奥运会中提供了稳定高效的云上支持,实现了子弹时间特效等创新应用。此外,容器技术还带来了弹性、普惠的计算能力升级,如每分钟创建1万Pod和秒级CPU资源热变配,以及针对大数据与AI应用的弹性临时盘和跨可用区云盘等高性能存储解决方案。智能运维方面,推出了即时弹性节点池、智能应用弹性策略和可信赖集群托管运维等功能,进一步简化了集群管理和优化了资源利用率。
|
18天前
|
监控 安全 Cloud Native
阿里云容器服务&云安全中心团队荣获信通院“云原生安全标杆案例”奖
2024年12月24日,阿里云容器服务团队与云安全中心团队获得中国信息通信研究院「云原生安全标杆案例」奖。
|
1月前
|
供应链 安全 Cloud Native
阿里云容器服务助力企业构建云原生软件供应链安全
本文基于2024云栖大会演讲,探讨了软件供应链攻击的快速增长趋势及对企业安全的挑战。文中介绍了如何利用阿里云容器服务ACK、ACR和ASM构建云原生软件供应链安全,涵盖容器镜像的可信生产、管理和分发,以及服务网格ASM实现应用无感的零信任安全,确保企业在软件开发和部署过程中的安全性。
|
1月前
|
人工智能 Kubernetes Cloud Native
阿里云容器服务,智算时代云原生操作系统
2024云栖大会,阿里巴巴研究员易立分享了阿里云容器服务的最新进展。容器技术已成为云原生操作系统的基石,支持多样化的应用场景,如自动驾驶、AI训练等。阿里云容器服务覆盖公共云、边缘云、IDC,提供统一的基础设施,助力客户实现数字化转型和技术创新。今年,阿里云在弹性计算、网络优化、存储解决方案等方面进行了多项重要升级,进一步提升了性能和可靠性。
|
1月前
|
Kubernetes Cloud Native API
云原生入门:从理论到实践的探索之旅
本文旨在为初学者提供一个关于云原生技术的全面介绍,包括其定义、核心原则、关键技术组件以及如何将这些概念应用于实际项目中。我们将通过一个简易的代码示例,展示如何在云原生环境下部署一个简单的应用,从而帮助读者更好地理解云原生技术的实践意义和应用价值。
|
1月前
|
Kubernetes Cloud Native Docker
云原生之旅:从容器化到微服务
本文将带领读者踏上云原生的旅程,深入探讨容器化和微服务架构的概念、优势以及它们如何共同推动现代软件的发展。我们将通过实际代码示例,展示如何在Kubernetes集群上部署一个简单的微服务应用,并解释相关的配置和操作。无论你是云原生新手还是希望深化理解,这篇文章都将为你提供有价值的见解和实操指南。
|
1月前
|
运维 Cloud Native 开发者
云原生技术入门与实践
在云计算的浪潮中,云原生技术以其独特的优势和魅力吸引了越来越多的开发者和企业。本文将从云原生技术的基本概念、核心组件以及实际应用三个方面进行详细介绍,帮助读者更好地理解和掌握这一新兴技术。同时,文章还将分享一些实际案例和经验教训,让读者能够更深入地了解云原生技术的应用场景和发展趋势。
56 5
|
2月前
|
Kubernetes Cloud Native 开发者
云原生入门:从容器到微服务
本文将带你走进云原生的世界,从容器技术开始,逐步深入到微服务架构。我们将通过实际代码示例,展示如何利用云原生技术构建和部署应用。无论你是初学者还是有经验的开发者,这篇文章都将为你提供有价值的信息和启示。