一.Docker简介
Docker是一个开源的应用容器引擎,基于Go语言并遵从Apache2.0协议开源.Docker可以让开发者打包他们的应用以及依赖到一个轻量级,可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化.
容器完全使用沙箱机制,相互之间不会有任何接口,更重要的是容器性能开销极低.Docker支持将软件编译成一个镜像;然后在镜像中各种软件做好布置,将镜像发布出去,其他使用者可以直接使用这个镜像.运行中的这个镜像称为容器,容器启动时非常快速的.
二.Docker核心概念
docker主机:安装了docker程序的机器,docker直接安装在操作系统之上;
docker客户端:连接docker主机进行操作;
docker仓库:用来保存各种打包好的软件镜像,例如公共软件镜像:https://hub.docker.com;
docker镜像:软件打包好的镜像,放在docker仓库中;
docker容器:镜像启动后的实例称为一个容器;
使用docker的步骤:
(1)安装docker;
(2)去Docker仓库找到这个软件对应的镜像;
(3)直接使用Docker运行这个镜像,这个镜像就会生成一个Docker容器;
(4)对容器的启动停止-->对软件的启动停止.
三.Docker安装
1)我们可以使用VirtualBox作为虚拟机;
2)导入虚拟机文件
3)双击启动linux虚拟机
4)使用客户端连接linux服务器
5)桥接网络
6)services network start 重启虚拟机网络
7)查看linux 的IP地址 ip addr
安装步骤:
1.查看liunx 内核版本是否高于3.10 uname -r
2.使用yum install docker
3.启动docker: systemctl start docker
4.使用systemctl enable docker设置docker开机自动启动
5.停止docker: systemctl stop docker
四.Docker常用操作
1.镜像操作,查看是否含有mysql镜像: docker search mysql,默认将去docker hub中搜索镜像;
2.拉取镜像:docker pull mysql;
3.查看当前含有多少镜像: docker images;
4.指定删除镜像: docker rmi images-id;
五.Docker容器操作
软件镜像-->运行镜像-->产生一个容器(正在运行的软件)
步骤:
1.搜索镜像docker search tomcat;
2.下载镜像docker pull tomcat;
3.根据镜像启动容器:docker run --name 自定义名称-d(以后台运行) image-name:tag
4.使用docker ps查看运行的容器
5.停止运行中的容器 docker stop 容器ID/name
6.docker ps -a 查看所有容器 也可以使用docker start id启动容器;
7.删除一个容器 docker rm id
8.启动一个可以外网访问的tomcat容器(-p 容器映射):docker run --name mytomcat -d -p 8888:8080 tomcat 将主机的端口映射到容器的一个端口-p(主机端口:容器内的端口);
9.如果无法启动需要关闭防火墙 service firewalld status 查看防火墙 service firewalld stop关闭防火墙
10.docker logs 容器名称/id 查看日志
六.安装常用Docker镜像
1.安装mysql
2.安装redis
3.安装rabbitmq
4.安装elasticsearch
(1)直接使用docker run --name mysql01 -d mysql 无法正常启动mysql 查看docker日志:
说明我们在启动mysql的时候没有指定密码;
(2) docker run --name mysql01 -e MYSQL_ROOT_PASSWORD=123456 -d -p3306:3306 mysql 可以启动mysql容器;
(3)docker run --name mysql03 -v /my/custom:/etc/mysql/conf.d-e ROOT_MYSQL_PASSWORD=123456 -d mysql:5.7
表示吧主机的/my/custom文件夹挂载到mysql docker容器的/etc/mysql/conf.d文件下下,这样启动mysql的docker容器就可以使用我们自定义的配置文件.这样我们修改mysql的配置文件只需要将mysql的配置文件放在这里就可以.
(4)docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci
不使用cnf配置文件启动
原文地址:https://www.cnblogs.com/skykuqi/p/12032244.html