Installing Docker on Mac is pretty straightforward. It has a Graphical installer.dmg file. The installation provides Docker Engine, Docker CLI client, Docker Compose, Docker Machine, and Kitematic. Pre-requisites for installing Docker on Mac. Docker requires OS X El Capitan 10.11 or newer macOS release running on a 2010 or newer Mac. Docker Captain Program. Docker Captain is a distinction that Docker awards select members of the community that are both experts in their field and are passionate about sharing their Docker knowledge with others. Captains are Docker ambassadors (not employees) and their commitment to sharing their expertise has a huge impact on the Docker.
Docker takes up a lot of space. When we run the container, pull the image, deploy the application, and build our own image, our disk space will be occupied.
If you are also troubled by this problem, let’s take a look at how docker uses disk space and how to recycle it.
The space occupied by docker can be viewed through the following command:
TYPE
Four types of disk used by docker are listed:
- Images: space occupied by all images, including pulled images and locally built images.
- Containers: the space occupied by the running containers, indicating the space of each container’s read-write layer.
- Local volumes: the space for the container to mount the local data volume.
- Build cache: mirrors the cache space generated during the build process (only available when using buildkit, available after docker 18.09).
finalRECLAIMABLE
Is recyclable size.
Let’s take a look at these types.
Disk usage of container
Every time a container is created, some files and directories are created, such as:
/var/lib/docker/containers/ID
Directory. If the container uses the default log mode, all its logs will be saved to this directory in JSON form./var/lib/docker/overlay2
The directory contains the read-write layer of the container. If the container uses its own file system to save data, it will be written to this directory.
Now let’s start with a completely clean system, assuming that docker has just been installed:
First, we start a nginx container:
Run nowdf
After the command, you will see:
- One image, 126mb
- A container
There is no recyclable space at this time because the container is running and the mirror is being used.
Now, let’s create a 100MB empty file in the container:
View space again:
You can see that the space occupied by the container has increased. Where is the file stored on this machine?
As mentioned above, it is stored in the read-write layer of the container.
When the container is stopped, the space occupied by the container becomes recyclable:
How to recycle it? Deleting a container will delete the space occupied by its associated read-write layer.
You can also delete all stopped containers with one click:
After deleting the container, the image can also be recycled:
abovedocker container prune
The command is to delete stopped containers. If you want to delete all containers (including stopped and running ones), you can use the following two commands:
Mirrored disk usage
Some of the images are invisible:
- A child image is an intermediate image referenced by other images and cannot be deleted.
- A suspended image, that is, an image that will no longer be used, can be deleted.
The following command lists all mirrors in the suspended state:
Delete this type of image:
Or:
If you want to delete all mirrors, you can use the following command:
Note that the image being used by the container cannot be deleted.
Disk usage of data volume
Data volume is the data storage outside the file system of the container itself.
For example, the application in the container has the function of uploading pictures, which can’t be saved in the container after uploading, because the data in the container will be deleted with the death of the container, so these pictures should be saved outside the container, that is, the data volume.
For example, we run a mongodb container for testing and import a lot of test data, which is not inside the container, but in the data volume, because the data volume is used in the dockerfile of mongodb.
After the test is completed, the mongodb container is deleted, but the test data is still there and has not been deleted.
To delete a data volume that is no longer in use:
Or:
Disk usage of build cache
Docker 18.09 introduced buildkit to improve the performance, security, storage management and other capabilities of the construction process.
To delete the build cache, you can use the following commands:
One click cleaning
Through the above instructions, we know that containers, images, and data volumes all provideprune
This subcommand helps us reclaim space.
In fact, the docker system also hasprune
This subcommand can clear the useless space with one click:
It’s a good habit to execute this order regularly.
Translation from:
https://medium.com/better-programming/docker-tips-clean-up-your-local-machine-35f370a01a78
The above is the whole content of this article. I hope it will help you in your study, and I hope you can support developepaer more.
Recently cleaned house and did a fresh os install, and when I was about to reinitialize my edge vm I realized that everything I had been using my virtual debain server for can now be done with docker.
And then some! Basically I was using a virtual server as a file share, an ssh gateway, a web server, and as a ddclient with google domains
I also wanted to create a honeypot because I’m always getting spammed. The honeypot is not super-advanced but for now, I get a steady stream of common usernames and passwords. Also, IPs to “investigate.” I’d love to go farther with this, but of course, who has the time?
ddclient image
I recently came across the linuxserver collection of docker images, including the one for ddclient. Super easy to set up (just point your image at the ddclient.conf), using something like
Now, my IP stays fresh and the service runs all the time without eating into my resources.
the ssh-honey honeypot
Docker Desktop For Mac El Capitan
I am using this image: txt3rob/docker-ssh-honey for starters. Now, I’ve nat’d my external port 22 to point to the machine where the image is running, and I’ve got it exposed on port 2022, so my command looks like this:
Comments are closed.