1.数据卷
(1)思考:我们删除容器时,容器中的数据是否会被删除--------会被删除
(2)思考:外界是否可以与容器之间进行交互:外界文件是否可以放入到容器中
---------无法直接进行交互
(3)思考:容器与容器之间是否可以进行数据共享?-----------无法进行数据共享
解决办法:我们可以是用数据卷来解决问题
2.数据卷的概念:
概念:
数据卷是宿主机中的一个目录或文件当容器目录和数据卷目录绑定后对方的修改会立即同步
一个数据卷可以被多个容器同时挂载
一个容器也可以被挂载多个数据卷
作用:
(1)解决数据持久化问题
(2)解决外部机器和容器的间接通讯问题
(3)解决容器之间的数据交换
数据卷: 它就是宿主机中一个普通的文件或目录,只是该文件或目录被挂载到相应容器中的某个目录或文件上。
3.如何定义数据卷:
创建容器时,使用-v参数 设置数据卷
docker run ... -v 宿主机目录(文件):容器内目录(文件)...
注意事项:(1)目录必须时绝对路径
(2)如果目录不存在,会自动创建
(3)可以挂在多个数据卷
(1)数据卷和容器中的目录内容会进行同步。
(2)当容器被删除后,再次开启新容器时 只要和数据卷绑定 那么原来的数据不会丢失
(3)多个容器之间可以通过数据卷完成数据的共享
创建新的容器c3 ,并在c3_data目录中创建qwq3,同时c2中的数据也会改变
4.使用docker安装软件
使用docker安装任何软件,步骤非常简单,而且无需担心系统环境的问题。
4.1 docker安装mysql
1.创建目录: mkdir -p /root/mysql
2.切换到mysql目录: cd /root/mysql
3.拉取mysql镜像 : docker pull mysql:5.7
4.创建mysql容器:
docker run -id \
-p 3307:3306 \
--name=c_mysql \
-v $PWD/conf:/etc/mysql/conf.d \
-v $PWD/logs:/logs \
-v $PWD/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=123456 \
mysql:5.7
参数说明:
-p 3307:3306:将容器的 3306 端口映射到宿主机的 3307 端口。
-v $PWD/conf:/etc/mysql/conf.d:将主机当前目录下的 conf/my.cnf 挂载到容器的 /etc/mysql/my.cnf。配置目录
-v $PWD/logs:/logs:将主机当前目录下的 logs 目录挂载到容器的 /logs。日志目录
-v $PWD/data:/var/lib/mysql :将主机当前目录下的data目录挂载到容器的 /var/lib/mysql 。数据目录
-e MYSQL_ROOT_PASSWORD=123456:初始化 root 用户的密码。【env】
验证外界是否可以连接到mysql容器上:
4.2 安装tomcat
1.创建目录: mkdir -p /root/tomcat
2.切换到tomcat目录: cd /root/tomcat
3.拉取tomcat镜像 : docker pull tomcat
4.创建容器:
docker run -id --name=c_tomcat \
-p 8080:8080 \
-v $PWD/webapps:/usr/local/tomcat/webapps \
tomcat
创建容器:
验证:再宿主机中webapps目录下创建 目录 并在test目录下创建一个网页index.html
4.3 安装redis
1.创建目录: mkdir -p /root/redis
2.进入目录: cd /root/redis
3.拉取镜像:docker pull redis
4.创建容器,设置映射端接口: docker run -id --name=c_redis -p 6379:6379 redis:5.0
创建容器:
测试:外部机器连接redis
4.4 安装nginx
拉取镜像:docker pull nginx
# 在/root目录下创建nginx目录用于存储nginx数据信息
mkdir ~/nginx
cd ~/nginx
mkdir conf
cd conf
# 在~/nginx/conf/下创建nginx.conf文件,粘贴下面内容
vi nginx.conf
粘贴下面内容
user nginx;
worker_processes 1;error_log /var/log/nginx/error.log warn;
pid /var/run/nginx.pid;
events {
worker_connections 1024;
}
http {
include /etc/nginx/mime.types;
default_type application/octet-stream;log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';access_log /var/log/nginx/access.log main;
sendfile on;
#tcp_nopush on;keepalive_timeout 65;
#gzip on;
include /etc/nginx/conf.d/*.conf;
}
创建nginx.conf 并粘贴内容
创建容器:
docker run -id --name=c_nginx \
-p 80:80 \
-v $PWD/conf/nginx.conf:/etc/nginx/nginx.conf \
-v $PWD/logs:/var/log/nginx \
-v $PWD/html:/usr/share/nginx/html \
nginx
参数说明:
-p 80:80:将容器的 80端口映射到宿主机的 80 端口。
-v $PWD/conf/nginx.conf:/etc/nginx/nginx.conf:将主机当前目录下的 /conf/nginx.conf 挂载到容器的 :/etc/nginx/nginx.conf。配置目录
-v $PWD/logs:/var/log/nginx:将主机当前目录下的 logs 目录挂载到容器的/var/log/nginx。日志目录
测试:使用外部机器访问nginx
在html数据卷目录下创建一个index.html的文件,内容自己随便写
外部机器访问成功: