Docker系列(2)--容器和镜像的使用

简介: Docker系列(2)--容器和镜像的使用

第一个docker程序:


一、Docker 允许你在容器内运行应用程序, 使用 docker run 命令来在容器内运行一个应用程序。 输出Hello world


[root@a ~]# docker run ubuntu:15.10 /bin/echo hello world
WARNING: IPv4 forwarding is disabled. Networking will not work.
hello world
解决:
[root@a ~]# echo "net.ipv4.ip_forward=1" >>/usr/lib/sysctl.d/00-system.conf
[root@a ~]# systemctl restart network
[root@a ~]# docker run ubuntu:15.10 /bin/echo hello world                     hello world

各个参数解析: docker: Docker 的二进制执行文件。 run: 与前面的 docker 组合来运行一个容器。 ubuntu:15.10 指定要运行的镜像,Docker 首先从本地主机上查找镜像是否存在,如果不存在,Docker 就会从镜像仓库 Docker Hub 下载公共镜像。 /bin/echo "Hello world": 在启动的容器里执行的命令 以上命令完整的意思可以解释为:Docker 以 ubuntu15.10 镜像创建一个新容器,然后在容器里执行 bin/echo "Hello world",然后输出结果。


二、运行交互式的容器

cat /proc/version
Linux version 4.4.0-151-generic (buildd@lgw01-amd64-043) (gcc version 5.4.0 20160609 (Ubuntu 5.4.0-6ubuntu1~16.04.10) ) #178-Ubuntu SMP Tue Jun 11 08:30:22 UTC 2019
root@0123ce188bd8:/# ls
bin  boot  dev  etc  home  lib  lib64  media  mnt  opt  proc  root  run  sbin  srv  sys  tmp  usr  var
root@0123ce188bd8:/# 

我们可以通过运行 exit 命令或者使用 CTRL+D 来退出容器。


三、启动容器(后台模式)


docker run -d ubuntu:15.10 /bin/sh -c "while true; do echo hello world; sleep 1; done"
2b1b7a428627c51ab8810d541d759f072b4fc75487eed05812646b8534a2fe63

这个长字符串叫做容器 ID,对每个容器来说都是唯一的,我们可以通过容器 ID 来查看对应的容器发生了什么。

[root@a ~]# docker ps
CONTAINER ID        IMAGE               COMMAND                  CREATED              STATUS              PORTS               NAMES
7c7321349118        ubuntu:15.10        "/bin/sh -c 'while t…"   About a minute ago   Up About a minute     
在宿主主机内使用 docker logs 命令,查看容器内的标准输出:
[root@a ~]# docker logs 7c7321349118
hello world
hello world
hello world
...
...

四、停止容器的运行


[root@a ~]# docker stop 7c7321349118
7c7321349118
[root@a ~]# docker ps
CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS              PORTS               NAMES

容器使用


1、获取镜像如果我们本地没有 ubuntu 镜像,我们可以使用 docker pull 命令来载入 ubuntu 镜像,也可以运行run自动去下载:


[root@a ~]# docker pull ubuntu

2、启动容器

[root@a ~]# docker run -it ubuntu:15.10 /bin/bash
root@6e7c29414a92:/#

3、启动已停止运行的容器

[root@a ~]# docker stop 6e7c29414a92
6e7c29414a92
[root@a ~]# docker ps -a
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS                        PORTS               NAMES
6e7c29414a92        ubuntu:15.10        "/bin/bash"              6 minutes ago       Exited (0) 14 seconds ago                         pedantic_yonath
[root@a ~]# docker start 6e7c29414a92
6e7c29414a92
[root@a ~]# docker ps -a
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS                        PORTS               NAMES
6e7c29414a92        ubuntu:15.10        "/bin/bash"              6 minutes ago       Up 1 second                                       pedantic_yonath

4、进入容器

在使用 -d 参数时,容器启动后会进入后台。此时想要进入容器,可以通过以下指令进入:
docker attach
docker exec:推荐使用 docker exec 命令,因为此退出容器终端,不会导致容器的停止。
[root@a ~]# docker attach 6e7c29414a92
root@6e7c29414a92:/#
如果从这个容器退出,会导致容器的停止。

[root@a ~]# docker exec -it 6e7c29414a92 /bin/bash
root@6e7c29414a92:/# exit
[root@a ~]# docker ps -a
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS                        PORTS               NAMES
6e7c29414a92        ubuntu:15.10        "/bin/bash"              11 minutes ago      Up 54 seconds                                     pedantic_yonath

5、导出和导入容器

导出:
[root@a ~]# docker export 1e560fca3906 > ubuntu.tar
导入:  
[root@a ~]# docker import - test/ubuntu:v1
查看:
[root@a ~]# docker images -a
ubuntu              15.10               9b9cb95443b5        3 years ago         137MB
此外,也可以通过指定 URL 或者某个目录来导入,例如:
docker import http://example.com/exampleimage.tgz example/imagerepo

6、删除容器

[root@a ~]# docker ps -a
1b389ac1c5e6        hello-world         "/hello"                 16 hours ago        Exited (0) 16 hours ago                          flamboyant_austin
[root@a ~]# docker start 1b389ac1c5e6
1b389ac1c5e6
[root@a ~]# docker rm -f 1b389ac1c5e6
1b389ac1c5e6
[root@a ~]# docker ps -a

下面的命令可以清理掉所有处于终止状态的容器。
[root@a ~]# docker ps -a
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS                      PORTS               NAMES
6e7c29414a92        ubuntu:15.10        "/bin/bash"              13 hours ago        Up 2 minutes                                    pedantic_yonath
ab809d1b1bdf        ubuntu:15.10        "/bin/bash"              13 hours ago        Exited (130) 13 hours ago                       objective_zhukovsky
7c7321349118        ubuntu:15.10        "/bin/sh -c 'while t…"   13 hours ago        Exited (137) 13 hours ago                       keen_hoover
bfd7245d01d1        ubuntu:15.10        "/bin/bash"              13 hours ago        Exited (0) 13 hours ago                         cool_cori
...
...
...
[root@a ~]# docker container prune
WARNING! This will remove all stopped containers.
Are you sure you want to continue? [y/N] y
Deleted Containers:
ab809d1b1bdf0a299320ff7bf11738a752266f8b019130a266869b03cefb7f7f
...
...
...
[root@a ~]# docker ps -a
CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS              PORTS               NAMES
6e7c29414a92        ubuntu:15.10        "/bin/bash"         13 hours ago        Up 3 minutes                            pedantic_yonath

7、运行一个 web 应用

[root@a ~]# docker pull training/webapp # 载入镜像
[root@a ~]# docker run -d -P training/webapp python app.py
-d后台运行,-P指定使用的网络端口映射到我们使用的主机上
查看 WEB 应用容器
使用 docker ps 来查看我们正在运行的容器:
runoob@runoob:~#  docker ps
CONTAINER ID        IMAGE               COMMAND             ...        PORTS                 
d3d5e39ed9d3        training/webapp     "python app.py"     ...        0.0.0.0:32769->5000/tcp
查看 WEB 应用程序日志
docker logs [ID或者名字] 可以查看容器内部的标准输出。
docker logs -f bf08b7f2cd89
 * Running on http://0.0.0.0:5000/ (Press CTRL+C to quit)
192.168.239.1 - - [09/May/2016 16:30:37] "GET / HTTP/1.1" 200 -
192.168.239.1 - - [09/May/2016 16:30:37] "GET /favicon.ico HTTP/1.1" 404 -
-f: 让 docker logs 像使用 tail -f 一样来输出容器内部的标准输出。


我们也可以通过 -p 参数来设置不一样的端口:

runoob@runoob:~$ docker run -d -p 5000:5000 training/webapp python app.py
docker ps查看正在运行的容器
runoob@runoob:~#  docker ps
CONTAINER ID        IMAGE                             PORTS                     NAMES
bf08b7f2cd89        training/webapp     ...        0.0.0.0:5000->5000/tcp    wizardly_chandrasekhar
d3d5e39ed9d3        training/webapp     ...        0.0.0.0:32769->5000/tcp   xenodochial_hoov
容器内部的 5000 端口映射到我们本地主机的 5000 端口上。

8、网络端口的快捷方式

docker port 6e7c29414a92
5000/tcp -> 0.0.0.0:5000
docker port wizardly_chandrasekhar
5000/tcp -> 0.0.0.0:5000

9、查看WEB应用程序容器的进程

[root@a ~]# docker top 6e7c29414a92
UID                 PID                 PPID                C                   STIME               TTY                 TIME                CMD
root                1710                1693                0                   May16               ?                   00:00:00            /bin/bash

10、检查 WEB 应用程序使用 docker inspect 来查看 Docker 的底层信息。它会返回一个 JSON 文件记录着 Docker 容器的配置和状态信息。

runoob@runoob:~$ docker inspect wizardly_chandrasekhar
[
    {
        "Id": "bf08b7f2cd897b5964943134aa6d373e355c286db9b9885b1f60b6e8f82b2b85",
        "Created": "2018-09-17T01:41:26.174228707Z",
        "Path": "python",
        "Args": [
            "app.py"
        ],
        "State": {
            "Status": "running",
            "Running": true,
            "Paused": false,
            "Restarting": false,
            "OOMKilled": false,
            "Dead": false,
            "Pid": 23245,
            "ExitCode": 0,
            "Error": "",
            "StartedAt": "2018-09-17T01:41:26.494185806Z",
            "FinishedAt": "0001-01-01T00:00:00Z"
        },
......

11、查询最后一次创建的容器:docker ps -l 查询最后一次创建的容器:

[root@a ~]# docker ps -l 
CONTAINER ID        IMAGE                             PORTS                     NAMES
bf08b7f2cd89        training/webapp     ...        0.0.0.0:5000->5000/tcp    wizardly_chandrasekhar

参考:菜鸟教程


相关文章
|
6月前
|
Kubernetes Devops Docker
Kubernetes 和 Docker Swarm:现代 DevOps 的理想容器编排工具
本指南深入解析 Kubernetes 与 Docker Swarm 两大主流容器编排工具,涵盖安装、架构、网络、监控等核心维度,助您根据团队能力与业务需求精准选型,把握云原生时代的技术主动权。
579 115
|
6月前
|
JavaScript Docker 容器
使用Docker多阶段构建优化镜像大小
使用Docker多阶段构建优化镜像大小
469 100
|
6月前
|
缓存 安全 Linux
优化Docker镜像大小的多阶段构建实践
优化Docker镜像大小的多阶段构建实践
433 99
|
6月前
|
缓存 Docker 容器
优化Docker镜像大小的五个实用技巧
优化Docker镜像大小的五个实用技巧
572 98
|
5月前
|
监控 Kubernetes 安全
还没搞懂Docker? Docker容器技术实战指南 ! 从入门到企业级应用 !
蒋星熠Jaxonic,技术探索者,以代码为笔,在二进制星河中书写极客诗篇。专注Docker与容器化实践,分享从入门到企业级应用的深度经验,助力开发者乘风破浪,驶向云原生新世界。
还没搞懂Docker? Docker容器技术实战指南 ! 从入门到企业级应用 !
|
5月前
|
监控 Linux 调度
【赵渝强老师】Docker容器的资源管理机制
本文介绍了Linux CGroup技术及其在Docker资源管理中的应用。通过实例演示了如何利用CGroup限制应用程序的CPU、内存和I/O带宽使用,实现系统资源的精细化控制,帮助理解Docker底层资源限制机制。
513 6
|
5月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
671 5