无限套娃_docker入门(镜像、容器、仓库)

简介: 无限套娃_docker入门(镜像、容器、仓库)

Docker

基于go语言、遵从Apache协议、操作系统虚拟化、复用本地主机的操作系统(区别于过往的硬件层面实现)

image镜像

梦中梦

镜像可容纳操作系统(系统里面包括Apache和程序),操作系统又可以安装Docker,无限循环套娃…想起盗梦空间的梦中梦

可以通过查看Docker安装的镜像辨别我是在第几层(id、tag)

查看镜像层数

查看image命令

docker image ls

载入镜像层

ok进入镜像

sudo docker run -t -i ubuntu:12.04 /bin/bash

其中image的id很重要,我理解为唯一标识符

我进入的id是ac565b40b68c

跳出镜像

如何处理呢,难道像盗梦中跳楼才能出来吗?

没错,只要我跳的够快,就能跳出镜像…

命令exit,快捷键ctrl+d

exit

添加评论到相应的镜像id

添加评论成功返回id

sudo docker commit -m "我好像做了个梦" ac565b40b68c ouruser/sinatra:v2  

再次进入镜像内的容器(程序)

docker run -t -i

sudo docker run -t -i ouruser/sinatra:v2 /bin/bash

container容器

依赖于镜像环境,是镜像创建运行的实例

容器间相互分离(启动、开始、停止、删除)

类似进程(创建、就绪、运行、阻塞、死亡)

进入容器

查看运行的容器

docker ps

attach命令

进入正在运行的docker的names

docker run -idt ubuntu:12.04

导入导出容器

export导出

先查看运行的容器实例

然后导出对应的容器(使用id)

sudo docker export e379e4c23b8c > yma16.tar

import导入

docker import - repository:tag
cat yma16.tar | docker import - test/ubuntu:v1.0

docker rm删除容器

启动容器

docker run

sudo docker run ubuntu:12.04

docker start可以启动已经终止的容器

守护态运行容器

守护态(Daemonized)

sudo docker run -d 

终止容器

docker stop

通过端口终止

sudo docker stop e470f1cd84fa

reposito仓库

主要存放镜像,服务器管理仓库的具体服务器,一个服务器有多个仓库,一个厂库有多个镜像

Hub

官方的Hub

有多个镜像

无需登录就可以查询镜像并下载

docker search

docker search centos

docker pull

下载镜像

sudo docker pull centos

docker push

注册登录账号后上传镜像

私有仓库

docker-registry工具创建私有的镜像厂库

安装运行docker-regitry

ubuntu:

$ sudo apt-get install -y build-essential python-dev libevent-dev python-pip liblzma-dev
$ sudo pip install docker-registry

Centos:

$ sudo yum install -y python-devel libevent-devel python-pip gcc xz-devel
$ sudo python-pip install docker-registry

clone仓库文件进行安装

$ sudo apt-get install build-essential python-dev libevent-dev python-pip libssl-dev liblzma-dev libffi-dev
$ git clone https://github.com/docker/docker-registry.git
$ cd docker-registry
$ sudo python setup.py install

修改配置文件到本地仓库路径
cp config/config_sample.yml config/config.yml

启动 Web 服务
sudo gunicorn -c contrib/gunicorn.py docker_registry.wsgi:application
docker tag 来标记一个镜像

sudo docker tag id 自定义tag

sudo docker tag 380443e9701e 192.168.100.91:5000/yma16_file

修改成功

docker push 上传标记的镜像
sudo docker push 192.168.100.91:22/yma16_file

curl 查看仓库中的镜像
curl http://192.168.100.91:5000/v1/search

我的web服务没有打开

配置文件

利用Docker 中 Registry 的模板(flavor)

config_sample.yml文件

  • common:基础配置
  • local:存储数据到本地文件系统
  • s3:存储数据到 AWS S3 中
  • dev:使用 local 模板的基本配置
  • test:单元测试使用
  • prod:生产环境配置(基本上跟s3配置类似)
  • gcs:存储数据到 Google 的云存储
  • swift:存储数据到 OpenStack Swift 服务
  • glance:存储数据到 OpenStack Glance 服务,本地文件系统为后备
  • glance-swift:存储数据到 OpenStack Glance 服务,Swift 为后备
  • elliptics:存储数据到 Elliptics key/value 存储

1024, 致敬这世界的程序员,respect!


目录
相关文章
|
3月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
594 5
|
3月前
|
监控 Linux 调度
【赵渝强老师】Docker容器的资源管理机制
本文介绍了Linux CGroup技术及其在Docker资源管理中的应用。通过实例演示了如何利用CGroup限制应用程序的CPU、内存和I/O带宽使用,实现系统资源的精细化控制,帮助理解Docker底层资源限制机制。
400 6
|
3月前
|
XML Java 应用服务中间件
【SpringBoot(一)】Spring的认知、容器功能讲解与自动装配原理的入门,带你熟悉Springboot中基本的注解使用
SpringBoot专栏开篇第一章,讲述认识SpringBoot、Bean容器功能的讲解、自动装配原理的入门,还有其他常用的Springboot注解!如果想要了解SpringBoot,那么就进来看看吧!
524 2
|
5月前
|
Kubernetes Docker Python
Docker 与 Kubernetes 容器化部署核心技术及企业级应用实践全方案解析
本文详解Docker与Kubernetes容器化技术,涵盖概念原理、环境搭建、镜像构建、应用部署及监控扩展,助你掌握企业级容器化方案,提升应用开发与运维效率。
961 108
|
6月前
|
存储 监控 测试技术
如何将现有的应用程序迁移到Docker容器中?
如何将现有的应用程序迁移到Docker容器中?
521 57
|
3月前
|
监控 Kubernetes 安全
还没搞懂Docker? Docker容器技术实战指南 ! 从入门到企业级应用 !
蒋星熠Jaxonic,技术探索者,以代码为笔,在二进制星河中书写极客诗篇。专注Docker与容器化实践,分享从入门到企业级应用的深度经验,助力开发者乘风破浪,驶向云原生新世界。
还没搞懂Docker? Docker容器技术实战指南 ! 从入门到企业级应用 !
|
6月前
|
存储 监控 Java
如何对迁移到Docker容器中的应用进行性能优化?
如何对迁移到Docker容器中的应用进行性能优化?
466 59

热门文章

最新文章