一、项目部署存在的问题
项目部署——将开发、测试完成的Java应用配置到生产环境中
-
由于开发、生产环境不一致,导致相同的程序可能无法正常运行;
-
将多个应用同时部署在同一台服务器,可能会因为其他应用的问题而影响到当前应用;
-
项目弹性部署较差,需要通过人工来进行项目(服务)的维护,运维成本较高;
-
如果应用依赖的环境比较多,运维人员需要对依赖的环境一一进行安装,会导致技术成本过高。
二、Docker介绍
2.1 Docker的由来
-
2010年,一帮年轻人创业,致力于PAAS平台开发(平台软件);
-
2013年,如亚马逊、Google等这样的大型企业也可以做PAAS平台;
-
2013年,这个创业公司宣布破产,将其产品对外开源——Docker;
-
2014年,获得了$4000w融资(C轮);
-
2015年,获得了$9500w融资(D轮);
2.2 Docker的思想
集装箱:会将所有需要的内容放到不同的集装箱中,谁需要这些环境就直接拿到这个集装箱就可以了。
标准化:
运输的标准化:Docker有一个码头,所有上传的集装箱都放在了这个码头上,当谁需要某一个环境,就直接指派小海豚去搬运这个集装箱就可以了。
命令的标准化:Docker提供了一些列的命令,帮助我们去获取集装箱等等操作。
提供了REST的API:衍生出了很多的图形化界面,Rancher。
隔离性:Docker在运行集装箱内的内容时,会在Linux的内核中,单独的开辟一片空间,这片空间不会影响到其他程序。
中央仓库|注册中心:超级码头,上面放的就是集装箱
镜像:就是集装箱
容器:运行起来的镜像
Docker示意图 |
---|
![]() |
三、Docker的安装
3.1 下载Docker依赖的环境
想安装Docker,需要先将依赖的环境全部下载,就像Maven依赖JDK一样
yum -y install yum-utils device-mapper-persistent-data lvm2
3.2 指定Docker镜像源
默认下载Docker会去国外服务器下载,速度较慢,我们可以设置为阿里云镜像源,速度更快
yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
3.3 安装Docker
依然采用yum的方式安装
yum makecache fast yum -y install docker-ce
3.4 启动Docker
安装成功后,需要手动启动,设置为开机自启,并测试一下Docker
# 启动Docker服务 systemctl start docker # 设置开机自动启动 systemctl enable docker
四、Docker的中央仓库
Docker官方的中央仓库:
国内的镜像网站:
https://c.163yun.com/hub#/home
http://hub.daocloud.io/ (推荐使用)
在公司内部会采用私服的方式拉取镜像,需要添加配置,如下……
# 需要创建/etc/docker/daemon.json,并添加如下内容 { "registry-mirrors": ["https://registry.docker-cn.com"], "insecure-registries": ["ip:port"] } # 重启两个服务 systemctl daemon-reload systemctl restart docker
五、镜像的操作
5.1 拉取镜像
从中央仓库拉取镜像到本地
官方仓库: http://hub.daocloud.io/
docloud:http://hub.daocloud.io/ 推荐使用
docker pull 镜像名称[:tag] # 举例:docker pull daocloud.io/library/tomcat:8.5.15-jre8
5.2 查看本地全部镜像
查看本地已经安装过的镜像信息,包含标识,名称,版本,更新时间,大小
docker images
5.3 删除本地镜像
镜像会占用磁盘空间,可以直接手动删除,表示通过查看获取
docker rmi 镜像的标识
5.4 镜像的导入导出
如果因为网络原因可以通过硬盘的方式传输镜像,虽然不规范,但是有效,但是这种方式导出的镜像名称和版本都是null,需要手动修改
# 将本地的镜像导出 docker save -o 导出的路径 镜像id # 加载本地的镜像文件 docker load -i 镜像文件 # 修改镜像名称 docker tag 镜像id 新镜像名称:版本
六、容器操作
6.1 运行容器
运行容器需要制定具体镜像,如果镜像不存在,会直接下载
# 简单操作 docker run 镜像的标识|镜像名称[:tag] # 常用的参数 docker run -d -p 宿主机端口:容器端口 --name 容器名称 镜像的标识|镜像名称[:tag] # -d:代表后台运行容器 # -p 宿主机端口:容器端口:为了映射当前Linux的端口和容器的端口 # --name 容器名称:指定容器的名称
示例:
[root@VM-12-7-centos ~]# docker images REPOSITORY TAG IMAGE ID CREATED SIZE tomcat 8.5 4560891aa934 5 years ago 113MB tomcat 9.0 99e8759f710c 5 years ago 334MB [root@VM-12-7-centos ~]# docker run -d -p 8001:8080 --name docker1 99 19ac9fee917898996323e1885e7a9e98bdf8419f9324f36a0a403ba5c4ee1dfd [root@VM-12-7-centos ~]# docker run -d -p 8002:8080 --name docker2 45 6fb2a10bc34e5fac515cbe45f668058e07933a7dd469d87edaa3cd68e06ba56d
6.2 查看正在运行的容器
查看全部正在运行的容器信息
docker ps [-qa] # -a:查看全部的容器,包括没有运行 # -q:只查看容器的标识
查看容器详情:
[root@VM-12-7-centos ~]# docker ps -a CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 6fb2a10bc34e 45 "catalina.sh run" 7 minutes ago Up 7 minutes 0.0.0.0:8002->8080/tcp, :::8002->8080/tcp docker2 19ac9fee9178 99 "catalina.sh run" 8 minutes ago Up 8 minutes 0.0.0.0:8001->8080/tcp, :::8001->8080/tcp docker1
6.3 查看容器日志
查看容器日志,以查看容器运行的信息
docker logs -f 容器id # -f:可以滚动查看日志的最后几行
6.4 进入容器内容部
可以进入容器内部进行操作
docker exec -it 容器id bash
exit退出容器
6.5 复制内容到容器
将宿主机的文件复制到容器内部的指定目录
一般将 war 文件复制到tomcat 的 webapp 目录下
docker cp 文件名称 容器id:容器内部路径 示例: docker cp fmmall.war id:/usr/local/tomcat/webapp
6.6 重启&启动&停止&删除容器
容器的启动,停止,删除等操作,后续经常会使用到
# 重新启动容器 docker restart 容器id # 启动停止运行的容器 docker start 容器id # 停止指定的容器(删除容器前,需要先停止容器) docker stop 容器id # 停止全部容器 docker stop $(docker ps -qa) # 删除指定容器 docker rm 容器id # 删除全部容器 docker rm $(docker ps -qa)
七、Docker应用-项目部署
7.1 Docker安装Tomcat
运行Tomcat容器,为部署SSM工程做准备
docker run -d -p 8080:8080 --name tomcat daocloud.io/library/tomcat:8.5.15-jre8
7.2 Docker安装MySQL
运行MySQL容器,为部署SSM工程做准备
docker run -d -p 3306:3306 --name mysql -e MYSQL_ROOT_PASSWORD=root daocloud.io/library/mysql:5.7.4
7.3 部署SSM工程
修改SSM工程环境,设置为Linux中Docker容器的信息
通过Maven的package重新打成war包
将Windows下的war包复制到Linux中
通过docker命令将宿主机的war包复制到tomcat容器内部
/usr/local/tomcat/webapps
测试访问SSM工程
后续数据卷、自定义镜像、compose、CICD(持续集成与持续部署 )
八、数据卷
为了部署SSM的工程,需要使用到cp的命令将宿主机内的ssm.war文件复制到容器内部。
数据卷:将宿主机的一个目录映射到容器的一个目录中。
可以在宿主机中操作目录中的内容,那么容器内部映射的文件,也会跟着一起改变。
8.1 创建数据卷
创建数据卷之后,默认会存放在一个目录下 /var/lib/docker/volumes/数据卷名称/_data
docker volume create 数据卷名称
8.2 查看数据卷详情
查看数据卷的详细信息,可以查询到存放路径,创建时间等等
docker volume inspect 数据卷名称
8.3 查看全部数据卷
查看全部数据卷信息
docker volume ls
8.4 删除数据卷
删除指定数据卷
docker volume rm 数据卷名称
8.5 容器映射数据卷
映射有两种方式:
通过数据卷名称映射,如果数据卷不存在。Docker会帮你自动创建,会将容器内部自带的文件,存储在默认的存放路径中。
通过路径映射数据卷,直接指定一个路径作为数据卷的存放位置。但是这个路径下是空的。
# 通过数据卷名称映射 docker run -v 数据卷名称:容器内部的路径 镜像id # 通过路径映射数据卷 docker run -v 路径:容器内部的路径 镜像id
九、Dockerfile自定义镜像
我们可以从中央仓库下载一个镜像,也可以自己手动去制作一个镜像,需要通过Dockerfile去指定自定义镜像的信息
9.1 Dockerfile
创建自定义镜像就需要创建一个Dockerfile,如下为Dockerfile的语言
from: 指定当前自定义镜像依赖的环境 copy: 将相对路径下的内容复制到自定义镜像中 workdir: 声明镜像的默认工作目录 run: 执行的命令,可以编写多个 cmd: 需要执行的命令(在workdir下执行的,cmd可以写多个,只以最后一个为准) # 举个例子,制作SSM容器镜像,而且ssm.war要放在Dockerfile的同级目录下 from daocloud.io/library/tomcat:8.5.15-jre8 copy ssm.war /usr/local/tomcat/webapps
9.2 通过Dockerfile制作镜像
编写完Dockerfile后需要通过命令将其制作为镜像,并且要在Dockerfile的当前目录下,之后即可在镜像中查看到指定的镜像信息,注意最后的 .
docker build -t 镜像名称[:tag] .