Docker 容器化部署实践--入门

本文涉及的产品
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: Docker 容器化部署实践--入门

前面的文章给大家分享了「Python web开发从入门到放弃」其中提到了开发部署的事宜。由于有很多同学咨询,为了让大家更好的理解,所以打算把容器化部署作为一个系列来阐述,今天给大家简单讲下Docker入门使用,欢迎大家进行持续关注。

Docker是基于Go语言实现的开源容器项目,从2013年诞生就引起了业界广泛的关注,它是一种新的容器技术对比传统的LXC(Linux Container)技术。


Docker理念是实现「Build,Ship and Run Any App Anywhere」,达到类似JAVA「一次封装,处处运行」的目的。通过Docker我们可以为应用的开发,测试,部署,进行一站式处理。


作为现在云计算最火的技术,Docker拥有非常多的优点:

  1. 简单容易上手
  2. 解决运维环境和服务调度问题
  3. 低CPU内存资源占用
  4. 云计算核心技术
  5. 社区活跃

下面我们简单介绍一下Docker的安装使用


Docker安装


Docker目前只能运行在64位平台上,我记得当初团队两年前团队服务器用不了Docker估计就是这个原因。

安装我们可以手动安装或者脚本进行安装,这里我们使用脚本进行安装。

Ubuntu Linux安装:


sudo curl -sSL https://get.docker.com | sh  # 官方安装
sudo curl -sSL https://get.daocloud.io/docker | sh # 安装速度快,二选一
sudo service docker start

Mac OS安装就直接下载Docker for Mac就好了,这里就不进行演示了。

https://docs.docker.com/v17.12/docker-for-mac/install/

为了避免Docker命令每次都用root身份,可以将当前用户加入到组里面。

sudo usermod -aG docker USER_NAME


Docker的基本概念

安装好了,我们也是时候讲下基本概念了:

Docker镜像(image): 类似一个只读模板,镜像是创造Docker 容器(container)基础。

Docker容器(container): 是一个沙箱环境,这个环境就是mini的Linux系统,我们主要利用容器来运行隔离不同应用。

Docker仓库(repository):这个类似我们版本的代码仓库,如Github或Bitbucket,集中存放镜像文件的地方。

一个仓库往往放了多个镜像文件,主要通过标签(tag)来进行区分。为了速度和安全性我们往往都建立自己的镜像私有仓库。

仓库,标签这些操作,熟悉Git的同学可以看到Docker与之非常相似,上手起来非常容易。


Docker 常用命令

讲完概念,我们说一下Docker的常见命令。

docker pull ubuntu:16.04 # 拉群镜像冒号后面是标签tag,不指定默认latest,强烈建议加上
docker images  # 列出本地已经有的镜像,注意image id很重要
docker tag ubuntu:16.04 myubuntu:product # 给镜像添加新标签,类似链接作用
docker inspect myubuntu:product # 获取镜像详细信息
docker rmi myubuntu:product # 这里删除可以用image id
docker run ubuntu:16.04 /bin/bash -c "while true; do echo 1; sleep 1; done" # 启动容器 容器ID(dd06064bf6c0)
docker stop dd06064bf6c0  # 停止容器 dd06064bf6c0为容器ID
docker exec -it 292586a3883f bash # 进入容器
docker rm 292586a3883f 删除容器
docker ps -a # 查看所有容器


这里我们说一下创建新镜像:

docker run -it ubuntu:16.04 bash # 1. 启动镜像
root@42e296cc9587:/# touch 123.txt 
docker commit -m "add 123.txt" 42e296cc9587 ubuntu:test123
sha256:99db484eac429a6413977903653396c226dcc9917346417e4153ea322dc6a5d0
docker push hub.yourdomain.com/ubuntu:test123 # 推送镜像到仓库


我们可以看下效果

image.png

图片

命令其实有很多,比如docker import/save/laod这里面我就不过多说了,更多命令我们可以使用docker -h操作,常用命令介绍我们就讲到这儿。

容器化部署实践,我打算从基础操作到实战应用以一个系列进行分享,今天是第一篇入门,后期我将持续分享更多相关内容,从容器化入门使用到部署实践编排技术,欢迎大家持续进行关注。


相关文章
|
6天前
|
弹性计算 运维 持续交付
探索Docker容器化技术及其在生产环境中的应用
探索Docker容器化技术及其在生产环境中的应用
36 5
|
3天前
|
容器 云栖大会
|
8天前
|
人工智能 API 数据库
FastGPT一站式解决方案[1-部署篇]:轻松实现RAG-智能问答系统(含sealos云端部署、docker部署、OneAPI&Xinference模型接入)
【9月更文挑战第5天】 FastGPT一站式解决方案[1-部署篇]:轻松实现RAG-智能问答系统(含sealos云端部署、docker部署、OneAPI&Xinference模型接入)
 FastGPT一站式解决方案[1-部署篇]:轻松实现RAG-智能问答系统(含sealos云端部署、docker部署、OneAPI&Xinference模型接入)
|
4天前
|
Kubernetes Cloud Native 开发者
云原生入门:从Docker到Kubernetes的旅程
【9月更文挑战第16天】 本文将带你进入云原生的世界,从理解Docker容器的基础开始,逐步深入到Kubernetes集群管理。我们将通过简单的代码示例和实际操作,探索这两个关键技术如何协同工作,以实现更高效、灵活的应用程序部署和管理。无论你是云原生新手还是希望深化理解,这篇文章都将为你提供清晰的指导和实用的知识。
30 11
|
2天前
|
运维 Ubuntu Linux
深入理解并实践Docker容器化技术
深入理解并实践Docker容器化技术
21 6
|
7天前
|
运维 Docker 微服务
掌握 Docker Compose:简化你的多容器应用部署
在微服务架构和容器化技术普及的今天,管理多容器部署变得颇具挑战。Docker Compose 通过一个 YAML 文件定义和运行多容器应用,简化了部署和运维。本文介绍其基本概念、使用方法及优势,包括服务、项目、卷和网络等核心概念,并提供从安装到管理服务的详细步骤,助你轻松掌握 Docker Compose,提高开发效率和应用运维质量。
|
9天前
|
缓存 Java 应用服务中间件
OpenResty 简介及其容器化实践
【9月更文挑战第2天】OpenResty 是一个基于 Nginx 与 Lua 的高性能 web 平台,它扩展了 Nginx 的功能,使之能够处理更加复杂的业务逻辑。通过集成 Lua 脚本,OpenResty 可以实现高效的请求处理、缓存、负载均衡等功能。
30 8
|
6天前
|
Devops jenkins 持续交付
DevOps实践:构建和部署一个Docker化的应用
【9月更文挑战第14天】在当今快节奏的软件开发领域,DevOps已经成为提升效率、加速交付的关键。本文将引导你理解DevOps的核心概念,并通过一个实际的示例—构建和部署一个Docker化的应用—来深入探讨其实践方法。我们将从简单的应用出发,逐步实现Docker容器化,并最终通过CI/CD流水线自动化部署过程。这不仅是对DevOps流程的一次实操演练,也是对现代软件开发理念的一次深刻体验。
|
5天前
|
Prometheus 监控 Cloud Native
docker安装prometheus+Granfan并监控容器
【9月更文挑战第14天】本文介绍了在Docker中安装Prometheus与Grafana并监控容器的步骤,包括创建配置文件、运行Prometheus与Grafana容器,以及在Grafana中配置数据源和创建监控仪表盘,展示了如何通过Prometheus抓取数据并利用Grafana展示容器的CPU使用率等关键指标。
|
6天前
|
Cloud Native 持续交付 Docker
探索容器化技术Docker的奥秘
探索容器化技术Docker的奥秘
23 3

相关产品

  • 容器服务Kubernetes版