摘要:以下都会使用到容器,所以执行以下指令查看容器或者容器名称检查环节变量查看日志备份恢复备份使用进入容器没有剩余磁盘空间使用以下指令删除容器和镜像删除所有容器删除未使用的镜像清理日
以下都会使用到容器 id,所以执行以下指令查看容器 id 或者容器名称
[yexiaobaideMacBook-Pro: ~]$ sudo docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 20ec96201fa3 swarm "/swarm manage token 26 hours ago Up 26 hours 0.0.0.0:2222->2375/tcp suspicious_sinoussi 7e90d4598a74 swarm "/swarm join -addr=1 26 hours ago Up 26 hours 2375/tcp sad_cray abf7cdbe5d1c rancher/server "/usr/bin/s6-svscan 26 hours ago Up 26 hours 3306/tcp, 0.0.0.0:8080->8080/tcp ecstatic_morse检查环节变量
sudo docker inspect --format "{{.Config.Env}}" abf7cdbe5d1c查看日志
sudo docker logs -f abf7cdbe5d1c备份
sudo docker run --rm -v /tmp:/backup --volumes-frombusybox tar -cvf /backup/backup.tar
恢复备份
sudo docker run --rm -v /tmp:/backup --volumes-from使用 docker exec 进入容器busybox tar -xvf /backup/backup.tar
sudo docker exec -it ecstatic_morse bash没有剩余磁盘空间
使用以下指令删除容器和镜像
sudo docker ps -aq | xargs sudo docker rm # 删除所有容器 sudo docker images -aq -f dangling=true | xargs sudo docker rmi # 删除未使用的镜像
清理日志 - 非 root 权限
sudo su -c "echo "" > $(sudo docker inspect --format="{{.LogPath}}" ecstatic_morse)"使用别名
在 .zshrc 或者 .bashrc 中写入以下脚本:
alias dockercleancontainers="docker ps -aq | xargs docker rm" alias dockercleanimages="docker images -aq -f dangling=true | xargs docker rmi" alias dockerclean="dockercleancontainers && dockercleanimages" alias docker-killall="docker ps -q | xargs docker kill" # runs docker exec in the latest container function docker-exec-last { docker exec -ti $( docker ps -a -q -l) /bin/bash } function docker-get-ip { # Usage: docker-get-ip (name or sha) [ -n "$1" ] && docker inspect --format "{{ .NetworkSettings.IPAddress }}" $1 } function docker-get-id { # Usage: docker-get-id (friendly-name) [ -n "$1" ] && docker inspect --format "{{ .ID }}" "$1" } function docker-get-image { # Usage: docker-get-image (friendly-name) [ -n "$1" ] && docker inspect --format "{{ .Image }}" "$1" } function docker-get-state { # Usage: docker-get-state (friendly-name) [ -n "$1" ] && docker inspect --format "{{ .State.Running }}" "$1" } function docker-memory { for line in `docker ps | awk "{print $1}" | grep -v CONTAINER`; do docker ps | grep $line | awk "{printf $NF" "}" && echo $(( `cat /sys/fs/cgroup/memory/docker/$line*/memory.usage_in_bytes` / 1024 / 1024 ))MB ; done } # keeps the commmand history when running a container function basher() { if [[ $1 = "run" ]] then shift docker run -e HIST_FILE=/root/.bash_history -v $HOME/.bash_history:/root/.bash_history "$@" else docker "$@" fi } # backup files from a docker volume into /tmp/backup.tar.gz function docker-volume-backup-compressed() { docker run --rm -v /tmp:/backup --volumes-from "$1" debian:jessie tar -czvf /backup/backup.tar.gz "${@:2}" } # restore files from /tmp/backup.tar.gz into a docker volume function docker-volume-restore-compressed() { docker run --rm -v /tmp:/backup --volumes-from "$1" debian:jessie tar -xzvf /backup/backup.tar.gz "${@:2}" echo "Double checking files..." docker run --rm -v /tmp:/backup --volumes-from "$1" debian:jessie ls -lh "${@:2}" } # backup files from a docker volume into /tmp/backup.tar function docker-volume-backup() { docker run --rm -v /tmp:/backup --volumes-from "$1" busybox tar -cvf /backup/backup.tar "${@:2}" } # restore files from /tmp/backup.tar into a docker volume function docker-volume-restore() { docker run --rm -v /tmp:/backup --volumes-from "$1" busybox tar -xvf /backup/backup.tar "${@:2}" echo "Double checking files..." docker run --rm -v /tmp:/backup --volumes-from "$1" busybox ls -lh "${@:2}" }使用 COPY 而不是 ADD 在下载之后和开始使用之前使用 checksum 检查
ENV JENKINS_VERSION 1.625.3 ENV JENKINS_SHA 537d910f541c25a23499b222ccd37ca25e074a0c RUN curl -fL http://mirrors.jenkins-ci.org/war-stable/$JENKINS_VERSION/jenkins.war -o /usr/share/jenkins/jenkins.war && echo "$JENKINS_SHA /usr/share/jenkins/jenkins.war" | sha1sum -c -在相同 layer 清理
RUN apt-get update && apt-get install -y curl python-pip && pip install requests && apt-get remove -y python-pip curl && rm -rf /var/lib/apt/lists/*记录日志到stdout
# forward request and error logs to docker log collector RUN ln -sf /dev/stdout /var/log/nginx/access.log RUN ln -sf /dev/stderr /var/log/nginx/error.log参考
原文:http://blog.labianchin.me/2016/02/15/docker-tips-and-tricks?mkt_tok=3RkMMJWWfF9wsRonuqTMZKXonjHpfsX57uglXKa%2FlMI%2F0ER3fOvrPUfGjI4DSsprI%2BSLDwEYGJlv6SgFQ7LMMaZq1rgMXBk%3D
https://zwischenzugs.wordpress.com/2015/06/14/my-favourite-docker-tip/
https://website-humblec.rhcloud.com/docker-tips-and-tricks/
https://docs.docker.com/engine/articles/dockerfile_best-practices/
http://www.projectatomic.io/docs/docker-image-author-guidance/
http://crosbymichael.com/dockerfile-best-practices.html
http://crosbymichael.com/dockerfile-best-practices-take-2.html
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/26522.html
摘要:最近看了这篇文章,了解到容器内的一个进程对应于宿主机器上的一个进程。在宿主机器上的进程拥有者和在容器内的进程拥有者都是,同理,我们已经验证了第二点。 最近看了这篇文章:Understanding how uid and gid work in Docker containers,了解到: docker容器内的一个进程对应于宿主机器上的一个进程。 容器内的进程,与相对应的宿主进程,由...
摘要:本文将介绍精简容器镜像的必要性并以基于的应用为例描述最小化容器镜像的常用技巧。经过这一优化,最终镜像的大小为。 背景 随着容器技术的普及,越来越多的应用被容器化。人们使用容器的频率越来越高,但常常忽略一个基本但又非常重要的问题 - 容器镜像的体积。本文将介绍精简容器镜像的必要性并以基于 spring boot 的 java 应用为例描述最小化容器镜像的常用技巧。 精简容器镜像的必要性 ...
摘要:但在生产环境下,如果不指定保存依赖的版本号会存在问题。它会生成一个文件,不仅记录了当前环境中使用的模块精确的版本号,还记录了这些模块的其他依赖的版本,以此类推。 本文来自国外新手向技术博客RisingStack。有兴趣的同学可点击原文查看。 相信npm install是npm-cli最常用的功能,但其实它还有很多其他可挖掘的地方。在本文中,你将会学习如何在应用开发的整个生命周期中——...
摘要:现代建议使用虚拟化工具来搭建同生产环境一模一样的开发环境。现代建议我们使用的进程管理器来部署应用,并存放在这样的服务器。 以下内容摘自《Modern PHP》现代PHP,也加入了我的一些理解,如有错误,麻烦提出,我好改正 避免使用ftp 在这之前,我们使用ftp进行代码管理,修改一个PHP文件,然后使用ftp上传,这非常危险。 现代PHP建议使用版本管理软件进行代码版本管理,例如使用G...
摘要:本系列教程翻译自,系列共有九篇,本文译自第二篇。总结本章知识介绍了最基本的十五个命令,接下来的教程将会陆续介绍如何在中运行一个应用以及其他的命令。接下来会在本系列教程结束后补充几篇应用的实例。 本系列教程翻译自 Flux7 Docker Tutorial Series,系列共有九篇,本文译自第二篇 Part 2: The 15 Commands。 该系列所有文章将参考其他学习...
阅读 1866·2021-11-22 15:25
阅读 1236·2021-11-19 09:40
阅读 1809·2021-09-27 13:57
阅读 972·2021-09-22 15:10
阅读 950·2021-08-16 11:01
阅读 2930·2021-07-23 17:51
阅读 732·2019-08-30 15:55
阅读 806·2019-08-30 13:58