殺死所有正在運行的容器
刪除所有已經停止的容器
刪除所有未打 dangling 標簽的鏡像
刪除所有鏡像
為這些命令創建別名
# 殺死所有正在運行的容器.
alias dockerkill='docker kill $(docker ps -a -q)'
# 刪除所有已經停止的容器.
alias dockercleanc='docker rm $(docker ps -a -q)'
# 刪除所有未打標簽的鏡像.
alias dockercleani='docker rmi $(docker images -q -f dangling=true)'
# 刪除所有已經停止的容器和未打標簽的鏡像.
alias dockerclean='dockercleanc || true && dockercleani'
另附上docker常用命令
docker version #查看版本
docker search tutorial#搜索可用docker鏡像
docker pull learn/tutorial #下載鏡像
docker run learn/tutorial echo "hello word"#在docker容器中運行hello world!
docker run learn/tutorial apt-get install -y ping#在容器中安裝新的程序
保存鏡像
首先使用docker ps -l命令獲得安裝完ping命令之后容器的id。然后把這個鏡像保存為learn/ping。
提示:
1.運行docker commit,可以查看該命令的參數列表。
2.你需要指定要提交保存容器的ID。(譯者按:通過docker ps -l 命令獲得)
3.無需拷貝完整的id,通常來講最開始的三至四個字母即可區分。(譯者按:非常類似git里面的版本號)
正確的命令:
docker commit 698 learn/ping
運行新的鏡像
docker run lean/ping ping www.google.com
檢查運行中的鏡像
現在你已經運行了一個docker容器,讓我們來看下正在運行的容器。
使用docker ps命令可以查看所有正在運行中的容器列表,使用docker inspect命令我們可以查看更詳細的關於某一個容器的信息。
目標:
查找某一個運行中容器的id,然后使用docker inspect命令查看容器的信息。
提示:
可以使用鏡像id的前面部分,不需要完整的id。
正確的命令:
docker inspect efe
啟動容器
- 啟動容器並啟動bash(交互方式):
$docker run -i -t <image_name/continar_id> /bin/bash
- 啟動容器以后台方式運行(更通用的方式):
$docker run -d -it image_name
ps:這里的 image_name 包含了tag:hello.demo.kdemo:v1.0
附着到容器
- 附着到正在運行的容器
docker attach <id、container_name>
- 進入正在運行的容器內部,同時運行bash(比attach更好用)
docker exec -t -i <id/container_name> /bin/bash
ps:docker exec是如此的有用,以至於我們通常是將其封裝為一個腳本,放到全局可調用的地方,比如,可以寫成一個indocker.sh:
$cat indocker.sh docker exec -t -i $1 /bin/bash # 查看需要附着的容器id $docker ps | less -S CONTAINER ID IMAGE 9cf7b563f689 hello.demo.kdemo:v160525.202747 $./indocker.sh 9cf7b563f689
查看容器日志
- 查看容器日志
docker logs <id/container_name>
- 實時查看日志輸出
docker logs -f <id/container_name> (類似 tail -f) (帶上時間戳-t)
查看容器
- 列出當前所有正在運行的container
$docker ps
- 用一行列出所有正在運行的container(容器多的時候非常清晰)
$docker ps | less -S
- 列出所有的container
$docker ps -a
- 列出最近一次啟動的container
$docker ps -l
- 顯示一個運行的容器里面的進程信息
$docker top Name/ID
- 查看容器內部詳情細節:
$docker inspect <id/container_name>
- 在容器中安裝新的程序
$docker run image_name apt-get install -y app_name
Note: 在執行apt-get 命令的時候,要帶上-y參數。如果不指定-y參數的話,apt-get命令會進入交互模式,需要用戶輸入命令來進行確認,但在docker環境中是無法響 應這種交互的。apt-get 命令執行完畢之后,容器就會停止,但對容器的改動不會丟失。
- 從容器里面拷貝文件/目錄到本地一個路徑
$docker cp Name:/container_path to_path $docker cp ID:/container_path to_path
- 保存對容器的修改(commit) 當你對某一個容器做了修改之后(通過在容器中運行某一個命令),可以把對容器的修改保存下來,這樣下次可以從保存后的最新狀態運行該容器。
$docker commit ID new_image_name
Note: image相當於類,container相當於實例,不過可以動態給實例安裝新軟件,然后把這個container用commit命令固化成一個image。
- 刪除單個容器
$docker rm Name/ID
-f, –force=false; -l, –link=false Remove the specified link and not the underlying container; -v, –volumes=false Remove the volumes associated to the container
- 刪除所有容器
$docker rm `docker ps -a -q`
- 停止、啟動、殺死、重啟一個容器
$docker stop Name/ID $docker start Name/ID $docker kill Name/ID $docker restart name/ID
操作Image
- 列出鏡像
$sudo docker images
-a, –all=false Show all images; –no-trunc=false Don’t truncate output; -q, –quiet=false Only show numeric IDs
- 從dockerhub檢索image
$docker search image_name
- 下載image
$docker pull image_name
- 刪除一個或者多個鏡像;
$docker rmi image_name
-f, –force=false Force; –no-prune=false Do not delete untagged parents
- 顯示一個鏡像的歷史;
$docker history image_name
- 發布docker鏡像
$docker push new_image_name
ps:要發布到私有Registry中的鏡像,在鏡像命名中需要帶上Registry的域名(如果非80端口,同時需要帶上端口號)比如:
$docker push dockerhub.yourdomain.com:443/hello.demo.kdemo:v1.0
- 拉取docker鏡像
$docker pull image_name
網絡操作
- 查看docker0的網絡(宿主機上操作)
$ip a show docker0
- 查看容器的IP地址
$docker inspect -f '{{ .NetworkSettings.IPAddress }}' <id、container_name>
附着到容器內部查看其內部ip:
$ip a show eth0
查看docker基礎信息
查看docker版本
$docker version
查看docker系統的信息
$docker info