docker 查询cpu核数 docker 查看cpu_docker 查询cpu核数


-     Docker是什么    -

1. 项目上线

  • 代码部署阶段:测试、开发、需求等需要通力合作
  • 软件部署阶段:MySql、Nginx、Redis、MQ等软件都需要会安装和运维
  • 硬件部署阶段:服务器(服务器品牌:内存、CPU、硬盘)、
  • 对服务器运维(网络、机房、运维)

这些都需要亲力亲为,很费事也很费时,需要大量的人力物力,如果有一套只需要代码部署层面的就好了,所以Docker应运而生。它是云时代的产物。


2. 云类型

  • SaaS:软件即服务,如:OA、钉钉、ERP
  • PaaS:平台即服务,如:MySQL、Nginx、MongoDB、Redis等。
  • Docker就是基于PaaS产生的一种容器技术
  • IaaS:基础设施即服务,如:服务器

                         4G内存、100T硬盘、10M带宽

                         8G内存、100G固态、100M带宽

docker 查询cpu核数 docker 查看cpu_docker 查询cpu核数_02


-    Docker的核心概念    -

1. 组成

  • 镜像(Image)
  • 一个只读的模板。
  • 可以用来创建 Docker 容器
  • 镜像里还包含Tag
  • 容器(Container)
  • 容器是从镜像创建的运行实例。它可以被启动、开始、停止、删除。每个容器都是相互隔离的、保证安全的平台。
  • 容器和镜像的关系:
  • 仓库注册中心(Registry)
  • 集中存放镜像文件的场所,又称为中央仓库
  • 仓库(Repository)
  • 对于其中的镜像进行分类管理。 
  • 一个 Repository 中会有多个不同 tag 的 Image。
  • 仓库注册中心和仓库的关系:

2. Registry

Registry 分为公有(public)和私有(private)两种形式。

  • 最大的公有 Registry 是 Docker Hub,存放了数量庞大的镜像供用户下载使用。 
  • 国内的公开 Registry 包括 USTC、网易云、DaoCloud、AliCloud等,可以供大陆用户更稳当快捷的访问。
  • 用户可以在本地创建一个私有 Registry。

docker 查询cpu核数 docker 查看cpu_Docker_03

docker 查询cpu核数 docker 查看cpu_docker 查询cpu核数_02


-    Docker操作    -

1. 镜像操作

  • 列出镜像:dockerimages
  • 搜索镜像:dockersearch 镜像名称
  • 拉取镜像:dockerpull 镜像名称:Tag
  • 删除镜像:
  • 删除指定镜像
    docker rmi repository:tag
    docker rmi imageID
  • 删除所有镜像
    docker rmi $(docker images -q)

       注意:删除时,如果镜像的 image id 一致,则需要按照一定顺序进行删除,因为镜像之间有关联(reference)。

  • 导入导出镜像(镜像迁移):
  • 导出镜像
    docker save repository:tag/imageId >/root/xx.tar.gz
    docker save -o mynginx.tar mynginx
    -o 输出到的文件
    执行后,运行 ls 命令即可看到打成的tar 包
  • 导入镜像:
    docker load < /root/xx.tar.gz
    docker load -i mynginx.tar
    -i 输入的文件
    执行后再次查看镜像,可以看到镜像已经恢复

2. 容器操作

  • 创建并运行容器
  • 创建容器命令:docker run
    创建容器常用的参数说明
  • -i:表示运行容器
  • -t:表示容器启动后会进入其命令行。加入这两个参数后,容器创建就能登录进去。即分配一个伪终端。
  • --name :为创建的容器命名。
  • -v:表示目录映射关系(前者是宿主机目录,后者是映射到宿主机上的目录),可以使用多个-v 做多个目录或文件映射。注意:最好做目录映射,在宿主机上做修改,然后共享到容器上。
  • -d:在 run 后面加上-d 参数,则会创建一个守护式容器在后台运行(这样创建容器后不会自动登录容器,如果只加-i -t 两个参数,创建后就会自动进去容器)。
  • -p:表示端口映射,前者是宿主机端口,后者是容器内的映射端口。可以使用多个-p 做多个端口映射
  • 以交互方式运行容器
  • docker run -i -t --name 容器名称 repository:tag /bin/bash
  • docker run -it --name 容器名称 imageID /bin/bash
  • 以守护进程方式运行容器
  • docker run -di --name 容器名称 repository:tag
  • docker run -di --name 容器名称 imageID

以守护进程方式运行容器以守护进程方式运行容器注意:通过 run 创建并进入容器之后,如果使用 exit 命令退出容器,则容器停止。

再次进入该容器,先使用 start 启动容器,再使用 exec/attach 命令进入容器。

  • 启动容器:docker start 容器名称或者容器 ID
  • 进入容器
  • 进入正在运行的容器的命令如下:

                docker exec -it 容器名称或者容器 ID /bin/bash

                docker attach 容器名称或者容器 ID

                  两者之间的区别:

                attach 进入容器之后,如果使用exit 退出容器,则容器停止。

                exec 进入容器之后,使用 exit退出容器,容器依然处于运行状态。

  • 查看容器
  • docker ps :查看正在运行的容器
  • docker ps -a:查看历史运行过的容器
  • docker ps -l:查看最近运行过的容器
  • 停止容器
  • docker stop 容器名称或者容器 ID
  • 删除容器
  • 删除指定容器:
    docker rm 容器名称或者容器ID
  • 删除所有容器:
    docker rm ‘docker ps -a -q’
  • 复制文件
  • docker cp 源文件 目标文件
    如:docker cp /root/boot.warmy-centos:/usr/local/
    说明:
  • /root/boot.war 是宿主机器的路径
  • my-centos 是容器的名称
  • /usr/local/是容器内的路径

        注意:源文件可以是宿主机器也可以是容器中的文件,同样,目标文件可以是容

        器也可以是宿主机器的文件。

docker 查询cpu核数 docker 查看cpu_docker 查询cpu核数


-    总结与经验分享    -

1. 指令学习思考

这么多指令怎么记,我要拿着一个笔记存起来,用的时候复制粘贴,需要改动的时候改吧改吧吗?

还是用的次数多了,自然就记住了?

但是有些指令太长了,懒的敲,直接复制粘贴了

是你你会怎么做?

2. 指令学习方法

示例一:

docker 查询cpu核数 docker 查看cpu_docker_06

示例二:

docker 查询cpu核数 docker 查看cpu_Docker_07

示例三:

docker 查询cpu核数 docker 查看cpu_Docker_08

2. 总结

我不知道我的这种方式适不适用大家,但是从本质来看,我这么做就是为了解决我的问题,只要我能通过一种自己能够理解的、并且能够很快的把知识点消化了,不管用什么方法,对于我们而言都是有益的

不管白猫黑猫,抓到老鼠就是好猫。

所以对于自己而言,要找出适合自己的方法,提升自己的效率,这样不仅能很快达到目的,说不定也能触类旁通

-     作者介绍    -