docker --- 操作系统

  目前最常用的Linux发行版包括Ubuntu系列和CentOS系列。
  
  前者以自带软件包版本较新而出名;后者则宣称运行更稳定一些。选择哪个操作系统取决于读者的具体需求。
  同时,社区还推出了完全基于Docker的Linux发行版CoreOS。
  
  使用Docker,读者只需要一个命令就能得到Linux发行版的Docker镜像,这是以往包括各种虚拟化技术都难以实现的。
  虽然Docker的镜像一般都很精简,但是它几乎可以实现所有的Linux服务器系统能实现的功能。
  
  本章将介绍如何使用Docker安装和使用Busybox、Debian/Ubuntu、CentOS/Fedora、CoreOS等操作系统。


  BusyBox
    BusyBox是一个集成了一百多个最常用的Linux命令和工具的软件工具箱,它在单一的可执行文件中提供了精简的Uninx工具集。
    BusyBox可运行于多款POSIX环境的操作系统中,如Linux、Hurd、FreeBSD等。
    
    BusyBox既包含了一些简单的实用工具,如cat和echo,也包含了一些更大,更复杂的工具,如grep、find、mount、及telnet等。可以说BusyBox是Linux系统的瑞士军刀。

  使用官方镜像
    在DockerHub中搜索BusyBox相关镜像
    --------------------------------------------------------------------
    [docker@localhost ~]$ sudo docker search busybox
    INDEX       NAME                                     DESCRIPTION                                     STARS     OFFICIAL   AUTOMATED
    docker.io   docker.io/busybox                        Busybox base image.                             1282      [OK]       
    docker.io   docker.io/busybox                        Busybox base image.                             1282      [OK]       
    docker.io   docker.io/progrium/busybox                                                               66                   [OK]
    docker.io   docker.io/progrium/busybox                                                               66                   [OK]
    docker.io   docker.io/hypriot/rpi-busybox-httpd      Raspberry Pi compatible Docker Image with ...   41                   
    ...
    --------------------------------------------------------------------
    大家可以看到最受环境的镜像同事带有official标记,说明它是官方镜像。
    
    下面使用【docker pull】命令下载这个镜像;
    --------------------------------------------------------------------
    [docker@localhost ~]$ sudo docker pull busybox
    Using default tag: latest
    Trying to pull repository docker.io/library/busybox ... 
    sha256:141c253bc4c3fd0a201d32dc1f493bcf3fff003b6df416dea4f41046e0f37d47: Pulling from docker.io/library/busybox
    07a152489297: Pull complete 
    Digest: sha256:141c253bc4c3fd0a201d32dc1f493bcf3fff003b6df416dea4f41046e0f37d47
    Status: Downloaded newer image for docker.io/busybox:latest
    [docker@localhost ~]$ sudo docker images 
    REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
    docker.io/busybox   latest              8c811b4aec35        4 weeks ago         1.15 MB
    --------------------------------------------------------------------
    如果不指定标签信息,则docker会下载最新版本的BusyBox镜像,可以看到Busybox镜像十分精巧,大小只有1.15M。
    
  运行Busybox
    启动一个Busybox容器,并在容器中执行grep命令。
    --------------------------------------------------------------------
    [docker@localhost ~]$ sudo docker run  -it docker.io/busybox
    / # grep
    BusyBox v1.28.4 (2018-05-22 17:00:17 UTC) multi-call binary.
    Usage: grep [-HhnlLoqvsriwFE] [-m N] [-A/B/C N] PATTERN/-e PATTERN.../-f FILE [FILE]...
    Search for PATTERN in FILEs (or stdin)
    -H  Add 'filename:' prefix
    -h  Do not add 'filename:' prefix
    -n  Add 'line_no:' prefix
    -l  Show only names of files that match
    -L  Show only names of files that don't match
    -c  Show only count of matching lines
    -o  Show only the matching part of line
    -q  Quiet. Return 0 if PATTERN is found, 1 otherwise
    -v  Select non-matching lines
    -s  Suppress open and read errors
    -r  Recurse
    -i  Ignore case
    -w  Match whole words only
    -x  Match whole lines only
    -F  PATTERN is a literal (not regexp)
    -E  PATTERN is an extended regexp
    -m N    Match up to N times per file
    -A N    Print N lines of trailing context
    -B N    Print N lines of leading context
    -C N    Same as '-A N -B N'
    -e PTRN Pattern to match
    -f FILE Read pattern from file
    --------------------------------------------------------------------
    查看容器内的挂载信息
    --------------------------------------------------------------------
    / # mount
    overlay on / type overlay (rw,relatime,lowerdir=/var/lib/docker/overlay2/l/73Z7NNV64TJNSFRXVWO2JS2Y66:/var/lib/docker/overlay2/l/CWQB3D6WK5CCO5WPVTH5YK7QYO,upperdir=/var/lib/docker/overlay2/c6fdee4a6e55aae6b47ad71784e12eee13791444e7732ee3d988535e7b63ad60/diff,workdir=/var/lib/docker/overlay2/c6fdee4a6e55aae6b47ad71784e12eee13791444e7732ee3d988535e7b63ad60/work)
    proc on /proc type proc (rw,nosuid,nodev,noexec,relatime)
    tmpfs on /dev type tmpfs (rw,nosuid,mode=755)
    devpts on /dev/pts type devpts (rw,nosuid,noexec,relatime,gid=5,mode=620,ptmxmode=666)
    sysfs on /sys type sysfs (ro,nosuid,nodev,noexec,relatime)
    tmpfs on /sys/fs/cgroup type tmpfs (ro,nosuid,nodev,noexec,relatime,mode=755)
    cgroup on /sys/fs/cgroup/systemd type cgroup (ro,nosuid,nodev,noexec,relatime,xattr,name=systemd)
    cgroup on /sys/fs/cgroup/hugetlb type cgroup (ro,nosuid,nodev,noexec,relatime,hugetlb)
    cgroup on /sys/fs/cgroup/freezer type cgroup (ro,nosuid,nodev,noexec,relatime,freezer)
    cgroup on /sys/fs/cgroup/net_cls,net_prio type cgroup (ro,nosuid,nodev,noexec,relatime,net_cls,net_prio)
    cgroup on /sys/fs/cgroup/cpu,cpuacct type cgroup (ro,nosuid,nodev,noexec,relatime,cpu,cpuacct)
    cgroup on /sys/fs/cgroup/pids type cgroup (ro,nosuid,nodev,noexec,relatime,pids)
    cgroup on /sys/fs/cgroup/devices type cgroup (ro,nosuid,nodev,noexec,relatime,devices)
    cgroup on /sys/fs/cgroup/blkio type cgroup (ro,nosuid,nodev,noexec,relatime,blkio)
    cgroup on /sys/fs/cgroup/cpuset type cgroup (ro,nosuid,nodev,noexec,relatime,cpuset)
    cgroup on /sys/fs/cgroup/memory type cgroup (ro,nosuid,nodev,noexec,relatime,memory)
    ...
    --------------------------------------------------------------------
    Busybox镜像虽然小巧,但是提供了常见的Linux命令,大家可以用它快速熟悉Linux命令。


你可能感兴趣的:(docker --- 操作系统)