无限套娃_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!


目录
相关文章
|
7月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
797 6
|
7月前
|
监控 Linux 调度
【赵渝强老师】Docker容器的资源管理机制
本文介绍了Linux CGroup技术及其在Docker资源管理中的应用。通过实例演示了如何利用CGroup限制应用程序的CPU、内存和I/O带宽使用,实现系统资源的精细化控制,帮助理解Docker底层资源限制机制。
705 6
|
Ubuntu Linux Docker
Docker 入门全攻略:安装、操作与常用命令指南
Docker 的世界非常广阔,这只是一个开始,请继续探索和学习 Docker 的高级特性和最佳实践。后续也会继续更新相关的理论与实践内容。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
Oracle 关系型数据库 Linux
Docker入门和安装
这篇文章提供了Docker的入门指南和在CentOS系统上安装Docker的详细步骤。
199 0
Docker入门和安装
|
Docker 索引 容器
Docker从入门到精通——安装Docker
Docker从入门到精通——安装Docker
219 0
|
关系型数据库 MySQL 应用服务中间件
Docker 从入门,安装、配置、及部署
Docker 从入门,安装、配置、及部署
412 1
|
存储 Cloud Native 关系型数据库
【云原生 · Docker】入门篇:安装、镜像加速
【云原生 · Docker】入门篇:安装、镜像加速
1127 0
|
运维 Ubuntu NoSQL
Docker(一)入门:Docker的入门与安装
我们发布一个项目,可能需要Redis、Mysql、Node.js的环境,电脑上运行只需要一分钟,而环境配置可能一天都不一定,充电两小时用时五分钟的概念。
518 0
Docker(一)入门:Docker的入门与安装

热门文章

最新文章