PAAS运维八(docker和VM)

 Docker 是世界领先的软件容器平台。开发人员利用 Docker 可以消除协作编码时“在我的机器上可正常工作”的问题。
 运维人员利用 Docker 可以在隔离容器中并行运行和管理应用,获得更好的计算密度。
 企业利用 Docker 可以构建敏捷的软件交付管道,
 以更快的速度、更高的安全性和可靠的信誉为 Linux 和 Windows Server 应用发布新功能。
 Docker 属于 Linux 容器的一种封装,提供简单易用的容器使用接口。它是目前最流行的 Linux 容器解决方案。
 Docker 将应用程序与该程序的依赖,打包在一个文件里面。运行这个文件,就会生成一个虚拟容器。
 程序在这个虚拟容器里运行,就好像在真实的物理机上运行一样。有了 Docker,就不用担心环境问题。
总体来说,Docker 的接口相当简单,用户可以方便地创建和使用容器,把自己的应用放入容器。
容器还可以进行版本管理、复制、分享、修改,就像管理普通的代码一样。

那么docker和VM到底有什么不同呢?

从下图可以看出,VM是一个运行在宿主机之上的完整的操作系统,VM运行自身操作系统会占用较多的CPU、内存、硬盘资源。Docker不同于VM,只包含应用程序以及依赖库,基于libcontainer运行在宿主机上,并处于一个隔离的环境中,这使得Docker更加轻量高效,启动容器只需几秒钟之内完成。
由于Docker轻量、资源占用少,使得Docker可以轻易的应用到构建标准化的应用中。但Docker目前还不够完善,比如隔离效果不如VM,共享宿主机操作系统的一些基础库等;网络配置功能相对简单,主要以桥接方式为主;查看日志也不够方便灵活。

PAAS运维八(docker和VM)_第1张图片

Docker 在容器的基础上,进行了进一步的封装,从文件系统、网络互联到进程隔离等等,极大的简化了容器的创建和维护。使得 Docker 技术比虚拟机技术更为轻便、快捷。

 作为一种新兴的虚拟化方式,Docker 跟传统的虚拟化方式相比具有众多的优势。
 Docker 容器的启动可以在秒级实现,这相比传统的虚拟机方式要快得多;
 Docker 对系统资源的利用率很高,一台主机上可以同时运行数千个 Docker 容器。

Docker是CS架构,主要有两个概念:

Docker daemon: 运行在宿主机上,Docker守护进程,用户通过Docker client(Docker命令)与Docker daemon交互

Docker client: Docker 命令行工具,是用户使用Docker的主要方式,Docker client与Docker daemon通信并将结果返回给用户,Docker client也可以通过socket或者RESTful api访问远程的Docker daemon
PAAS运维八(docker和VM)_第2张图片

Docker image:镜像是只读的,镜像中包含有需要运行的文件。镜像用来创建container,一个镜像可以运行多个container;镜像可以通过Dockerfile创建,也可以从Docker hub/registry上下载。
Docker container:容器是Docker的运行组件,启动一个镜像就是一个容器,容器是一个隔离环境,多个容器之间不会相互影响,保证容器中的程序运行在一个相对安全的环境中。
Docker hub/registry: 共享和管理Docker镜像,用户可以上传或者下载上面的镜像,官方地址为https://registry.hub.docker.com/,也可以搭建自己私有的Docker registry。

镜像就相当于打包好的版本,镜像启动之后运行在容器中,仓库就是装存储镜像的地方。

除过以上我们使用的Docker命令外,Docker还有一些其它常用的命令

拉取docker镜像

docker pull image_name

查看宿主机上的镜像,Docker镜像保存在/var/lib/docker目录下:

docker images

删除镜像

docker rmi  docker.io/tomcat:7.0.77-jre7   或者  docker rmi b39c68b7af30

查看当前有哪些容器正在运行

docker ps

查看所有容器

docker ps -a

启动、停止、重启容器命令:

docker start container_name/container_id
docker stop container_name/container_id
docker restart container_name/container_id

后台启动一个容器后,如果想进入到这个容器,可以使用attach命令:

docker attach container_name/container_id

删除容器的命令:

docker rm container_name/container_id

查看当前系统Docker信息

docker info

从Docker hub上下载某个镜像:

docker pull centos:latest
docker pull centos:latest

执行docker pull centos会将Centos这个仓库下面的所有镜像下载到本地repository

下面进行简单演练

1.在 server 节点,将运行的 mysql 容器创建为镜像,完成后查询该镜像,将以上操作命令及检查结果以文本形式填入答题框。(docker commit)

[root@server ~]# docker ps -a
CONTAINER ID        IMAGE                           COMMAND                  CREATED             STATUS                         PORTS                              NAMES
6b9ef06bb4f0        10.0.3.137:5000/mysql:8.0       "docker-entrypoint.sh"   About an hour ago   Up About an hour               0.0.0.0:13306->3306/tcp            angry_kare
[root@server ~]# docker export 6b9ef06bb4f0  > mysqltar
[root@server ~]# ls
anaconda-ks.cfg  mysql111tar  mysqltar  www1  www2
[root@server ~]# cat mysqltar | docker import - mysqltest:test
sha256:573734ed502d09fcbc5beffbc3309f675e3502bbb7090b76f4698b6366442014
[root@server ~]# docker images | grep  mysqltest
mysqltest                                                   test                573734ed502d        21 seconds ago      337.1 MB
[root@server ~]#

2.在 server 节点查询 registry 容器的 CPU、内存等统计信息,将以上操作命 令及检查结果以文本形式填入答题框。

[root@server ~]# docker stats 51f1b21decdc

CONTAINER           CPU %               MEM USAGE / LIMIT       MEM %               NET I/O             BLOCK I/O           PIDS
51f1b21decdc        0.00%               2.941 MiB / 5.671 GiB   0.05%               23.42 kB / 648 B    20.42 MB / 0 B      0

3.在 server 节点修改运行的 rancher/server 容器的名称,修改名称为 xiandian_server,完成后查询容器列表,将以上操作命令及检查结果以文本形式 填入答题框。

[root@server ~]# docker ps -a
CONTAINER ID        IMAGE                           COMMAND                  CREATED             STATUS                         PORTS                              NAMES
6b9ef06bb4f0        10.0.3.137:5000/mysql:8.0       "docker-entrypoint.sh"   About an hour ago   Up About an hour               0.0.0.0:13306->3306/tcp            angry_kare
[root@server ~]# docker rename 6b9ef06bb4f0 xiandian_server_mysql
[root@server ~]# docker ps 
CONTAINER ID        IMAGE                       COMMAND                  CREATED             STATUS              PORTS                              NAMES
6b9ef06bb4f0        10.0.3.137:5000/mysql:8.0   "docker-entrypoint.sh"   About an hour ago   Up About an hour    0.0.0.0:13306->3306/tcp            xiandian_server_mysql

4.在 server 节点,使用 docker 命令列举所有的网络,将以上操作命令及检 查结果以文本形式填入答题框

[root@server ~]# docker network ls
NETWORK ID          NAME                DRIVER              SCOPE
2f6ad52bc918        bridge              bridge              local               
e1ba55c090ee        host                host                local               
e337e9d1630d        none                null                local     

5.在 server 节点,使用 docker 命令查询 bridge 网络的所有详情,将以上操 作命令及检查结果填入答题框


[root@server ~]# docker network inspect bridge 

6.在 server 节点,使用 docker 命令创建名为 xd_net 的网络,网络网段为 192.168.3.0/24,网关为 192.168.3.1,创建完成后查询网络列表,将以上操作命令 及检查结果以文本形式填入答题框\

[root@server ~]# docker network create --subnet 192.168.3.0/24 --gateway 192.168.3.1 xd_net
a387254a2821302b11a6088a95e1176c178b7dbcc924c9e26df8db965a16af77
[root@server ~]# docker network ls | grep xd_net
a387254a2821        xd_net              bridge              local               
[root@server ~]#

7.在 server 节点,使用 docker 命令创建名为 xd_net 的网络,网络网段为 192.168.3.0/24,网关为 192.168.3.1,创建完成后查询此网络的详细信息,将以上 操作命令及检查结果以文本形式填入答题框。

[root@server ~]# docker network create --subnet 192.168.3.0/24 --gateway 192.168.3.1 xd_net
a387254a2821302b11a6088a95e1176c178b7dbcc924c9e26df8db965a16af77
[root@server ~]# docker network ls | grep xd_net
a387254a2821        xd_net              bridge              local               
[root@server ~]#
[root@server ~]# docker network inspect xd_net
[
    {
        "Name": "xd_net",
        "Id": "a387254a2821302b11a6088a95e1176c178b7dbcc924c9e26df8db965a16af77",
        "Scope": "local",
        "Driver": "bridge",
        "EnableIPv6": false,
        "IPAM": {
            "Driver": "default",
            "Options": {},
            "Config": [
                {
                    "Subnet": "192.168.3.0/24",
                    "Gateway": "192.168.3.1"
                }
            ]
        },
        "Internal": false,
        "Containers": {},
        "Options": {},
        "Labels": {}
    }
]

  1. .在 server 节点,使用 docker 命令创建名为 xd_net 的网络,网络网段为 192.168.3.0/24,网关为 192.168.3.1,创建镜像为 centos:latest,容器名称为 centos, 使用 docker 网络为 xd_net,创建完成后查询容器使用的网络名称和查询该容器 的运行状态,将以上操作命令及检查结果以文本形式填入答题框。
[root@server ~]# docker network create --subnet 192.168.3.0/24 --gateway 192.168.3.1 xd_net
a387254a2821302b11a6088a95e1176c178b7dbcc924c9e26df8db965a16af77
[root@server ~]# docker network ls | grep xd_net
a387254a2821        xd_net              bridge              local               
[root@server ~]#
[root@server ~]# docker run -itd  --name centos --network=xd_net  10.0.3.137:5000/centos:latest 
7fb738b189a1ed23bb5eca1efd6e827cfa371fdbb56054522fe9bdd03448637b
 [root@server ~]# docker inspect -f "{{.HostConfig.NetworkMode}}" 7fb738b189a1
xd_net
[root@server ~]# docker ps -l
CONTAINER ID        IMAGE                           COMMAND             CREATED              STATUS              PORTS               NAMES
7fb738b189a1        10.0.3.137:5000/centos:latest   "/bin/bash"         About a minute ago   Up 58 seconds                           centos

9…在 server 节点,使用 docker 命令创建名为 xd_net 的网络,网络网段为 192.168.3.0/24,网关为 192.168.3.1,创建镜像为 centos:latest,容器名称为 centos, 使用 docker 网络为 xd_net,创建完成后查询容器 IP 地址,将以上操作命令及检 查结果以文本形式填入答题框。

[root@server ~]# docker network create --subnet 192.168.3.0/24 --gateway 192.168.3.1 xd_net
a387254a2821302b11a6088a95e1176c178b7dbcc924c9e26df8db965a16af77
[root@server ~]# docker network ls | grep xd_net
a387254a2821        xd_net              bridge              local               
[root@server ~]#
[root@server ~]# docker run -itd  --name centos --network=xd_net  10.0.3.137:5000/centos:latest 
7fb738b189a1ed23bb5eca1efd6e827cfa371fdbb56054522fe9bdd03448637b
[root@server ~]# docker inspect -f {{.NetworkSettings.Networks.xd_net.IPAddress}} 7fb738b189a1
192.168.3.2

10。在 server 节点,使用 docker 命令创建名为 xd_net 的网络,网络网段为 192.168.3.0/24,网关为 192.168.3.1,创建完成后,查询网络列表,接着删除 docker 网络 xd_net,完成后查询 docker 网络列表,将以上操作命令及检查结果以文本 形式填入答题框。

[root@server ~]# docker network create --subnet 192.168.3.0/24 --gateway 192.168.3.1 xd_net
a387254a2821302b11a6088a95e1176c178b7dbcc924c9e26df8db965a16af77
[root@server ~]# docker network ls
NETWORK ID          NAME                DRIVER              SCOPE
2f6ad52bc918        bridge              bridge              local               
e1ba55c090ee        host                host                local               
e337e9d1630d        none                null                local               
a387254a2821        xd_net              bridge              local               
[root@server ~]# docker network rm a387254a2821
a387254a2821
[root@server ~]# docker network ls
NETWORK ID          NAME                DRIVER              SCOPE
2f6ad52bc918        bridge              bridge              local               
e1ba55c090ee        host                host                local               
e337e9d1630d        none                null                local               
[root@server ~]#

你可能感兴趣的:(Linux,云计算,docker)