Docker基本命令及原理

docker run原理圖

run原理圖

docker是怎么工作的?

圖片.png
圖片.png
圖片.png

docker的常用命令

https://www.cnblogs.com/DeepInThought/p/10896790.html

1、Docker容器信息

##查看docker容器版本
docker version
##查看docker容器信息
docker info
##查看docker容器幫助
docker --help

2、鏡像操作

##列出本地images
docker images
##含中間映像層
docker images -a
##只顯示鏡像ID
docker images -q
##含中間映像層
docker images -qa 
##顯示鏡像摘要信息(DIGEST列)
docker images --digests
##顯示鏡像完整信息
docker images --no-trunc
##顯示指定鏡像的歷史創(chuàng)建;參數(shù):-H 鏡像大小和日期,默認(rèn)為true;--no-trunc  顯示完整的提交記錄;-q  僅列出提交記錄ID
docker history -H redis
##搜索倉(cāng)庫(kù)MySQL鏡像
docker search mysql
## --filter=stars=600:只顯示 starts>=600 的鏡像
docker search --filter=stars=600 mysql
## --no-trunc 顯示鏡像完整 DESCRIPTION 描述
docker search --no-trunc mysql
## --automated :只列出 AUTOMATED=OK 的鏡像
docker search  --automated mysql
##下載Redis官方最新鏡像,相當(dāng)于:docker pull redis:latest
docker pull redis
##下載倉(cāng)庫(kù)所有Redis鏡像
docker pull -a redis
##下載私人倉(cāng)庫(kù)鏡像
docker pull bitnami/redis
##單個(gè)鏡像刪除,相當(dāng)于:docker rmi redis:latest
docker rmi redis
##強(qiáng)制刪除(針對(duì)基于鏡像有運(yùn)行的容器進(jìn)程)
docker rmi -f redis
##多個(gè)鏡像刪除,不同鏡像間以空格間隔
docker rmi -f redis tomcat nginx
##刪除本地全部鏡像
docker rmi -f $(docker images -q)
##(1)編寫(xiě)dockerfile
cd /docker/dockerfile
vim mycentos
##(2)構(gòu)建docker鏡像
docker build -f /docker/dockerfile/mycentos -t mycentos:1.1

3、容器操作

##新建并啟動(dòng)容器,參數(shù):-i  以交互模式運(yùn)行容器;-t  為容器重新分配一個(gè)偽輸入終端;--name  為容器指定一個(gè)名稱
docker run -i -t --name mycentos
##后臺(tái)啟動(dòng)容器,參數(shù):-d  已守護(hù)方式啟動(dòng)容器
docker run -d mycentos
##啟動(dòng)一個(gè)或多個(gè)已經(jīng)被停止的容器
docker start redis
##重啟容器
docker restart redis
##top支持 ps 命令參數(shù),格式:docker top [OPTIONS] CONTAINER [ps OPTIONS]
##列出redis容器中運(yùn)行進(jìn)程
docker top redis
##查看所有運(yùn)行容器的進(jìn)程信息
for i in  `docker ps |grep Up|awk '{print $1}'`;do echo \ &&docker top $i; done
##查看redis容器日志,默認(rèn)參數(shù)
docker logs rabbitmq
##查看redis容器日志,參數(shù):-f  跟蹤日志輸出;-t   顯示時(shí)間戳;--tail  僅列出最新N條容器日志;
docker logs -f -t --tail=20 redis
##查看容器redis從2019年05月21日后的最新10條日志。
docker logs --since="2019-05-21" --tail=10 redis
##使用run方式在創(chuàng)建時(shí)進(jìn)入
docker run -it centos /bin/bash
##關(guān)閉容器并退出
exit
##僅退出容器,不關(guān)閉
快捷鍵:Ctrl + P + Q
##直接進(jìn)入centos 容器啟動(dòng)命令的終端,不會(huì)啟動(dòng)新進(jìn)程,多個(gè)attach連接共享容器屏幕,參數(shù):--sig-proxy=false  確保CTRL-D或CTRL-C不會(huì)關(guān)閉容器
docker attach --sig-proxy=false centos 
##在 centos 容器中打開(kāi)新的交互模式終端,可以啟動(dòng)新進(jìn)程,參數(shù):-i  即使沒(méi)有附加也保持STDIN 打開(kāi);-t  分配一個(gè)偽終端
docker exec -i -t  centos /bin/bash
##以交互模式在容器中執(zhí)行命令,結(jié)果返回到當(dāng)前終端屏幕
docker exec -i -t centos ls -l /tmp
##以分離模式在容器中執(zhí)行命令,程序后臺(tái)運(yùn)行,結(jié)果不會(huì)反饋到當(dāng)前終端
docker exec -d centos  touch cache.txt 
##查看正在運(yùn)行的容器
docker ps
##查看正在運(yùn)行的容器的ID
docker ps -q
##查看正在運(yùn)行+歷史運(yùn)行過(guò)的容器
docker ps -a
##顯示運(yùn)行容器總文件大小
docker ps -s
##顯示最近創(chuàng)建容器
docker ps -l
##顯示最近創(chuàng)建的3個(gè)容器
docker ps -n 3
##不截?cái)噍敵?docker ps --no-trunc 
##獲取鏡像redis的元信息
docker inspect redis
##獲取正在運(yùn)行的容器redis的 IP
docker inspect --format='{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' redis
##停止一個(gè)運(yùn)行中的容器
docker stop redis
##殺掉一個(gè)運(yùn)行中的容器
docker kill redis
##刪除一個(gè)已停止的容器
docker rm redis
##刪除一個(gè)運(yùn)行中的容器
docker rm -f redis
##刪除多個(gè)容器
docker rm -f $(docker ps -a -q)
docker ps -a -q | xargs docker rm
## -l 移除容器間的網(wǎng)絡(luò)連接,連接名為 db
docker rm -l db 
## -v 刪除容器,并刪除容器掛載的數(shù)據(jù)卷
docker rm -v redis
##基于當(dāng)前redis容器創(chuàng)建一個(gè)新的鏡像;參數(shù):-a 提交的鏡像作者;-c 使用Dockerfile指令來(lái)創(chuàng)建鏡像;-m :提交時(shí)的說(shuō)明文字;-p :在commit時(shí),將容器暫停
docker commit -a="DeepInThought" -m="my redis" [redis容器ID]  myredis:v1.1
##將rabbitmq容器中的文件copy至本地路徑
docker cp rabbitmq:/[container_path] [local_path]
##將主機(jī)文件copy至rabbitmq容器
docker cp [local_path] rabbitmq:/[container_path]/
##將主機(jī)文件copy至rabbitmq容器,目錄重命名為[container_path](注意與非重命名copy的區(qū)別)
docker cp [local_path] rabbitmq:/[container_path]
?著作權(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)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

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