安装Docker
更新yum包
yum update
安装需要的软件包,vum-util 提供yum-config-manager功能,另外两个是devicemapper动依赖的(一般更新完都有了)
[root@msr-server ~]# yum -y install gcc
[root@msr-server ~]# yum -y install gcc-c++
[root@msr-server ~]# yum install -y yum-utils device-mapper-persistent-data lvm2
设置docker yum源
[root@msr-server ~]# sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
安装docker
yum makecache fast
yum install docker -ce
启动docker,加入开机选项,验证安装
[root@msr-server ~]# systemctl start docker
[root@msr-server ~]# systemctl enable docker
[root@msr-server ~]# docker version
卸载
yum list installed | grep docker
yum -y remove docker-ce.x86_64
...
中央仓库
官网镜像:https://hub.docker.com/
网易:http://c.163.com/hub
daocloud:http://hub.daocloud.io/
修改注册文件
修改/etc/docker/daemon.josn,若文件不存在,则手动创建:
添加以下内容:
{
"registry-mirrors":["https://docker-cn.com"],
"insecure-registries":["ip:port"] //替换相应的IP和端口即可
}
重启服务:
systemctl daemon-reload
systermctl restart docker
docker镜像操作
docker pull 镜像名称[:tag]
docker pull daocloud.io/library/tomcat:8.5.15-jre8
查看本地镜像
docker images
刪除本地镜像
docker rmi 镜像的标识
镜像的导入和导出
docker save -o到处的路径 镜像id
docker load -i 镜像文件
修改镜像名称
docker tag 镜像id 新镜像名称:版本
Docker容器操作
运行
docker run 镜像的标识镜像名称[:tag]
常用参数
docker run -d -p宿主机端口∶容器端口 --name 容器名称 镜像的标识镜像名称[:tag]
查看正在运行的容器
docker ps 【-aq】
-a 查看全部的容器,保罗没有运行
-q 只查看容器得到标识
查看容器的日志
docker logs -f 容器id
-f可以滚动查看日志的最后几行
删除容器(前提是先停止容器)
#停止指定的容器
docker stop 容器ID
#停止全部容器
docker stop $(docker ps -qa)
#删除指定容器
docker rm 容器id
#删除全部容器
docker rm $(docker ps -qa)
#启动容器
docker start 容器ID
Docker应用
- 创建一个文件夹,例如 demo:
- 创建一个文件佳WEB—INF
- 在WEB—INF中创建一个文件web.xml
- 在web.xml中添加以下内容:
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee
http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
version="3.1"
metadata-complete="true">
</web-app>
接下来创建一个index.html页面 ,内容如下:
hello docker!
### 创建mysql容器 docker pull daocloud.io/library/mysql:5.7.5-m15 #### 查看mysql镜像 docker images #### 创建mysql容器 docker run -d -p 3306:3306 -e MYSQL_ROOT_PASSWORD=root --name mysql 镜像tag创建Tomcat容器
docker pull daocloud.io/library/tomcat:8.0.45
docker run -d -p 8080:8080 --name tomcat 镜像tag
将项目部署到Tomcat
####上传项目
进入容器目录
docker exec -it 容器tag bash
将项目拷贝到tomcat容器下的webapps目录下边
docker cp demo 容器id:/usr/local/tomcat/webapps
查看tomcat运行日志
docker logs -f 容器tag
Docker数据卷
为了不输我们的demo工程,需要使用到cp命令将宿主机的demo文件复制到容器内部
数据卷:
将宿主机的一个目录,映射到容器的一个目录中,可以在宿主机中操作目录中的内容,那么容器内部映射的文件,也会跟着一起改变
创建文件
docker volume create 数据卷名称
创建数据卷之后,默认会存放在一个目录下/var/lib/docker/volumes/数据卷名称/_data
查看数据卷的详细名称
docker volume inspect 数据卷名称
查看全部的数据卷
docker volume ls
删除数据卷
docker volume rm 数据卷名称
应用数据卷
当你映射数据卷后,如果数据卷不存在,Docker会帮助你自动创建 会将容器内部的自带的文件,存储在默认的存放路径中
docker run -v 数据卷名称∶容器内部的路径 镜像id
#直接指定一个路径作为数据卷的存放位置。这个路径下是空的。
docker run -v 路径∶容器内部的路径 镜像id
Dockerfile
什么是 Dockerfile
Dockerfile是一个包含用于组合映像的命令的文本文档。可以使用在命令行中调用的任何命令。 Docker通过读取 Dockerfile 中的指令自动生成映像。
docker build 命令用于从Dockerfle构建映像。可以在 docker build 命令中使用f 标志指向文件系统中任何位置的Dockerfile.
例
docker build -f /path/to/a/Dockerfile
Dockerfile的基础结构
Dockerfile 一般分为四部分:
1基础镜像信息
2维护信息
3.镜像操作指令
4.容器启动时执行指令
Dockerfile文件说明
Docker以从上到下的顺序运行Dockerfile的指令。为了指定基本映像,第一条指令必须是 FROM。一个声明以 # 字符开头则被视为注
释。可以在Docker文件中使用 RUN, CMD, FROM, EXPOSE, ENV 等指令。
下载安装Docker-Compose
需求
之前运行一个镜像,需要添加大量的参数
可以通过Docker-Compose编写这些参数
Docker-Compose可以帮助我们批量的管理容器。
只需要通过一个docker-compose.yml文件去维护即可
下载安装
Docker-Compose管理Mysql和tomcat容器
version: '3.8'
services:
mysql: # 服务的名称
restart: always # 代表只要Docker启动,那么这个容器就跟着一起启动
image: daocloud.io/library/mysql:5.7.5-m15 # 指定镜像路径
container_name: mysql # 指定容器名称
ports:
- 3306:3306 # 指定端口号的映射
environment:
MYSQL_ROOT_PASSWORD: 123456 # 指定MySQL的ROOT用户登录密码
TZ: Asia/Shanghai # 指定时区
volumes:
- /home/docker_mysql/:/var/lib/mysql # 映射数据卷
tomcat:
restart: always # 代表只要Docker启动,那么这个容器就跟着一起启动
image: daocloud.io/library/tomcat:8.5.15-jre8 # 指定镜像路径
container_name: tomcat # 指定容器名称
ports:
- 8080:8080
environment:
TZ: Asia/Shanghai
volumes:
- /home/tomcat_webapps:/usr/local/tomcat/webapps
- /home/tomcat_logs:/usr/local/tomcat/logs