docker

  • Docker

    docker基于容器技术的轻量级虚拟化解决方案,docker是容器引擎
    
    • 1、NameSpase 资源隔离


      • PID - 进程编号 内核版本:2.6.24
      • NET - 网络设备、网络协议栈、端口等 内核版本:2.6.29
      • IPC - 信号量、消息队列、共享内存 内核版本:2.6.19
      • MOUNT - 文件系统,挂载点 内核版本:2.4.19
      • UTS - 主机名和主机域 内核版本:2.6.19
      • USER - 操作进程的用户和用户组 内核版本:3.8.x

        所以内核版本要在3.8.x以上

    • Docker 引擎

      • Docker 引擎主要有两个版本:企业版本(EE)和社区版本(CE)
    • 2、用例

      操作命令

      • 关闭SELINUX

        setenforce 0
        vim /etc/selinux/config
        
      • 关闭防火墙

        systemctl stop firewalld
        
      • 安装配置源

        yum install epel-release
        yum repolist
        
      • 安装yum工具

        yum install -y yum-utils
        
      • 添加docker-ce阿里源

        yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
        
      • 查看源中的docker-ce信息

        yum list docker-ce --show-duplicates
        
      • 安装docker

        yum install docker-ce-19.03.4-3.el7 -y
        
      • 启动docker

        systemctl enable docker
        
      • 编辑docker daemon.json配置

        vim /etc/docker/daemon.json
        {
          "graph":"/data/docker",  ###工作目录
          "storage-driver": "overlay2",  ###存储驱动overlay2
          "insecure-registries": ["registry.access.redhat.com","quay.io"],  ###不安全的源, 私有仓库填写位置
          "registry-mirrors": ["https://q2qgrodke.mirror.aliyuncs.com"],   ###配置国内的加速源
          "bip":"172.168.100.148/24",###docker的ip地址,建议使用跟宿主机的ip地址后两位一样,方便查找
          "exec-opts": ["native.cgroupdriver=systemd"],  ###cgroupdriver谷歌将管理cpu内存等资源控制方法,写到内核里的
          "live-restore": true ###docker容器引擎死掉死,docker容器还能活着,不影响容器使用
        

      }

      • 重启docker

        systemctl restart docker
        
      • 报错查询命令

        docker info 
        
      • 启动容器

        docker run hello-world 
        
      • docker的运行步骤

        Hello from Docker!
        This message shows that your installation appears to be working correctly.
        
        To generate this message, Docker took the following steps:
        1. The Docker client contacted the Docker daemon.
        2. The Docker daemon pulled the "hello-world" image from the Docker Hub.(amd64)
        3. The Docker daemon created a new container from that image which runs the executable that produces the output you are currently reading.
        4. The Docker daemon streamed that output to the Docker client, which sent it to your terminal.
        
    • 3、镜像

      • 镜像结构

        ${registry_name}/${repository_name}/${image_name}:${tag_name}
        远端仓库网址/分类的仓库的名字/镜像名称:标签的名称
        
      • 例如

        docker.io/library/alpine:3.10.1 
        
      • 镜像管理

        • 查询镜像

          docker search alpine      
          alpine --- linux的一种小的发行版
          
        • 下载镜像

          docker pull alpine
          
        • 查询镜像

          docker images
          
        • 给镜像打标签

        • 创建一个docker hub public仓库

          https://hub.docker.com/ 
          reateaRepository
          Push container images to a repository on
          Docker Hub.
          
          
          Docker Hub Basics
          Watch the guide on how to create and
          push your first image into Docker Hub
          repository.
          
          Language-SpecificGuides
          Learn how to containerize language-
          specific applications using Docker.
          
        • 创建完成后,后台链接仓库

          docker login docker.io
          
        • 更改镜像标签

          docker tag  965ea09ff2eb  docker.io/aluckylive/alpine:v3.10.3
          docker tag feb5d9fea6a5 docker.io/aluckylive/hello-world:0.0.1
          
        • 上传到public仓库

          docker push docker.io/aluckylive/alpine:v3.10.3
          docker push docker.io/aluckylive/hello-world:0.0.1
          
        • 删除本地镜像标签(以下命令只能删除标签)

          docker rmi docker.io/aluckylive/alpine:latest
          
        • 彻底删除本地镜像

          docker rmi -f 965ea09ff2eb
          
        • 从自己的public仓库下载镜像

          docker pull aluckylive/alpine:latest
          
      • 容器管理

        • 查看docker容器的运行情况

          docker ps -a
          
        • 启动容器(运行镜像)

          docker run 是日常用的最频繁的命令之一,同样也是较为复杂的命令之一
          命令格式:docker run [OPTIONS] IMAGE [COMMAND] [ARG]
          OPTIONS:选项
          -i:表示启动一个交互式的容器,并持续打开标准输入
          -t:表示使用终端关联到容器的标准标准的输入输出上
          -d:表示将容器放置后台运行
          -rm:表示退出后删除容器
          --name:表示定容器唯一的名称
          IMAGE:表示要运行的镜像
          COMMAND:表示启动容器时要运行的命令*
          
        • 操作实例

          • 交互式启动

            [root@192 ~]# docker run -it aluckylive/alpine:latest /bin/sh
            / # ip a
            1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN qlen 1000
            link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
            inet 127.0.0.1/8 scope host lo
            valid_lft forever preferred_lft forever
            4: eth0@if5: <BROADCAST,MULTICAST,UP,LOWER_UP,M-DOWN> mtu 1500 qdisc noqueue state UP 
            link/ether 02:42:ac:a8:64:01 brd ff:ff:ff:ff:ff:ff
            inet 172.168.100.1/24 brd 172.168.100.255 scope global eth0
            valid_lft forever preferred_lft forever
            / # cat /etc/issue 
            Welcome to Alpine Linux 3.10
            Kernel \r on an \m (\l)
            / # exit
            [root@192 ~]# 
            
            [root@192 ~]# docker ps -a
            CONTAINER ID   IMAGE                      COMMAND     CREATED         STATUS                       PORTS     NAMES
            49bb63362322   aluckylive/alpine:latest   "/bin/sh"   6 minutes ago   Exited (127) 5 minutes ago             recursing_mccarthy
            
            使用容器使用exit退出后,在查看容器时,状态为为启动状态。 
            
          • 非交互式模式启动一个后台容器

            [root@192 ~]# docker run -d aluckylive/alpine:latest /bin/sleep 300
            d202035ba6fc6cc1dde27949454a8204901c770c13d24ba5c2ddf5b92301cc8a 
            [root@192 ~]# docker ps -a
            CONTAINER ID   IMAGE                      COMMAND            CREATED          STATUS                        PORTS     NAMES
            d202035ba6fc   aluckylive/alpine:latest   "/bin/sleep 300"   17 seconds ago   Up 16 seconds                           nervous_fermat
            [root@192 ~]# docker run -d --name mytest aluckylive/alpine:latest /bin/sleep 300
            39689351e8c367d16632876d7c08cf5936d2e776b245a73bb4cdde095cd62c5f
            [root@192 ~]# docker ps -a
            CONTAINER ID   IMAGE                      COMMAND            CREATED          STATUS                        PORTS     NAMES
            39689351e8c3   aluckylive/alpine:latest   "/bin/sleep 300"   14 seconds ago   Up 13 seconds                           mytest
            
          • 查看容器在宿主机上的进程

            [root@192 ~]# ps aux |grep sleep|grep -v grep
            root     21996  0.0  0.0   1540   248 ?        Ss   02:06   0:00 /bin/sleep 300
            
          • 进入容器,指定容器名称或id

            [root@192 ~]# docker exec -it  mytest /bin/sh
            / # ps -a
            PID   USER     TIME  COMMAND
            1 root      0:00 /bin/sleep 300
            6 root      0:00 /bin/sh
            11 root      0:00 ps -a
            / # 
            
          • 容器的start/restart/stop

            docker start mystest
            
          • 删除容器

            docker rm mytest
            当容器启动状态时删除不掉这时加-f
            docker rm -f mytest
            [root@192 ~]# docker run -d --name mytest aluckylive/alpine:latest /bin/sleep 300
            47477bbbde2745a0e439314c59e1f08c499d713a1400b5537b61167792ac2c2b
            [root@192 ~]# docker rm mytest
            Error response from daemon: You cannot remove a running container 47477bbbde2745a0e439314c59e1f08c499d713a1400b5537b61167792ac2c2b. Stop the container before attempting removal or force remove
            [root@192 ~]# docker rm -f mytest
            mytest
            
          • 生产环境删除退出的容器

            [root@192 ~]# for i in `docker ps -a|grep -i exit |sed '1d' |awk '{print $1}'`;do docker rm -f  $i; done
            49bb63362322
            c3f8d0dae58b
            9c71663e7e17
            [root@192 ~]# docker ps -a
            CONTAINER ID   IMAGE                      COMMAND            CREATED          STATUS                      PORTS     NAMES
            d202035ba6fc   aluckylive/alpine:latest   "/bin/sleep 300"   29 minutes ago   Exited (0) 24 minutes ago             nervous_fermat
            
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,772评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,458评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,610评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,640评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,657评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,590评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,962评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,631评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,870评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,611评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,704评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,386评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,969评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,944评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,179评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,742评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,440评论 2 342

推荐阅读更多精彩内容