# 查看所有的数据卷
docker volume ls
# 查看特定数据卷的详细信息 语法:docker volume inspect <volume_name>
docker volume inspect 0c4f810bb132301e6bbedd68f40a28d42970fa7472c5113bcec93f704d4ca136
# 会显示挂载点路径 语法:docker volume inspect <volume_name> | grep Mountpoint
docker volume inspect 0c4f810bb132301e6bbedd68f40a28d42970fa7472c5113bcec93f704d4ca136 | grep Mountpoint
# 创建临时容器挂载数据卷来查看内容
docker run --rm -it -v 0c4f810bb132301e6bbedd68f40a28d42970fa7472c5113bcec93f704d4ca136:/data alpine sh
# 进入容器后查看 /data 目录内容
ls -la /data
# 查看所有容器(包括停止的)及其挂载信息
docker ps -a --format "table {{.ID}}\t{{.Names}}\t{{.Status}}\t{{.Mounts}}"
# 或者查看详细的挂载信息 语法: docker inspect $(docker ps -aq) | grep -A 10 -B 2 "容器ID"
docker inspect $(docker ps -aq) | grep -A 10 -B 2 "0c4f810bb132"
#!/bin/bash
# 遍历所有数据卷并显示内容概览
for volume in $(docker volume ls -q); do
echo "=== Volume: $volume ==="
docker run --rm -v $volume:/data alpine sh -c "ls -la /data | head -10" 2>/dev/null || echo "无法访问此数据卷"
echo ""
done
# 查看哪些数据卷正在被使用
docker system df -v
# 查看数据卷大小
docker run --rm -v 0c4f810bb132301e6bbedd68f40a28d42970fa7472c5113bcec93f704d4ca136:/data alpine du -sh /data
# 1. 先查看哪些是未使用的数据卷
docker volume ls --filter dangling=true
# docker volume ls -f dangling=false # 显示被引用的卷
# 2. 逐个检查可疑的数据卷内容
docker run --rm -v <volume_name>:/data alpine ls -la /data
# 3. 确认安全后再删除
docker volume prune -f
# 创建容器时使用命名数据卷
docker run -v my_app_data:/app/data nginx
# 或者使用 docker-compose 明确命名
version: '3'
services:
app:
image: nginx
volumes:
- app_data:/usr/share/nginx/html
volumes:
app_data:
name: my_project_data
# 在宿主机上直接查看数据卷内容(需要root权限)
sudo ls -la /var/lib/docker/volumes/0c4f810bb132301e6bbedd68f40a28d42970fa7472c5113bcec93f704d4ca136/_data/