七、Docker应用部署
- 容器内的网络服务和外部机器不能直接通信
- 外部机器和宿主机可以直接通信
- 宿主机和容器可以直接通信
- 当容器中的网络服务需要被外部机器访问时,可以将容器中提供服务的端口映射到宿主机的端口上。外部机器访问宿主机的该端口,从而间接访问容器的服务。
- 这种操作成为端口映射
MySQL部署:
1、搜索MySQL镜像:
docker search mysql
2、拉取MySQL镜像:
docker pull mysql:5.6
3、创建容器,设置端口映射、目录映射
#在/root目录下创建mysql目录用于存储mysql数据信息
mkdir ~/mysql
cd ~/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.6
$PWD相当于/root/mysql
参数说明:
- -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用户的密码。
4、进入容器
docker exec -it c_mysql /bin/bash
5、进入mysql
mysql -uroot -p123456
6、使用Navicat连接mysql
新建user表,并在容器中的mysql中查看
Tomcat部署:
1、搜索tomcat镜像:
docker search tomcat
2、拉取tomcat镜像:
docker pull tomcat
3、创建容器,设置端口映射、目录映射
#在/root目录下创建tomcat目录用于存储tomcat数据信息
mkdir ~/tomcat
cd ~/tomcat
docker run -id --name=c_tomcat \
-p 8088:8080 \
-v $PWD:/usr/local/tomcat/webapps \
tomcat
参数说明:
- -p 8088:8080:将容器的8080端口映射到主机的8088端口
- -v $PWD:/usr/local/tomcat/webapps:将主机中当前目录挂载到容器的webapps
4、使用外部机器访问tomcat(在tomcat中创建1.HTML并写入文字)
Nginx部署:
1、搜索nginx镜像:
docker search nginx
2、拉取nginx镜像:
docker pull nginx
3、创建容器,设置端口映射、目录映射
#在/root目录下创建nginx目录用于存储nginx数据信息
mkdir ~/nginx
cd ~/nginx
mkdir conf
cd conf
#在~/nginx/conf/下创建nginx.conf文件,粘贴下面内容
vim 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;
}
docker run -id --name=c_nginx \
-p 86:80 \
-v $PWD/conf/nginx.conf:/etc/nginx/nginx.conf \
-v $PWD/logs:/var/log/nginx \
-v $PWD/html:/usr/share/nginx/html \
nginx
注:/conf/nginx.conf需要自己创建
参数说明:
-p 87:80:将容器的80端口映射到宿主机的87端口。
-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目录再run
4、使用外部机器访问nginx。(在nginx中的html中创建2.HTML并写入文字)
Redis部署:
1、搜索redis镜像:
docker search redis
2、拉取redis镜像:
docker pull redis:5.0
3、创建容器,设置端口映射、目录映射
docker run -id --name=c_redis -p 6379:6379 redis:5.0
4、使用外部机器连接redis
./redis-cli.exe -h 192.168.67.129 -p 6379
windoes版本redis安装:
在redis下载目录下的cmd输入
redis-server.exe redis.windows.conf
重新打开一个cmd,输入redis-cli验证redis临时服务是否启动
使用set命令,对redis数据库进行数据存储和获取
创建永久服务,重新打开cmd,输入
redis-server.exe --service-install redis.windows.conf --loglevel verbose
查看任务管理器,redis服务停止,启动服务:
redis-server --service-start