CentOS 安裝 Docker

1、Docker 要求 CentOS 系統(tǒng)的內(nèi)核版本高于 3.10
通過(guò) uname -r 命令查看你當(dāng)前的內(nèi)核版本
[root@localhost ~]# uname -r
2、使用 root 權(quán)限登錄 Centos。確保 yum 包更新到最新。
[root@localhost ~]# yum -y update
3、卸載舊版本(如果安裝過(guò)舊版本的話)
[root@localhost ~]# yum remove docker docker-common docker-selinux docker-engine
4、安裝需要的軟件包, yum-util 提供yum-config-manager功能,另外兩個(gè)是devicemapper驅(qū)動(dòng)依賴的
[root@localhost ~]# yum install -y yum-utils device-mapper-persistent-data lvm2
5、安裝docker
[root@localhost ~]# yum install docker
6、啟動(dòng)并加入開機(jī)啟動(dòng)
[root@localhost ~]# systemctl start docker
[root@localhost ~]# systemctl enable docker
7、驗(yàn)證安裝是否成功(有client和service兩部分表示docker安裝啟動(dòng)都成功了)
[root@localhost ~]# docker version
創(chuàng)建一個(gè)鏡像
命令格式:docker run [OPTIONS] IMAGE [COMMAND] [ARG...]
通過(guò)run命令創(chuàng)建一個(gè)新的容器(container)
OPTIONS:
-d, --detach=false => 指定容器運(yùn)行于前臺(tái)還是后臺(tái),默認(rèn)為false
-i, --interactive=false => 打開STDIN,用于控制臺(tái)交互
-t, --tty=false => 分配tty設(shè)備,該可以支持終端登錄,默認(rèn)為false
-u, --user="" => 指定容器的用戶
-a, --attach=[] => 登錄容器(必須是以docker run -d啟動(dòng)的容器)
-w, --workdir="" => 指定容器的工作目錄
-c, --cpu-shares=0 => 設(shè)置容器CPU權(quán)重,在CPU共享場(chǎng)景使用
-e, --env=[ => 指定環(huán)境變量,容器中可以使用該環(huán)境變量
-m, --memory="" => 指定容器的內(nèi)存上限
-P, --publish-all=false => 指定容器暴露的端口
-p, --publish=[] => 指定容器暴露的端口
-h, --hostname="" => 指定容器的主機(jī)名
-v, --volume=[] => 給容器掛載存儲(chǔ)卷,掛載到容器的某個(gè)目錄
--volumes-from=[] => 給容器掛載其他容器上的卷,掛載到容器的某個(gè)目錄
--cap-add=[] => 添加權(quán)限
--cap-drop=[] => 刪除權(quán)限
--cidfile="" => 運(yùn)行容器后,在指定文件中寫入容器PID值,一種典型的監(jiān)控系統(tǒng)用法
--cpuset="" => 設(shè)置容器可以使用哪些CPU,此參數(shù)可以用來(lái)容器獨(dú)占CPU
--device=[] => 添加主機(jī)設(shè)備給容器,相當(dāng)于設(shè)備直通
--dns=[] => 指定容器的dns服務(wù)器
--dns-search=[] => 指定容器的dns搜索域名,寫入到容器的/etc/resolv.conf文件
--entrypoint="" => 覆蓋image的入口點(diǎn)
--env-file=[] => 指定環(huán)境變量文件,文件格式為每行一個(gè)環(huán)境變量
--expose=[] => 指定容器暴露的端口,即修改鏡像的暴露端口
--link=[] => 指定容器間的關(guān)聯(lián),使用其他容器的IP、env等信息
--lxc-conf=[] => 指定容器的配置文件,只有在指定--exec-driver=lxc時(shí)使用
--name="" => 指定容器名字,后續(xù)可以通過(guò)名字進(jìn)行容器管理,links特性需要使用名字
--net="bridge" => 容器網(wǎng)絡(luò)設(shè)置:
bridge => 使用docker daemon指定的網(wǎng)橋
host => 容器使用主機(jī)的網(wǎng)絡(luò)
container:NAME_or_ID > => 使用其他容器的網(wǎng)路,共享IP和PORT等網(wǎng)絡(luò)資源
none => 容器使用自己的網(wǎng)絡(luò)(類似--net=bridge),但是不進(jìn)行配置
--privileged=false => 指定容器是否為特權(quán)容器,特權(quán)容器擁有所有的capabilities
--restart="no" => 指定容器停止后的重啟策略:
no => 容器退出時(shí)不重啟
on-failure => 容器故障退出(返回值非零)時(shí)重啟
always => 容器退出時(shí)總是重啟
--rm=false => 指定容器停止后自動(dòng)刪除容器(不支持以docker run -d啟動(dòng)的容器)
--sig-proxy=true => 設(shè)置由代理接受并處理信號(hào),但是SIGCHLD、SIGSTOP和SIGKILL不能被代理
啟動(dòng)容器
命令格式:docker start [OPTIONS] CONTAINER [CONTAINER...]
docker start ID/NAME 可以根據(jù)容器的Name或者ID啟動(dòng)容器
OPTIONS:
-a, --attach => 連接容器并打印輸出或錯(cuò)誤
--detach-keys string
-i, --interactive => 啟動(dòng)容器并進(jìn)入交互模式
重啟容器
命令格式:docker restart[OPTIONS] CONTAINER [CONTAINER...]
docker restart ID/NAME 可以根據(jù)容器的Name或者ID重啟容器
OPTIONS:
-t, --time int => 停止容器前等待的時(shí)間(默認(rèn)10秒)
停止一個(gè)運(yùn)行的容器
命令格式:docker stop[OPTIONS] CONTAINER [CONTAINER...]
docker restart ID/NAME 可以根據(jù)容器的Name或者ID停止容器
OPTIONS:
-t, --time int => 停止容器前等待的時(shí)間(默認(rèn)10秒)
查看本地所有鏡像
命令格式:docker images [OPTIONS] [REPOSITORY[:TAG]]
OPTIONS:
-a => 列出本地所有的鏡像(含中間映像層,默認(rèn)情況下,過(guò)濾掉中間映像層);
--digests => 顯示鏡像的摘要信息;
-f => 顯示滿足條件的鏡像;
--format => 指定返回值的模板文件;
--no-trunc => 顯示完整的鏡像信息;
-q => 只顯示鏡像ID。

查看本地所有容器
命令格式:docker ps [OPTIONS]
docker ps -a
OPTIONS:
-a => 顯示所有的容器,包括未運(yùn)行的。
-f => 根據(jù)條件過(guò)濾顯示的內(nèi)容。
--format => 指定返回值的模板文件。
-l => 顯示最近創(chuàng)建的容器。
-n => 列出最近創(chuàng)建的n個(gè)容器。
--no-trunc => 不截?cái)噍敵觥?br> -q => 靜默模式,只顯示容器編號(hào)。
-s => 顯示總的文件大小。

拉取鏡像
命令格式:docker pull [OPTIONS] NAME[:TAG|@DIGEST]
docker pull imageName:tag
OPTIONS:
--all-tags , -a => 下載倉(cāng)庫(kù)所有鏡像
--disable-content-trust true => 跳過(guò)鏡像校驗(yàn)
--platform => 設(shè)置鏡像所屬平臺(tái), 如果有多個(gè)鏡像服務(wù)

刪除一個(gè)或多個(gè)容器
命令格式:docker rm [OPTIONS] CONTAINER [CONTAINER...]
OPTIONS:
-f => 通過(guò)SIGKILL信號(hào)強(qiáng)制刪除一個(gè)運(yùn)行中的容器
-l => 移除容器間的網(wǎng)絡(luò)連接,而非容器本身
-v => -v 刪除與容器關(guān)聯(lián)的卷
刪除本地一個(gè)或多個(gè)鏡像
命令格式:docker rmi [OPTIONS] IMAGE [IMAGE...]
OPTIONS:
-f => 強(qiáng)制刪除;
--no-prune => 不移除該鏡像的過(guò)程鏡像,默認(rèn)移除;
標(biāo)記本地鏡像,將其歸入某一倉(cāng)庫(kù)
命令格式:docker tag SOURCE_IMAGE[:TAG] TARGET_IMAGE[:TAG]
將本地的鏡像上傳到鏡像倉(cāng)庫(kù),要先登陸到鏡像倉(cāng)庫(kù)
命令格式:docker push [OPTIONS] NAME[:TAG]
OPTIONS:
--disable-content-trust => 忽略鏡像的校驗(yàn),默認(rèn)開啟
在運(yùn)行的容器中執(zhí)行命令
命令格式:docker exec [OPTIONS] CONTAINER COMMAND [ARG...]
OPTIONS:
-d => 分離模式: 在后臺(tái)運(yùn)行
-i => 即使沒有附加也保持STDIN 打開
-t => 分配一個(gè)偽終端

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容