阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

64位 CentOS下安装与启动 Docker

185次阅读
没有评论

共计 6621 个字符,预计需要花费 17 分钟才能阅读完成。

一、Docker 简介

Docker 提供了一个可以运行你的应用程序的封套(envelope),或者说容器,是轻量级的“容器引擎 + 映像仓库”,在 LXC(linux 轻量级容器)的基础上构建,可以运行任何应用程序。

Docker 扩展了 Linux 容器(Linux Containers),或着说 LXC,通过一个高层次的 API 为进程单独提供了一个轻量级的虚拟环境。Docker 利用了 LXC,cgroups 和 Linux 自己的内核。和传统的虚拟机不同的是,一个 Docker 容器并不包含一个单独的操作系统,而是基于已有的基础设施中操作系统提供的功能来运行的。

Docker 类似虚拟机的概念,但是与虚拟化技术的不同点在于下面几点:

1. 虚拟化技术依赖物理 CPU 和内存,是硬件级别的;而 docker 构建在操作系统上,利用操作系统的 containerization 技术,所以 docker 甚至可以在虚拟机上运行。

2. 虚拟化系统一般都是指操作系统镜像,比较复杂,称为“系统”;而 docker 开源而且轻量,称为“容器”,单个容器适合部署少量应用,比如部署一个 redis、一个 memcached。

3. 传统的虚拟化技术使用快照来保存状态;而 docker 在保存状态上不仅更为轻便和低成本,而且引入了类似源代码管理机制,将容器的快照历史版本一一记录,切换成本很低。

4. 传统的虚拟化技术在构建系统的时候较为复杂,需要大量的人力;而 docker 可以通过 Dockfile 来构建整个容器,重启和构建速度很快。更重要的是 Dockfile 可以手动编写,这样应用程序开发人员可以通过发布 Dockfile 来指导系统环境和依赖,这样对于持续交付十分有利。

5.Dockerfile 可以基于已经构建好的容器镜像,创建新容器。Dockerfile 可以通过社区分享和下载,有利于该技术的推广。

Docker 会像一个可移植的容器引擎那样工作。它把应用程序及所有程序的依赖环境打包到一个虚拟容器中,这个虚拟容器可以运行在任何一种 Linux 服务器上。这大大地提高了程序运行的灵活性和可移植性,无论需不需要许可、是在公共云还是私密云、是不是裸机环境等等。

Docker 也是一个云计算平台,它利用 Linux 的 LXC、AUFU、Go 语言、cgroup 实现了资源的独立,可以很轻松的实现文件、资源、网络等隔离,其最终的目标是实现类似 PaaS 平台的应用隔离。

docker.io 的核心层由以下几个部分组成:

1、可执行程序,“/usr/bin/docker”

2、docker.io 网站上有一系列创建好的操作系统和应用程序映像

3、AUFS(另一个统一文件系统)来实现文件系统的快照,文件变化,控制只读或读写的需求。

4、LXC(Linux 轻量级容器)

5、Cgroups(各种资源和命名空间的管理)

更多 Docker 相关教程见以下内容

Docker 安装应用(CentOS 6.5_x64) http://www.linuxidc.com/Linux/2014-07/104595.htm

Ubuntu 14.04 安装 Docker  http://www.linuxidc.com/linux/2014-08/105656.htm

Ubuntu 使用 VNC 运行基于 Docker 的桌面系统  http://www.linuxidc.com/Linux/2015-08/121170.htm

Docker 开发平台的构建  http://www.linuxidc.com/Linux/2017-03/141592.htm

Ubuntu 15.04 下安装 Docker  http://www.linuxidc.com/Linux/2015-07/120444.htm

在 Ubuntu Trusty 14.04 (LTS) (64-bit)安装 Docker http://www.linuxidc.com/Linux/2014-10/108184.htm

在 Ubuntu 15.04 上如何安装 Docker 及基本用法 http://www.linuxidc.com/Linux/2015-09/122885.htm

Ubuntu 16.04 上 Docker 使用手记 http://www.linuxidc.com/Linux/2016-12/138490.htm

二、安装

1、取消 selinux,因为它会干扰 lxc 的正常功能

sudo vim /etc/selinux/config

SELINUX=disabled

SELINUXTYPE=targeted

64 位 CentOS 下安装与启动 Docker

2、配置 Fedora EPEL 源

[root@YTX_18_93 ~]# sudo yum install http://ftp.riken.jp/Linux/fedora/epel/6/i386/epel-release-6-8.noarch.rpm

64 位 CentOS 下安装与启动 Docker

3、配置 hop5.in 源

[root@YTX_18_93 ~]# cd /etc/yum.repos.d

[root@YTX_18_93 yum.repos.d]# sudo wget http://www.hop5.in/yum/el6/hop5.repo

64 位 CentOS 下安装与启动 Docker

4、安装 docker-io

[root@YTX_18_93 ~]# yum install docker-io

64 位 CentOS 下安装与启动 Docker

64 位 CentOS 下安装与启动 Docker

64 位 CentOS 下安装与启动 Docker

5、检查安装情况

[root@YTX_18_93 ~]# docker -h

64 位 CentOS 下安装与启动 Docker

6、启动 docker

[root@YTX_18_93 ~]# service docker start

Starting docker:                                          [OK]

更多详情见请继续阅读下一页的精彩内容:http://www.linuxidc.com/Linux/2017-03/141714p2.htm

三、docker 常用命令

1、将 docker 加入开机启动:chkconfig docker on

2、基本信息查看:docker version(查看 docker 的版本号,包括客户端、服务端、依赖的 Go 等)

                      docker info:查看系统 (docker) 层面信息,包括管理的 images, containers 数等

3、搜索镜像:docker search <image>:在 docker index 中搜索 image

4、下载镜像:docker pull <image>:从 docker registry server 中下拉 image

5、查看镜像:

    docker images:列出 images

    docker images -a:列出所有的 images(包含历史)

    docker images –tree:显示镜像的所有层(layer)

    docker rmi  <image ID>:删除一个或多个 image

6、查看容器:

    docker ps:列出当前所有正在运行的 container
    docker ps -l:列出最近一次启动的 container
    docker ps -a:列出所有的 container(包含历史,即运行过的 container)
    docker ps -q:列出最近一次运行的 container ID

7、启动容器:

    docker start/stop/restart <container> 开启 / 停止 / 重启 container

    docker start [container_id]:再次运行某个 container(包括历史 container)
    docker attach [container_id]:连接一个正在运行的 container 实例(即实例必须为 start 状态,可以多个窗口同时 attach 一个 container 实例)
    docker start -i <container>:启动一个 container 并进入交互模式(相当于先 start,在 attach)

    docker run -i -t <image> /bin/bash:使用 image 创建 container 并进入交互模式, login shell 是 /bin/bash
    docker run -i -t -p <host_port:contain_port>:映射 HOST 端口到容器,方便外部访问容器内服务,host_port 可以省略,省略表示把 container_port 映射到一个动态端口。

8、删除容器:

    docker rm <container…>:删除一个或多个 container
    docker rm `docker ps -a -q`:删除所有的 container
    docker ps -a -q | xargs docker rm:同上, 删除所有的 container

9、通过容器生成新的镜像:

    docker commit <container> [repo:tag] 将一个 container 固化为一个新的 image,后面的 repo:tag 可选。

10、docker 文件存放目录:

    /var/lib/docker

    containers 目录当然就是存放容器(container)了,graph 目录存放镜像,文件层(file system layer)存放在 graph/imageid/layer 路径下

11、查看 root 密码:

    docker 容器启动时的 root 用户的密码是随机分配的。所以,通过这种方式就可以得到容器的 root 用户的密码了,
  docker logs 5817938c3f6e 2>&1 | grep ‘User: ‘ | tail -n1

12、根据 Dockerfile 构建出一个容器:

$docker build -t image_name Dockerfile_path 

13、要获取容器的输出信息(docker logs):
      docker logs container_name

14、交互式进入容器中:

$docker run -i -t image_name /bin/bash 

15、查看时间:

  date

16、修改容器时间:

Docker run -d–name[] -v /etc/localtime:/etc/localtime:ro …

docker cp/etc/localtime:【容器 ID 或者 NAME】/etc/localtime

四、安装启动 docker 出错情况

重启 docker 服务器后遇到 ‘device or resource busy’ 错误:

解决方式是先找出没有 umount 的路径

cat /proc/mounts |grep “mapper/docker” | awk ‘{print $2}’

然后依次 umount

Docker 的详细介绍:请点这里
Docker 的下载地址:请点这里

本文永久更新链接地址:http://www.linuxidc.com/Linux/2017-03/141714.htm

一、Docker 简介

Docker 提供了一个可以运行你的应用程序的封套(envelope),或者说容器,是轻量级的“容器引擎 + 映像仓库”,在 LXC(linux 轻量级容器)的基础上构建,可以运行任何应用程序。

Docker 扩展了 Linux 容器(Linux Containers),或着说 LXC,通过一个高层次的 API 为进程单独提供了一个轻量级的虚拟环境。Docker 利用了 LXC,cgroups 和 Linux 自己的内核。和传统的虚拟机不同的是,一个 Docker 容器并不包含一个单独的操作系统,而是基于已有的基础设施中操作系统提供的功能来运行的。

Docker 类似虚拟机的概念,但是与虚拟化技术的不同点在于下面几点:

1. 虚拟化技术依赖物理 CPU 和内存,是硬件级别的;而 docker 构建在操作系统上,利用操作系统的 containerization 技术,所以 docker 甚至可以在虚拟机上运行。

2. 虚拟化系统一般都是指操作系统镜像,比较复杂,称为“系统”;而 docker 开源而且轻量,称为“容器”,单个容器适合部署少量应用,比如部署一个 redis、一个 memcached。

3. 传统的虚拟化技术使用快照来保存状态;而 docker 在保存状态上不仅更为轻便和低成本,而且引入了类似源代码管理机制,将容器的快照历史版本一一记录,切换成本很低。

4. 传统的虚拟化技术在构建系统的时候较为复杂,需要大量的人力;而 docker 可以通过 Dockfile 来构建整个容器,重启和构建速度很快。更重要的是 Dockfile 可以手动编写,这样应用程序开发人员可以通过发布 Dockfile 来指导系统环境和依赖,这样对于持续交付十分有利。

5.Dockerfile 可以基于已经构建好的容器镜像,创建新容器。Dockerfile 可以通过社区分享和下载,有利于该技术的推广。

Docker 会像一个可移植的容器引擎那样工作。它把应用程序及所有程序的依赖环境打包到一个虚拟容器中,这个虚拟容器可以运行在任何一种 Linux 服务器上。这大大地提高了程序运行的灵活性和可移植性,无论需不需要许可、是在公共云还是私密云、是不是裸机环境等等。

Docker 也是一个云计算平台,它利用 Linux 的 LXC、AUFU、Go 语言、cgroup 实现了资源的独立,可以很轻松的实现文件、资源、网络等隔离,其最终的目标是实现类似 PaaS 平台的应用隔离。

docker.io 的核心层由以下几个部分组成:

1、可执行程序,“/usr/bin/docker”

2、docker.io 网站上有一系列创建好的操作系统和应用程序映像

3、AUFS(另一个统一文件系统)来实现文件系统的快照,文件变化,控制只读或读写的需求。

4、LXC(Linux 轻量级容器)

5、Cgroups(各种资源和命名空间的管理)

更多 Docker 相关教程见以下内容

Docker 安装应用(CentOS 6.5_x64) http://www.linuxidc.com/Linux/2014-07/104595.htm

Ubuntu 14.04 安装 Docker  http://www.linuxidc.com/linux/2014-08/105656.htm

Ubuntu 使用 VNC 运行基于 Docker 的桌面系统  http://www.linuxidc.com/Linux/2015-08/121170.htm

Docker 开发平台的构建  http://www.linuxidc.com/Linux/2017-03/141592.htm

Ubuntu 15.04 下安装 Docker  http://www.linuxidc.com/Linux/2015-07/120444.htm

在 Ubuntu Trusty 14.04 (LTS) (64-bit)安装 Docker http://www.linuxidc.com/Linux/2014-10/108184.htm

在 Ubuntu 15.04 上如何安装 Docker 及基本用法 http://www.linuxidc.com/Linux/2015-09/122885.htm

Ubuntu 16.04 上 Docker 使用手记 http://www.linuxidc.com/Linux/2016-12/138490.htm

二、安装

1、取消 selinux,因为它会干扰 lxc 的正常功能

sudo vim /etc/selinux/config

SELINUX=disabled

SELINUXTYPE=targeted

64 位 CentOS 下安装与启动 Docker

2、配置 Fedora EPEL 源

[root@YTX_18_93 ~]# sudo yum install http://ftp.riken.jp/Linux/fedora/epel/6/i386/epel-release-6-8.noarch.rpm

64 位 CentOS 下安装与启动 Docker

3、配置 hop5.in 源

[root@YTX_18_93 ~]# cd /etc/yum.repos.d

[root@YTX_18_93 yum.repos.d]# sudo wget http://www.hop5.in/yum/el6/hop5.repo

64 位 CentOS 下安装与启动 Docker

4、安装 docker-io

[root@YTX_18_93 ~]# yum install docker-io

64 位 CentOS 下安装与启动 Docker

64 位 CentOS 下安装与启动 Docker

64 位 CentOS 下安装与启动 Docker

5、检查安装情况

[root@YTX_18_93 ~]# docker -h

64 位 CentOS 下安装与启动 Docker

6、启动 docker

[root@YTX_18_93 ~]# service docker start

Starting docker:                                          [OK]

更多详情见请继续阅读下一页的精彩内容:http://www.linuxidc.com/Linux/2017-03/141714p2.htm

正文完
星哥说事-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-21发表,共计6621字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中