Docker总结

mac2022-06-30  25

Docker总结

1.Docker与传统虚拟化方式比较2.Docker的镜像与容器3.Docker安装与启动4.设置阿里云的镜像5.Docker的启动与停止6.镜像相关命令7.容器相关命令8.文件拷贝9.目录挂载10.查看容器IP地址11.MySQL部署12.Tomcat部署13.Nginx部署14.Redis部署15.迁移与备份16.Dockerfile17.Docker私有仓库搭建与配置18.镜像上传到私有仓库

1.Docker与传统虚拟化方式比较

2.Docker的镜像与容器

容器是基于镜像启动起来的,容器中可以运行一个或多个进程。我们可以认为,镜像是Docker生命周期中构建或者打包阶段,而容器则是启动或者执行阶段。容器给予镜像启动,一旦容器启动完成后,我们就可以登陆到容器中安装自己需要的软件或者服务。

3.Docker安装与启动

需要使用CentOS7.X以上的版本:

yum包更新到最新; sudo yum update 安装需要的软件包,yum-util提供yum-config-manager功能,另外两个是device mapper驱动依赖的 sudo yum install ‐y yum‐utils device‐mapper‐persistent‐data lvm2 设置yum源为阿里云 sudo yum‐config‐manager ‐‐add‐repo http://mirrors.aliyun.com/dockerce/ linux/centos/docker‐ce.repo 安装docker sudo yum install docker‐ce 安装后查看docker版本 docker -v

4.设置阿里云的镜像

5.Docker的启动与停止

systemctl命令是系统服务管理器指令;

启动docker systemctl start docker停止docker systemctl stop docker重启docker systemctl restart docker参看docker状态 systemctl status docker开机启动 systemctl enable docker查看docker概要信息 docker info查看docker帮助文档 docker --help

6.镜像相关命令

查看镜像 docker images搜索镜像 docker search 镜像名称拉取镜像 docker pull 镜像名称按照镜像ID删除镜像 docker rmi 镜像ID删除所有镜像 docker rmi 'docker images -q'其中的 ` 是esc键下的按键

7.容器相关命令

查看正在运行的容器 docker ps参看所有容器 docker ps -a查看最后一次运行的容器 docker ps -l参看停止的容器 docker ps -f status=exited创建容器 docker run -i 表示运行容器-t 表示容器启动后会进入器命令行。加入这两个参数后,容器创建就能登陆进去。即分配一个伪终端。--name 为创建的容器命名-v 表示目录映射关系(前者是宿主机目录,后者是映射到宿主机上的目录)-d在run后面加上-d参数,则会创建一个守护式容器在后台运行,这样创建容器后不会自动登录容器,如果只加了-i -t两个参数,创建后就会自动进去容器。-p 表示端口映射,前者是宿主机端口,后者是容器内的映射端口。可以使用多个-p做多个端口映射。::交互式方式创建容器:: docker run ‐it ‐‐name=容器名称 镜像名称:标签 /bin/bash这时我们可以通过exit命令退出当前容器。::守护式方式创建容器:: docker run ‐di ‐‐name=容器名称 镜像名称:标签登录守护式容器方式docker exec ‐it 容器名称 (或者容器ID) /bin/bash。启动容器 docker start 容器名称(或容器ID)停止容器 docker stop 容器名称(或容器ID) 删除指定容器docker rm 容器名称(容器ID)

8.文件拷贝

如果我们需要将文件拷贝到容器内可以使用cp命令

docker cp 需要拷贝到文件或目录 容器名称:容器目录

也可以将文件从容器内拷贝出来

docker cp 容器名称:容器目录 需要拷贝到文件或目录

9.目录挂载

我们可以在创建容器的时候,将宿主机的目录与容器内的目录进行映射,这样我们就可以通过修改宿主机某个目录的文件而去影响容器。 创建容器添加-v参数,后面为宿主机目录:容器目录,例如:

docker run ‐di ‐v /usr/local/myhtml:/usr/local/myhtml ‐‐name=mycentos3 centos:7

如果你共享的是多级的目录,可能会出现权限不足的提示。 这是因为CentOS7的安全模块selinux把权限静掉了,我们需要添加参数 --privileged=true 来解决挂载的目录没有权限的问题。

10.查看容器IP地址

我们可以通过以下命令查看容器运行的各种数据

docker inspect 容器名称(容器ID)

也可以直接执行下面的命令直接输出IP地址

docker inspect ‐‐format='{{.NetworkSettings.IPAddress}}' 容器名称(容器ID)

11.MySQL部署

拉取MySQL镜像 docker pull centos/mysql-57-centos7 创建MySQL容器 docker run -di --name=mysql01 -p 33306:3306 -e MYSQL_ROOT_PASSWORD=320512 centos/mysql-57-centos7

-p 代表端口映射,格式为 宿主机映射端口:容器运行端口 -e 代表添加环境变量 MYSQL_ROOT_PASSWORD 是root用户的登录密码

12.Tomcat部署

拉取镜像 docker pull tomcat:7-jre7 创建容器 创建容器 -p表示地址映射 docker run ‐di ‐‐name=mytomcat ‐p 9000:8080 ‐v /usr/local/webapps:/usr/local/tomcat/webapps tomcat:7‐jre7

13.Nginx部署

拉取镜像 docker pull nginx 创建容器 docker run ‐di ‐‐name=mynginx ‐p 80:80 nginx

14.Redis部署

拉取镜像 docker pull redis 创建容器 docker run ‐di ‐‐name=myredis ‐p 6379:6379 redis

15.迁移与备份

我们可以通过以下命令将容器保存为镜像 docker commit 容器名称 镜像名称 我们可以通过以下命令将镜像保存为tar文件 docker save -o tar文件名称 镜像名称 恢复镜像 docker load -i tar文件名称

16.Dockerfile

Dockerfile是由一系列命令和参数构成的脚本,这些命令应用于基础镜像并最终创建一个新的镜像。 使用脚本创建镜像案例:

创建目录: mkdir -p /usr/local/dockerjdk8 下载jdk-8u171-linux-x64.tar.gz并上传到服务器(虚拟机)中的/usr/local/dockerjdk8目录中创建文件Dockerfile vi Dockerfile 执行命令构建镜像(注意后边的空格和点,不能省略) docker build ‐t='jdk1.8' . 参看镜像是否建立完成 docker images

17.Docker私有仓库搭建与配置

拉取私有仓库镜像 docker pull registry 启动私有仓库容器 docker run -di --name=registry -p 5000:5000 registry 打开浏览器输入地址http://172.16.124.130:5000/v2/_catalog,看到{"repositories":[]}表示私有仓库搭建成功并且内容为空。修改daemon.json vi /etc/docker/daemon.json

添加以下内容,保存退出,这是为了让docker信任私有仓库地址

{"insecure-registries":["172.16.124.130:5000"]} 重启docker服务 systemctl restart docker

18.镜像上传到私有仓库

标记此镜像为私有仓库的镜像 docker tag jdk1.8 172.16.124.130:5000/jdk1.8 再次启动私服容器 docker start registry 上传标记的镜像 docker push 172.16.124.130:5000/jdk1.8
最新回复(0)