CenOS 6.5下安裝docker

Docker是一個開源的應用容器引擎,能夠輕鬆的爲任何應用建立一個輕量級的、可移植的、自給自足的容器。利用Linux的LXC、AUFS、Go語言、cgroup實現了資源的獨立,能夠很輕鬆的實現文件、資源、網絡等隔離,其最終的目標是實現相似PaaS平臺的應用隔離。node

    Docker值得關注的特性:linux

  • 文件系統隔離:每一個進程容器運行在一個徹底獨立的根文件系統裏。web

  • 資源隔離:系統資源,像CPU和內存等能夠分配到不一樣的容器中,使用cgroup。docker

  • 網絡隔離:每一個進程容器運行在本身的網絡空間,虛擬接口和IP地址。shell

  • 日誌記錄:Docker將會收集和記錄每一個進程容器的標準流(stdout/stderr/stdin),用於實時檢索或批量檢索。數據庫

  • 變動管理:容器文件系統的變動能夠提交到新的映像中,並可重複使用以建立更多的容器。無需使用模板或手動配置。centos

  • 交互式shell:Docker能夠分配一個虛擬終端並關聯到任何容器的標準輸入上,例如運行一個一次***互shell。bash

    Docker一般用於以下場景:網絡

  • web應用的自動化打包和發佈;
    ide

  • 自動化測試和持續集成、發佈;

  • 在服務型環境中部署和調整數據庫或其餘的後臺應用;

  • 從頭編譯或者擴展示有的OpenShift或Cloud Foundry平臺來搭建本身的PaaS環境。

    本文介紹如何在RedHat/CentOS環境下安裝Docker。官方文檔要求Linux kernel至少3.8以上,且docker只能運行在64位的系統中。因爲RHEL6和CentOS6的內核版本爲2.6,所以必需要先升級內核。

    下面以CentOS6.5(64位)爲例,介紹下docker安裝步驟和使用方法:

1、升級內核(帶aufs模塊)

    一、yum安裝帶aufs模塊的3.10內核(或到這裏下載kernel手動安裝:http://down.51cto.com/data/1903250

1
2
3
cd  /etc/yum .repos.d 
wget http: //www .hop5. in /yum/el6/hop5 .repo
yum  install  kernel-ml-aufs kernel-ml-aufs-devel

    二、修改grub的主配置文件/etc/grub.conf,設置default=0,表示第一個title下的內容爲默認啓動的kernel(通常新安裝的內核在第一個位置)。

wKiom1R1XF_BWoKPAAPcDXlNx-A406.jpg

    三、重啓系統,這時候你的內核就成功升級了。

1
2
[root@localhost ~] # uname -r
3.10.5-3.el6.x86_64

    查看內核是否支持aufs:

1
2
[root@localhost ~] # grep aufs /proc/filesystems
nodev    aufs

2、安裝docker

    一、首先關閉selinux:
1
2
setenforce 0
sed  -i  '/^SELINUX=/c\SELINUX=disabled'  /etc/selinux/config

    二、在Fedora EPEL源中已經提供了docker-io包,下載安裝epel:

1
2
rpm -ivh http: //mirrors .sohu.com /fedora-epel/6/x86_64/epel-release-6-8 .noarch.rpm
sed  -i  's/^mirrorlist=https/mirrorlist=http/'  /etc/yum .repos.d /epel .repo

    三、yum安裝docker-io:

1
yum -y  install  docker-io

wKioL1R2oWOCRxohAAONGaU5ZIs803.jpg

    四、啓動docker:

1
service docker start

wKioL1R1QBaDsuZ9AACThIbJ9Eo954.jpg

    五、查看docker版本:

wKioL1R1ejWCsWMqAAG***-s-Uk526.jpg

    查看docker日誌:

1
cat  /var/log/docker

3、docker命令的使用

    一、直接輸入docker命令來查看全部的Options和Commands。

    查看某一個command的詳細使用方法:docker COMMAND --help

wKiom1R1dHbzIJLfAADQR3jiJtM669.jpg

    二、搜索可用的docker鏡像:docker search NAME

wKiom1R1Z2eDpDhPAAS6paTJagQ409.jpg

    三、下載鏡像:docker pull NAME[:TAG]

    好比獲取最新的centos鏡像:docker pull centos:latest

    注意:這裏要寫用docker search搜索到的完整的鏡像名。
    四、查看安裝的鏡像:docker p_w_picpaths [NAME]

wKiom1R1c7LgL0uwAADPCgcMWqw663.jpg

    五、在docker容器中運行命令:docker run IMAGE [COMMAND] [ARG...]

    docker run命令有兩個參數,一個是鏡像名,一個是要在鏡像中運行的命令。

    注意:IMAGE=REPOSITORY[:TAG],若是IMAGE參數不指定鏡像的TAG,默認TAG爲latest。

    在剛剛下載的鏡像中輸出"hello word":docker run centos echo 'hello world!'wKiom1R1c3fj6XQFAABqRD8XV6o479.jpg

    六、列出容器:docker ps -a

    查看最近生成的容器:docker ps -l

    查看正在運行的容器:docker ps

    七、顯示容器的標準輸出:docker logs CONTAINERID

    無需拷貝完整的id,通常寫最開始的三至四個字符便可。

wKiom1R1m_STX0iUAAGRjbJx35o891.jpg

    八、在容器中安裝新程序,好比安裝ifconfig命令(centos7默認沒有ifconfig):docker run centos yum install net-tools -y

    若是yum不指定-y參數的話,yum命令會進入交互模式,須要用戶輸入命令來進行確認,在docker環境中是沒法響應這種交互的。但使用docker run的-i -t參數就會響應這種交互,用戶能夠輸入命令了,好比:docker run -i -t centos yum install net-tools

    九、保存對容器的修改並生成新的鏡像:docker commit CONTAINERID [REPOSITORY[:TAG]]

    REPOSITORY參數能夠是新的鏡像名字,也能夠是舊的鏡像名;若是和舊的鏡像名和TAG都相同,會覆蓋掉舊的鏡像。

wKiom1R1lhuQSjeFAAYdjYDJl7g665.jpg

    十、中止正在運行的容器:docker stop CONTAINERID

    默認等待10秒鐘再殺死指定容器。可使用-t參數來設置等待時間。

wKioL1R1eVaAon28AAFM9IS_WPk474.jpg

    十一、查看容器或鏡像的詳細信息:docker inspect CONTAINERID|IMAGE

    參數能夠是容器的ID或者是鏡像名(NAME:TAG)。

wKioL1R1e8uSeslZAAIcWL54yBA017.jpg

    十二、刪除容器:docker rm CONTAINERID

    查看全部容器ID:docker ps -a -q

    刪除全部的容器:docker rm $(docker ps -a -q)

    1三、刪除鏡像:docker rmi IMAGE

wKioL1R1oW-gqMmrAALqpTRiwN8314.jpg

    14.查看docker的信息,包括Containers和Images數目、kernel版本等。

wKiom1R1sCDBp_afAAEBBnNOVBo956.jpg

4、建立容器並登入的操做

    一、建立一個新容器並登入:docker run -i -t IMAGE /bin/bash

    使用p_w_picpath建立container並進入交互模式,login shell是/bin/bash,如今能夠自由的對容器進行操做了。最後使用exit退出容器。

    注意:若是IMAGE參數不指定TAG,默認TAG爲latest。

    二、啓動一個退出的容器:docker start CONTAINERID

    三、attach到運行中的容器:docker attach CONTAINERID

wKiom1R1pBST_fU7AAOkWUKDLA0506.jpg

相關文章
相關標籤/搜索