1.docker使用的优点

1.更快速的交付和部署
对于开发和运维人员来说,最希望的是保持所有环境一致,这样不会导致,开发在自己的环境里程序运行正常而运维跑的服务器环境里就不正常;对于运维来说,可以使用容器来部署代码,使运维和开发的环境一致,不用相互扯皮,也节约了大量的部署时间 2.更轻松的迁移和扩展
迁移只需要将docker容器打包,而且docker兼容很多的系统,很容易进行迁移 3.更简单的管理
使用 Docker,只需要小小的修改,就可以替代以往大量的更新工作。所有的修改都以增量的方式被分发和更新,从而实现自动化并且高效的管理

2.Docker引擎

docker引擎是一个c/s结构的应用,主要组件见下图:

    docker引擎是一个c/s结构的应用,主要组件见下图:
Server是一个常驻进程
REST API 实现了client和server间的交互协议
CLI 实现容器和镜像的管理,为用户提供统一的操作界面
image是镜像
container是容器

3.Docker架构

Docker使用C/S架构,Client 通过接口与Server进程通信实现容器的构建,运行和发布。client和server可以运行在同一台集群,也可以通过跨主机实现远程通信。

client:客户端
docker_host:宿主主机
registry:仓库:私服和中央仓库(Docker Hub)

4.核心概念

镜像(image)
  docker 镜像是用于创建 Docker 容器的模板 容器(container)
  容器是独立运行的一个或一组应用 客户端(Client)
  Docker 客户端通过命令行或者其他工具使用 Docker API (https://docs.docker.com/reference/api/docker_remote_api) 与 Docker 的守护进程通信。 主机(Host)
  一个物理或者虚拟的机器用于执行 Docker 守护进程和容器。 仓库(Registry)
  Docker 仓库用来保存镜像,可以理解为代码控制中的代码仓库
  Docker Hub(https://hub.docker.com) 提供了庞大的镜像集合供使用

5.Centos 7.2 中docker安装

1.yum 包更新到最新
yum update 2.安装需要的软件包
yum install -y yum-utils device-mapper-persistent-data lvm2 3.设置yum源为阿里云
yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo 4.安装docker
yum install docker-ce -y
docker version # 查看docker版本 5.设置ustc的镜像
ustc是老牌的linux镜像服务提供者了,还在遥远的ubuntu 5.04版本的时候就在用。ustc的docker镜像加速器速度很快。ustc docker mirror的优势之一就是不需要注册,是真正的公共服务。
https://lug.ustc.edu.cn/wiki/mirrors/help/docker vi /etc/docker/daemon.json
{
"registry-mirrors": ["https://docker.mirrors.ustc.edu.cn"]
}
docker数据目录可以在daemon.json这里进行设置,默认是/var/lib/docker,也可以不修改,用软连接的形式进行处理
data-root:/db/docker

设置完成后:
systemctl daemon-reload
systemctl restart docker

6.开启包转发功能和修改内核参数
modprobe br_netfilter #重启后会失效,设置为开机自动加载,可以写脚本
vi /etc/sysctl.d/docker.conf #docker之间通信,外部访问需要用到
net.ipv4.ip_forward = 1
net.bridge.bridge-nf-call-ip6tables = 1
net.bridge.bridge-nf-call-iptables = 1

参数生效:sysctl -p
查看: lsmod | grep br_netfilter

6.docker的启动与停止

1.启动与停止命令
systemctl start docker
systemctl stop docker 2.查看docker信息
systemctl status docker
docker info 3.docker帮主文档
docker --help

7.Docker的镜像操作

1.查看镜像
docker images
  REPOSITORY:镜像名称
  TAG:镜像标签
  IMAGE ID:镜像ID
  CREATED:镜像的创建日期(不是获取该镜像的日期)
  SIZE:镜像大小
这些镜像都是存储在Docker宿主机的/var/lib/docker目录下 REPOSITORY TAG IMAGE ID CREATED SIZE
centos7.9 latest aed04a88237a 3 hours ago 520MB
hello-world latest bf756fb1ae65 12 months ago 13.3kB 2.搜索镜像
如果你需要从网络中查找需要的镜像,可以通过以下命令搜索:docker search 镜像名称
例如:docker search centos7.2 NAME:仓库名称
DESCRIPTION:镜像描述
STARS:用户评价,反应一个镜像的受欢迎程度
OFFICIAL:是否官方
AUTOMATED:自动构建,表示该镜像由Docker Hub自动构建流程创建的 3.拉取镜像
拉取镜像就是从中央仓库中下载镜像到本地:docker pull 镜像名称
例如:docker pull centos:7.2 4.删除镜像
1)按镜像ID删除
docker rmi 镜像ID
2)删除所有镜像
docker rmi `docker images -q`

5.docker修改REPOSITORY和TAG,以便标记可以让人记住此tag的用途
  根据image id进行修改:docker tag b28ded29c3e9 nginx-1-18:centos7.9
  此时可以发现2个相同的image id,可以删除之前的
docker rmi 镜像名称:镜像标签

8. Docker容器操作

1.查看正在运行的容器
docker ps 查看所有容器
docker ps –a 查看停止的容器
docker ps -f status=exited 查看最后一次运行的容器
docker ps -l

查看容器日志
docker logs 容器名 2.创建于启动容器
创建容器常用的参数说明:
创建容器命令:docker run -i:表示运行容器
-t:表示容器启动后会进入其命令行。加入这两个参数后,容器创建就能登录进去。即分配一个伪终端。
--name :为创建的容器命名。
-v:表示目录映射关系(前者是宿主机目录,后者是映射到宿主机上的目录),可以使用多个-v做多个目录或文件映射。注意:最好做目录映射,在宿主机上做修改,然后共享到容器上。
-d:在run后面加上-d参数,则会创建一个守护式容器在后台运行(这样创建容器后不会自动登录容器,如果只加-i -t两个参数,创建后就会自动进去容器)。
-p:表示端口映射,前者是宿主机端口,后者是容器内的映射端口。可以使用多个-p做多个端口映射
-P:端口映射,宿主机单口随机生成,映射到容器,例如:

docker run -it -P --name nginx1 nginx

[root@zabbix ~]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
2928a8e9564e nginx "/docker-entrypoint.…" 11 minutes ago Up 11 minutes 0.0.0.0:49153->80/tcp, :::49153->80/tcp nginx

  udp映射:docker run -it -p 80:80/udp --name nginx1 nginx

(1) 交互式方式创建容器(如果容器名称已被测试使用,可以使用后面的命令删除)
docker run -it --name=容器名称 镜像名称:标签 /bin/bash
(2) 守护式方式创建容器:
docker run -di --name=容器名称 镜像名称:标签 登录守护式容器方式:
docker exec -it 容器名称 (或者容器ID) /bin/bash

9.停止与启动容器

1.停止容器
docker stop 容器名称(或者容器ID) 2.启动容器
docker start 容器名称(或者容器ID)

10.删除容器

删除指定的容器:
docker rm 容器名称(容器ID)

11.文件拷贝

1.如果我们需要将文件拷贝到容器内可以使用cp命令
docker cp 需要拷贝的文件或目录 容器名称:容器目录 2.也可以将文件从容器内拷贝出来
docker cp 容器名称:容器目录 需要拷贝的文件或目录

12.目录挂载

    我们可以在创建容器的时候,将宿主机的目录与容器内的目录进行映射,这样我们就可以通过修改宿主机某个目录的文件从而去影响容器。(可以作为日志的目录文件映射到宿主机,或者配置文件目录映射到宿主机)
创建容器 添加-v参数 后边为 宿主机目录:容器目录
例如:
docker run -di -v /data/logs:/usr/local/nginx/logs --name=mycentos centos:7

如果你共享的是多级的目录,可能会出现权限不足的提示。

这是因为CentOS7中的安全模块selinux把权限禁掉了,我们需要添加参数 --privileged=true 来解决挂载的目录没有权限的问题

# 避免孤儿目录,删除没用的目录,避免占用磁盘空间

docker rm -fv xxx

docker volume prune

13.查看容器的IP地址

我们可以通过以下命令查看容器运行的各种数据:
docker inspect 容器名称(容器ID) 也可以直接执行下面的命令直接输出IP地址:
docker inspect --format='{{.NetworkSettings.IPAddress}}' 容器名称(容器ID)

14.容器的迁移与备份和恢复

# 1.容器保存为镜像
格式:docker commit -m '镜像描述' -a '制作者' 容器名 镜像名
例如:docker commit -m "test_hj" -a "cxiong" test centos7.9 # 2.镜像备份:导出镜像
格式:docker save -o tar包的名字 镜像名
例如:docker save -o /home/test_hj.tar centos7.9
# 多个镜像导出备份
docker save 镜像名1 镜像名2 -o backup.tar.gz

# 3. 镜像恢复与迁移
可以重新找一台安装了docker的机器,将导出的镜像导入进去
例如:docker load < test_hj.tar
执行后再次查看镜像,可以看到镜像已经恢复 # 4.创建镜像
docker run -di --name=test images id
登录镜像:docker exec -it test /bin/bash # 登录镜像可以查看原来的镜像所有的环境与一些内容都还在,如果需要添加内容可以再次制作为镜像

15.docker安装nginx

1.拉取镜像
docker pull nginx 2. 创建Nginx容器
docker run -di --name=mynginx -p 80:80 nginx

16.阿里云的容器镜像服务

1.登录阿里云的控制平台打开容器镜像服务,可以创建镜像服务,也可以从阿里的官方镜像源中拉取镜像

2.登录实例(可以使用固定密码或临时密码)
docker login --username=test@xxx registry.cn-shanghai.aliyuncs.com
docker tag [ImageId] registry.cn-hangzhou.aliyuncs.com/aliyunhangzhou/cxiong:[镜像版本号]
#[镜像版本号]自定义
3.自己定制的镜像可以push到阿里的个人本地镜像仓库中以便以后有需要可以直接使用
docker push registry.cn-hangzhou.aliyuncs.com/aliyunhangzhou/cxiong:[镜像版本号]
# 拉取镜像
docker pull registry.cn-hangzhou.aliyuncs.com/aliyunhangzhou/cxiong:[镜像版本号]

17.将宿主机端口映射到docker中

# nginx为例
# 将容器指定端口指定映射到宿主机的一个端口上
docker run -di --name=nginx -p 80:80 nginx:1.18

# 指定ip映射
docker run -it -p 172.17.0.1:82:80 --name nginx2 nginx

Docker的基本命令的更多相关文章

  1. Docker容器基本命令注意点

    Docker 容器基本命令注意点 前言: a. 本文主要为 Docker的视频教程 笔记. b. 本机环境为 Windows 10 专业版,使用的命令行为 PowerShell. 1. docker ...

  2. 记录以下docker的基本命令

    docker search xxx(tag)      在OFFICIAL上ok的是官方镜像    这里也可以去dockerhub上面看到   搜索xxx镜像docker images查看本地所安装的 ...

  3. 【Docker】基本命令

    1.进入容器交互状态 docker exec -ti xxxx /bin/bash 2.查询镜像 docker images 3.查询容器 docker ps

  4. 【Docker】- 基本命令

    1.docker ps -a    显示所有容器 2.doker ps -l 显示最近一次启动的容器 3.docker ps   显示正在运行的容器 4.docker start [容器ID]  启动 ...

  5. 【Docker】基本命令使用介绍

    # docker命令行学习 ## docker run- docker run --help:老实说这条最管用了- docker run -it:交互模式,允许控制台输出 - docker run - ...

  6. docker 的基本命令

    查看命令 docker images 查看镜像 docker ps 查看正在运行的容器 docker ps -a 查看所有的容器 docker inspect container-name 记录着 D ...

  7. Docker安装基本命令操作,带你了解镜像和容器的概念!

    上一章节我们了解了Docker的基本概念,以及相关原理.这一章节进行实操. <Docker这么火爆.章节一:带你详尽了解Docker容器的介绍及使用> 一.Docker安装 声明:Dock ...

  8. Docker 02 基本命令

    参考源 https://www.bilibili.com/video/BV1og4y1q7M4?spm_id_from=333.999.0.0 https://www.bilibili.com/vid ...

  9. 七、docker基本命令

    Docker 基本命令 docker的基本命令 docker version :查看docker的版本号,包括客户端.服务端.依赖的Go等 [root@centos7 ~]# docker versi ...

  10. Docker 基本命令和使用

    Docker 基本命令 systemctl start docker : 启动 Docker systemctl stop docker : 停止 Docker systemctl restart d ...

随机推荐

  1. rnacos 版本更新为 v0.1.4

    rnacos是一个用 rust重新实现的nacos. 周一发布 rnacos 后,有收到部分对2.0版本兼容问题的反馈. 主要是nacos2.0版本的注册心跳与1.0不同,rnacos之前没对2.0版 ...

  2. 【环境配置】vscode配置C C++开发和调试环境

    按照本教程配置好之后,不再需要写任何tasks.json和launch.json文件,减轻记忆负担,即使是调试程序,也不用再写这些文件了,跟着做就能得到一个很好的集成开发环境 目录 msys2的安装与 ...

  3. 基于proteus的4026的二分频计数

    基于proteus的4026的二分频计数 1.芯片原理 4026还是一个CMOS芯片,是直接输出段码的计数器.显然,这个芯片的作用就是和七段数码管配合,直接将计数结果显示在数码管上.这里只是用于分频, ...

  4. KingbaseES V8R6 创建索引create index concurrently被阻塞

    前言 CREATE INDEX CONCURRENTLY(CIC)是DBA们最常用的语句之一,它的好处是不阻塞DML语句. 但在大事务.长事务较多的系统,它可能被阻塞得很久. 本篇就从这个阻塞的案例开 ...

  5. #KD-Tree#洛谷 4849 寻找宝藏

    题目传送门 题目大意 在一个四维坐标系中,给定 \(n\) 个点,问有多少种选择点的方案, 使得这些点排序后任意坐标单调不降,并且选择的点权和最大,同时输出最大值 分析 设 \(f[i]\) 表示最后 ...

  6. 深入理解 Java 变量类型、声明及应用

    Java 变量 变量是用于存储数据值的容器.在 Java 中,有不同类型的变量,例如: String - 存储文本,例如 "你好".字符串值用双引号引起来. int - 存储整数( ...

  7. C# 报错 Lc.exe已退出 代码为-1 如何解决

    完美解决方案:把项目文件夹下Properties文件夹下的licenses.licx文件删除,重新编译即可:

  8. Linux忘记root密码修改方法

    1. 再开机启动的时候按键盘上的"e"键会出现如下界面.再次按"e"键进行选择相应的内核. 2. 选择相应的内核,再次按"e". 3.经过第 ...

  9. TAMUctf 2024 RSA-证书修复-总结

    上周末跟朋友们参加了TAMUctf 2024国际赛,最终排在了第14名,还是很不错的成绩. 本次比赛Monk师傅也是出了三个RSA证书修复问题的题目,质量很不错.这里给大家整理一下供学习. Trunc ...

  10. pc=mobile+pad自适应布局:页面结构与打开方式

    pc=mobile+pad自适应布局 在这篇文章,咱们重点聊聊自适应布局的页面结构,以及打开页面的几种方式.关于pc=mobile+pad自适应布局的起源.概念.效果,参见文章:自适应布局:pc = ...