部署MySQL
1)拉取镜像并运行MySQL容器
# 拉取镜像到本地docker pull dockerhub.icu/library/mysql:5.6# 查看镜像docker images# 本地创建MySQL目录并进入,用于挂载mkdir -p /docker/mysqlcd /docker/mysql/# 运行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 \
dockerhub.icu/library/mysql:5.6
• 参数说明:
o -p 3307:3306:将容器的 3306 端口映射到宿主机的 3307 端口。
o -v $PWD/conf:/etc/mysql/conf.d:将主机当前目录下的 conf/my.cnf 挂载到容器的 /etc/mysql/my.cnf。配置目录
o -v $PWD/logs:/logs:将主机当前目录下的 logs 目录挂载到容器的 /logs。日志目录
o -v $PWD/data:/var/lib/mysql :将主机当前目录下的data目录挂载到容器的 /var/lib/mysql 。数据目录
o -e MYSQL_ROOT_PASSWORD=123456:初始化 root 用户的密码。
2)客户端访问MySQL
docker exec -it c_mysql /bin/bash
mysql -uroot -p123456
部署Tomcat
1)拉取镜像并运行Tomcat容器
# 在宿主机上创建目录
mkdir /docker/tomcat
cd /docker/tomcat/# 运行Tomcat容器
docker run -id --name=c_tomcat \
-p 8080:8080 \
-v $PWD:/usr/local/tomcat/webapps \
tomcat
• 参数说明:
o -p 8080:8080:将容器的8080端口映射到主机的8080端口
-v $PWD:/usr/local/tomcat/webapps:将主机中当前目录挂载到容器的webapps
2)创建页面,外部访问
部署Nginx
宿主机上配置nginx
在宿主机的/docker/nginx/conf/下创建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容器
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• 参数说明:
o -p 80:80:将容器的 80端口映射到宿主机的 80 端口。
o -v $PWD/conf/nginx.conf:/etc/nginx/nginx.conf:将主机当前目录下的 /conf/nginx.conf 挂载到容器的 :/etc/nginx/nginx.conf。配置目录
o -v $PWD/logs:/var/log/nginx:将主机当前目录下的 logs 目录挂载到容器的/var/log/nginx。日志目录
部署Redis
启动redis服务端容器
docker run -id --name=c_redis -p 6379:6379 redis
安装redis客户端
https://github.com/microsoftarchive/redis/releases/tag/win-3.2.100
redis-cli.exe -h 192.168.100.10 -p 6379
扩展:关于Mysql端口映射不出去问题
编辑/etc/sysctl.conf
# 1)编辑这个文件
vi /etc/sysctl.conf
# 2)增加 net.ipv4.ip_forward=1
# 3)重启网络systemctl restart network
拉取镜像
运行MySQL(主机3506->容器3306)
docker run --restart=always -p 3506:3306 --name mysql -v /tmp/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=root -e TZ=Asia/Shanghai -d mysql:5.7.25 --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci --default-time_zone='+8:00'
docker镜像拉取失败问题
配置了很多镜像源后,终于能pull下来镜像
# 编辑/etc/docker/daemon.json文件,如果不存在则新创建一个,内容如下
{"registry-mirrors": ["https://hub.uuuadc.top","https://docker.anyhub.us.kg","https://dockerhub.jobcher.com","https://dockerhub.icu","https://docker.ckyl.me","https://docker.awsl9527.cn"]
}
# 编辑完指向下面两行命令
systemctl daemon-reload
systemctl restart docker
指定镜像地址下载
docker pull dockerhub.icu/library/mysql:5.6