Docker

安装

文档参考地址

道客

dockerHub

安装docker:curl -sSL https://get.daocloud.io/docker | sh

systemctl enable docker --设置docker开机自启

systemctl start docker --启动docker服务


常用命令

docker network ls

docker network delete [NAME]

docker network create tomcat-net

docker network inspect tomcat-net

docker inspect bridge

docker network create -d bridge my-net  --d参数指定 Docker 网络类型,有 bridge overlay。其中 overlay 网络类型用于 Swarm mode。引用例如:docker run -it --rm --name busybox1 --network my-net busybox sh

--net=bridge   bridge模式是 docker 的默认网络模式。例如:docker run -tid --net=bridge --name docker_bri2 ubuntu-base:v3

--net=host  启动容器的时候使用host模式,那么这个容器将不会获得一个独立的Network Namespace,而是和宿主机共用一个 Network Namespace。例如:docker run -tid --net=host --name docker_host2 ubuntu-base:v3

--net=container:docker_bri1  指定新创建的容器和已经存在的一个容器共享一个 Network Namespace,而不是和宿主机共享。例如:docker run -tid --net=container:docker_bri1 --name docker_con1 ubuntu-base:v3

--net=none  使用none模式,Docker 容器拥有自己的 Network Namespace,但是,并不为Docker 容器进行任何网络配置。也就是说,这个 Docker 容器没有网卡、IP、路由等信息。

docker start [container-name] --启动未运行的容器

docker build -f [dockerfile] --no-cache -t xxx/xxx/image:version . --根据dockerfile构建镜像,.表示当前路径下的所有内容

docker commit my-centos vim-centos-image --把container做成定制化的镜像

docker save imageID > filename  --  保存镜像为文件形式

docker save -o [file-name] [docker-image]:[docker-tag]  --  保存镜像为文件形式

docker load < filename  --  从本地文件加载镜像(通过image保存的镜像会保存操作历史,可以回滚到历史版本)

docker export containID > filename;docker import filename [newname]  --  保存,加载容器

docker login --username=dreamlee0201 registry.cn-hangzhou.aliyuncs.com --登录阿里云镜像仓库

docker pull registry.cn-hangzhou.aliyuncs.com/durian/dreamlee0201/...... --拉取阿里云仓库镜像

docker tag [IMAGE-NAME:IMAGE-VERSION] [NEW-IMAGE-NAME:NEW-IMAGE-VERSION]--给镜像打标签

docker push registry.cn-hangzhou.aliyuncs.com/durian/dreamlee0201/...... --把镜像推送到阿里云仓库

docker rm -f $(docker ps -aq) --删除所有容器

docker rm -f $(docker ps -aq -f status=exited) --删除所有无用的容器

docker rmi -f $(docker images) --删除所有镜像

docker rmi -f $(docker images -f "dangling=true" -q) --删除所有dangling数据卷,即无用volume镜像

docker volume prune --清理无主volume

--mount type=bind,source=/src/webapp,target=/opt/webapp  --加载主机的 /src/webapp 目录到容器的 /opt/webapp目录

docker run -d --name mysql -v mysql_volume:/var/lib/mysql -p 3300:3306 -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7 --启动容器

docker run -u root --rm -d -p 8080:8080 -p 50000:50000 -v jenkins-data:/var/jenkins_home -v /var/run/docker.sock:/var/run/docker.sock jenkinsci/blueocean --启动Jenkins容器

docker run --name nginx -d -p 80:80 -v /home/dreamlee/nginx_conf/log:/var/log/nginx -v /home/dreamlee/nginx_conf/conf/nginx.conf:/etc/nginx/nginx.conf -v /home/dreamlee/nginx_conf/html/index.html:/usr/share/nginx/html/index.html nginx

docker run -d --name redis01 -v redis01_volume -p 6379:6379 redis

docker exec -it mysql01 bash --进入容器

docker cp /www/runoob 96f7f14e99ab:/www/  --将主机/www/runoob目录拷贝到容器96f7f14e99ab的/www目录下

docker logs -t --tail=n e2f4beff730c --查看日志

docker inspect e2f4beff730c|grep Mounts -A 20 --表示查询文件中 Mounts 关键字所在行及后面的 20 行

docker volume ls

docker volume inspect [ID]

docker volume rm -f [ID]

docker volume prune -f 强制删 docker 清理无用的卷

配置相关

设置限制docker的data文件大小:  1.备份镜像 2.修改配置文件[/lib/systemd/system/docker.service];找到ExecStart=/usr/bin/dockerd 在这一行后面加上 [--storage-opt dm.loopdatasize=8G --storage-opt dm.loopmetadatasize=4G --storage-opt dm.basesize=8G][DOCKER_STORAGE_OPTIONS="--storage-driver devicemapper --storage-opt dm.loopdatasize=2000G --storage-opt dm.loopmetadatasize=10G --storage-opt dm.fs=ext4 --storage-opt dm.basesize=20G"]即可,意思是为,设置devicemapper的data为8G,metadata为4G,镜像的大小不能大于8G;  3.修改后运行sudo systemctl daemon-reload;sudo systemctl start docker;docker info


dockerfile

FROM:定制的镜像都是基于from的镜像

RUN:用于执行后面跟着的命令行命令

COPY:复制指令,从上下文目录中复制文件或者目录到容器里指定路径

ADD:和copy类似,推荐copy。

CMD:类似于RUN;但cmd在docker run时运行,run是在docker build运行

ENTRYPOINT:

ENV:设置环境变量,定义了环境变量在后续指令中就可以使用这个环境变量了

ARG:构建参数,与ENV作用一致,但作用域不同。arg设置的环境变量仅对dockerfile内有效,也就是在docker build过程中有效,构建好的镜像内不存在此环境变量

VOLUME:定义匿名数据卷,在启动容器时未挂载数据卷,会自动挂载到匿名卷。在启动容器docker run时,可通过-v参数修改挂载点

EXPOSE:声明端口。帮助镜像使用者理解这个镜像服务的守护端口,以方便配置映射;在启动容器docker run时,可通过-P参数修改映射端口

WORKDIR:指定工作目录。docker build构建镜像过程中,每一个RUN命令都新建一层,只有通过WORKDIR创建的目录才会一直存在

USER:指定执行后续命令的用户和用户组

HEALTHYCHECK:指定某个程序或指令来监控docker容器服务的运行状态

ONBUILD:延迟构建命令的执行。dockerfile里用onbulid指定的命令,在本次构建镜像过程中不会执行,当有新的dockerfile使用之前的镜像时,执行新镜像的dockerfile构建时候会执行之前dockerfile里的onbuild指定的命令


网络相关

ip link show --查看网卡信息

ls /sys/class/net --查看网卡文件

ip addr add 192.168.0.100/24 dev etho --给网卡增加IP地址

ip addr delete 192.168.0.100/24 dev etho --给网卡删除IP地址

网络隔离,network namespace技术:

ip netns add ns1;

ip netns list;

ip netns exec ns1 ip a;

ip netns exec ns1 ifup lo;

ip link add veth-ns1 type veth peer name veth-ns2;

ip link set veth-ns1 netns ns1;

ip netns exec ns1 pi addr add 192.168.8.11/24 dev veth-ns1;

ip link set veth-ns2 up;


配置镜像加速器(阿里云镜像加速器)

sudo mkdir -p /etc/docker

sudo tee /etc/docker/daemon.json <<-'EOF'

{

  "registry-mirrors":["https://8ekevzsi.mirror.aliyuncs.com"]

}

EOF

sudo systemctl daemon-reload

sudo systemctl restart docker


docker-compose

是什么:能够根据yaml文件的配置,在单个机器中管理多个容器



常用镜像

postgres

redis

MySQL

Docker Hub


Grafana+Prometheus的详解以及使用

docker run -d --restart=unless-stopped --name prometheus -p 9090:9090 -v /root/docker/prometheus/prometheus.yml:/etc/prometheus/prometheus.yml prom/prometheus

docker run -d --restart=unless-stopped -p 3000:3000 --name=grafana -v /root/docker/grafana/conf:/etc/grafana -v /root/docker/grafana/data:/var/lib/grafana -v /root/docker/grafana/log:/var/log/grafana grafana/grafana

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,393评论 5 467
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,790评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,391评论 0 330
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,703评论 1 270
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,613评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,003评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,507评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,158评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,300评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,256评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,274评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,984评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,569评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,662评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,899评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,268评论 2 345
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,840评论 2 339

推荐阅读更多精彩内容