简述

`docker是如火如荼的容器技术,今后会陆续上传关于微服务技术的学习笔记,希望能和大家一起学习一起分享!`

docker环境搭建

1.获取最新版的Docker安装包


$ wget -qO- https://get.docker.com/ | sh

2.直接使用docker无须加 sudo


# Add the docker group if it doesn't already exist.
$ sudo groupadd docker
# Add the connected user "${USER}" to the docker group.
# Change the user name to match your preferred user.
# You may have to logout and log back in again for
# this to take effect.
$ sudo gpasswd -a ${USER} docker
# Restart the docker daemon.
$ sudo service docker restart
#############单条指令##############
sudo usermod -aG docker $USER # 把当前用户加入docker组

3 . 从 17.04 以后,可以用下面的命令安装。


$ export CHANNEL=stable
$ curl -fsSL https://get.docker.com/ | sh -s -- --mirror Aliyun

镜像基本操作指令

1.搜索镜像


$ sudo docker search ubuntu

2.获取镜像


$ sudo docker pull ubuntu

3.查看镜像信息


$ sudo docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
ubuntu latest ccc7a11d65b1 3 weeks ago 120MB
swarm latest 7ecf8baf8eae 8 weeks ago 15.8MB

4.查看镜像的详细信息


$ sudo docker inspect 7ecf8baf8eae
#或
$ sudo docker inspect ubuntu

5.删除镜像


$ sudo docker rmi swarm
Error response from daemon: conflict: unable to remove repository reference "swarm" (must force) - container c445ef19d3e7 is using its referenced image 7ecf8baf8eae

因此,删除镜像之前得确保容器已删除

6.删除容器


$ sudo docker rm 7ecf8baf8eae #删除指定容器
$ sudo docker rm $(docker ps -a -q) #删除所有已生成容器

7.复制镜像


$ sudo docker tag ubuntu:latest hzy/test:latest
hzy@hadoop:~$ sudo docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
hzy/test latest ccc7a11d65b1 3 weeks ago 120MB
ubuntu latest ccc7a11d65b1 3 weeks ago 120MB
swarm latest 7ecf8baf8eae 8 weeks ago 15.8MB

创建镜像

1.创建一个新镜像,进行操作


$ docker run -it ubuntu /bin/bash --name bieming
root@3138d574074e:/#

2.使用 docker commit 来提交一个新的镜像


$ sudo docker commit -m "added a new file" -a "huangzy" 3138d574074e hzy/test
3138d574074esha256:f8b1d41ff97589f7c207577b391b1d5074b197a1ec3196a8907269ec6e00dcae
# -a, --author="" 作者信息
# -m, --message="" 提交消息
# -p, --pause=ture 提交时暂停容器运行

存出和载入镜像

1.存出镜像


$ sudo docker save -o ubuntu.tar ubuntu:latest

2.载入镜像


$ sudo docker load --input ubuntu.tar
Loaded image: ubuntu:latest
#或
$ sudo docker load < ubuntu.tar

容器

1.创建容器


$ sudo docker run -it ubuntu:latest /bin/bash
root@939831baa91d:/#
# -t 分配一个伪终端绑定到容器的标准输入上
# -i 让容器的标准输入保持打开
# -d 让Docker容器在后台以守护态(Daemonized)形式运行

2.终止容器


$ sudo docker stop 939831b

3.查看容器状态


$ sudo docker ps
#或
$ sudo docker ps -a -q # 可查看到终止状态的容器

4.使用 docker start 命令来重新启动处于终止状态的容器


$ sudo docker start 939831b
#或
$ sudo docker restart 939831b

5.删除容器


$ sudo docker rm 3138d574074e
Error response from daemon: You cannot remove a running container 3138d574074e5a45a543760c2ecb3935b0173d89940c05fa3cd969d1112338ff. Stop the container before attempting removal or force remove
#应该先停止容器服务,再进行删除。
$ sudo docker stop 3138d574074e

导入和导出容器

1.导出容器(无论该容器是否处于运行状态)


$ sudo docker export 3138d > test_for_run.tar

2.导入容器(导出的文件可以导入,成为镜像)


$ cat test_for_run.tar | sudo docker import - test/ubuntu:v1
sha256:b974a00be6dd0ac5f794c3ec5ef6b1812cdc535390b67950cf220aa1e557c759

仓库(Repository)

仓库:是集中存放镜像的地方。

注册服务器(Registry):是存放仓库的具体服务器。

1.终端登录Docker Hub


$ sudo docker login
[sudo] password for hzy:
Login with your Docker ID to push and pull images from Docker Hub. If you don't have a Docker ID, head over to https://hub.docker.com to create one.
Username: s152118130110
Password:
Login Succeeded

2.将本地镜像推送到Docker Hub


$ sudo docker push swarm:latest

创建和使用私有仓库

1.默认情况下,会将仓库存放于容器的 /tmp/registry 目录下,如果容器被删除,则数据也会丢失,所以我们可以通过 -v 参数来将镜像文件存放在本地的指定路径


$ sudo docker run –d –p 5000:5000 --restart=always --name registry -v /opt/myregistry:/var/lib/registry registry
# -i: 保持sdtin开放状态
# -d: 使容器以守护进程方式后台运行,并打印容器id
# -t: 分配一个tty(虚拟终端设备)
# -v: 绑定挂载一个容器内的路径到宿主机路径
# -p: 映射一个容器的端口到宿主机端口
# -restart: 当容器退出时的重启策略
# -name: 给容器命名一个名称

打开chrome输入 http://127.0.0.1:80/v2

2.标记


$ sudo docker tag swarm 192.168.18.19:5000/swarm

3.上传


$ sudo docker push 192.168.18.19:5000/swarm
The push refers to a repository [192.168.18.19:5000/swarm]
Get https://192.168.18.19:5000/v2/: http: server gave HTTP response to HTTPS client
#由于客户端采用https,docker registry未采用https服务所致。一种处理方式是把客户对地址“192.168.1.100:5000”请求改为http
#在 "etc/docker" 目录下,创建daemon.json文件,并在文件写入:
{"insecure-registries":["ip地址:5000"]}
#重新启动docker
$ sudo service docker restart
#重新上传镜像即可
$ sudo docker push 192.168.18.19:5000/swarm
# 查看上传是否成功
$ curl http://192.168.18.19:5000/v2/_catalog
{"repositories":["swarm"]}

4.下载镜像


$ sudo docker pull 192.168.18.19:5000/swarm

客户机访问Registry

1.对于需要访问Registry仓库的客户机,需要修改文件。


# ubuntu 在以下文件添加 {"insecure-registries":["192.168.18.19:5000]}
$ vi /etc/docker/daemon.json
# centos 在以下文件添加 OPTIONS=‘--SELINUXENABLED--INSECUREREGISTRY192.168.18.19:5000’
$ vi /etc/sysconfig/docker

数据卷

1 . 使用 -v标记可以指定挂载一个本地的目录到容器中


$ docker run -d -P --name web -v /src/webapp:/opt/webapp:ro training/webapp python app.py
# 地目录的路径必须是绝对路径,如果目录不存在 Docker 会自动为你创建它。

2 . 使用 -v 标记也可以从主机挂载单个文件到容器中


$ docker run --rm -it -v ~/.bash_history:/.bash_history ubuntu /bin/bash
# 这样可以记录在容器输入过的命令

进一步?

待续。。。

【docker 一】入门实践、环境部署、基本操作指令、镜像库、数据卷的更多相关文章

  1. 微服务 + Docker + Kubernetes 入门实践 目录

    微服务 + Docker + Kubernetes 入门实践: 微服务概念 微服务的一些基本概念 环境准备 Ubuntu & Docker 本文主要讲解在 Ubuntu 上安装和配置 Dock ...

  2. Docker容器入门实践

    Docker 是一个开源项目,诞生于 2013 年初,最初是 dotCloud 公司内部的一个业余项目.它基于 Google 公司推出的 Go 语言实现. 项目后来加入了 Linux 基金会,遵从了 ...

  3. 自动化运维工具Ansible之LNMP实践环境部署

    Ansible-实战指南-LNMP环境部署,并使用zabbix监控 主机规划 系统初始化:必要的系统初始化 基础组件包括:zabbix监控,mariadb(用于存放zabbix监控信息) 业务组件包括 ...

  4. Docker基础入门实践

    原文地址 基本概念 Docker三个基本概念 镜像(Image) 容器(Container) 仓库(Repository) 镜像 镜像可以理解为只读模板,如包含一个centos操作系统环境 容器 Do ...

  5. 《Docker从入门到跑路》之镜像和容器的基本操作

    一.获取镜像 官方提供了一个公共镜像仓库Docker Hub,默认是从这上面获取镜像的. 搜素镜像使用docker search 命令: # docker search --help Usage: d ...

  6. docker部署harbor私有镜像库(3)

    一.harbor介绍 在实际生产运维中,往往需要把镜像发布到几十.上百台或更多的节点上.这时单台Docker主机上镜像已无法满足,项目越来越多,镜像就越来越多,都放到一台Docker主机上是不行的,我 ...

  7. Docker 从入门到放弃(三)镜像使用

    当运行容器时,使用的镜像如果在本地中不存在,docker 就会自动从 docker 镜像仓库中下载,默认是从 Docker Hub 公共镜像源下载. 下面我们来学习: 1.管理和使用本地 Docker ...

  8. Docker部署Registry私有镜像库

    拉取镜像 docker pull registry:2.6.2   生成账号密码文件,这里采用htpasswd方式认证 docker run --rm --entrypoint htpasswd re ...

  9. 1.docker介绍、命令、容器、镜像、数据卷、Dockerfile、常用软件安装、推送阿里云

    一.docker介绍 1.docker是什么 一款产品从开发到上线,从操作系统,到运行环境,再到应用配置.作为开发+运维之间的协作我们需要关心很多东西,这也是很多互联网公司都不得不面对的问题,特别是各 ...

  10. SuperMap开发入门2——环境部署

    由于超图的相关资源比较少,可参考官方提供的<SuperMap iDesktop 9D安装指南>和<SuperMap iObjects .NET 9D安装指南>完成应用软件和开发 ...

随机推荐

  1. 分析Array.apply(null, { length: 5 })

    Array.apply(null, { length: 5 }) 和 Array(5)有什么不同 注意:ES5,apply函数的第二个参数除了可以是数组外,还可以是类数组对象 // 类转成真正的数组 ...

  2. 【译】Asp.Net Identity Cookies 格式化-中英对照版

    原文出处 Trailmax Tech Max Vasilyev: ASP.Net MVC development in Aberdeen, Scotland I've been reached out ...

  3. C# 中操作API

    作为初学者来说,在C#中使用API确是一件令人头疼的问题.在使用API之间你必须知道如何在C#中使用结构.类型转换.安全/不安全代码,可控/不可控代码等许多知识. 一切从简单开始,复杂的大家一时不能接 ...

  4. Linux系列教程(二十一)——Linux的bash基本功能

    上篇博客我们介绍了什么是shell,以及编写shell脚本的两种执行方式.我们知道在敲命令的时候,有很多快捷键,比如tab键能补全命令,在比如为什么我们直接敲 ll 命令能显示目录的长格式,其实这是b ...

  5. 比特币区块结构Merkle树及简单支付验证分析

    在比特币网络中,不是每个节点都有能力储存完整的区块链数据,受限于存储空间的的限制,很多节点是以SPV(Simplified Payment Verification简单支付验证)钱包接入比特币网络,通 ...

  6. 学会WCF之试错法——安全配置报错分析

    安全配置报错分析 服务端配置 <system.serviceModel> <bindings> <wsHttpBinding> <binding name = ...

  7. Linux命令kill和signal

    Linux命令kill和signal kill命令用于终止指定的进程(terminate a process),是Unix/Linux下进程管理的常用命令.通常,我们在需要终止某个或某些进程时,先使用 ...

  8. Java并发之线程管理(线程基础知识)

    因为书中涵盖的知识点比较全,所以就以书中的目录来学习和记录.当然,学习书中知识的时候自己的思考和实践是最重要的.说到线程,脑子里大概知道是个什么东西,但很多东西都还是懵懵懂懂,这是最可怕的.所以想着细 ...

  9. MyBatis《2》

    MyBatis入参考文档:http://mybatis.org/mybatis-3/zh/   1.properties 属性 1.在MyBatis配置文件中引用属性文件     MyBatis允许在 ...

  10. 前端worker之web worker

    web worker 背景 众所周知javascript是单线程的,同一时间内只能做一件事情. 这是十分必要的,设想,如果js是多线程的.有个dom元素两个线程同时做了改变,一个display:non ...