docker-java应用部署

  • Post author:
  • Post category:java



目录


1端口映射


2.Mysql部署


3.Tomcat部署


4.Nginx部署


5.Redis部署


1端口映射

容器内的网络服务和外部机器不能直接通信
外部机器和宿主机可以直接通信
宿主机和容器可以直接通信
当容器中的网络服务需要被外部机器访问时,可以将容器中提供服务的端口映射到宿主机的端口上。外部机器访问宿主机的该端口,从而间接访问容器的服务。
这种操作称为:端口映射
-p 宿主机端口:容器端口

2.Mysql部署

在Docker容器中部署MySQL,并通过外部mysql客户端操作MySQL Server。
1.搜索mysql镜像
2.拉取mysql镜像
3.创建容器
4.参数说明
5.操作容器中的mysql
6.使用外部机器连接容器中的mysql
# 搜索mysql镜像
docker search mysql
# 拉取mysql镜像
docker pull mysql:5.7.41
# 创建容器,设置端口映射、目录映射
# 在/docker-data目录下创建mysql目录用于存储mysql数据信息
mkdir -p /docker-data/mysql
cd /docker-data/mysql
docker run -id \
-p 3307:3306 \
--name=c_mysql \
-v /docker-data/mysql/conf:/etc/mysql/conf.d \
-v /docker-data/mysql/logs:/logs \
-v /docker-data/mysql/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=admin123456 \
mysql:5.7.41

4.参数说明


  • -p 3307:3306

    :将容器的 3306 端口映射到宿主机的 3307 端口。


  • -v /docker-data/mysql/conf:/etc/mysql/conf.d

    :将主机当前目录下的 conf/my.cnf 挂载到容器的 /etc/mysql/my.cnf。配置目录


  • -v /docker-data/mysql/logs:/logs

    :将主机当前目录下的 logs 目录挂载到容器的 /logs。日志目录


  • -v /docker-data/mysql/data:/var/lib/mysql

    :将主机当前目录下的data目录挂载到容器的 /var/lib/mysql 。数据目录


  • -e MYSQL_ROOT_PASSWORD=admin123456:

    初始化 root 用户的密码。

5.进入容器,操作mysql

docker exec -it c_mysql /bin/bash
mysql -h 127.0.0.1 -P 3306 -u root -padmin123456
> show databases;

6.连接容器中的mysql

宿主机ip:宿主机端口3307
mysql -h 宿主机ip -P 3307 -u root -padmin123456

3.Tomcat部署

在Docker容器中部署Tomcat,并通过外部机器访问Tomcat部署的项目。
1.搜索tomcat镜像
2.拉取tomcat镜像
3.创建容器
4.参数说明
5.部署项目
6.测试访问
# 搜索tomcat镜像

docker search tomcat
# 拉取tomcat镜像

docker pull tomcat:8
# 创建容器,设置端口映射、目录映射

# 在/root目录下创建tomcat目录用于存储tomcat数据信息
mkdir -p /docker-data/tomcat
cd /docker-data/tomcat
docker run -id --name=c_tomcat \
-p 8080:8080 \
-v /docker-data/tomcat/webapps:/usr/local/tomcat/webapps \
tomcat:8

4.参数说明


-p 8080:8080:

将容器的8080端口映射到主机的8080端口


-v $PWD:/usr/local/tomcat/webapps:

将主机中当前目录挂载到容器的webapps

5.使用外部机器访问tomcat

宿主机ip:宿主机端口8080

4.Nginx部署

在Docker容器中部署Nginx,并通过外部机器访问Nginx
1.搜索Nginx镜像
2.拉取Nginx镜像
3.创建容器
5.参数说明
4.测试访问
# 搜索nginx镜像

docker search nginx
# 拉取nginx镜像

docker pull nginx
3.创建容器,设置端口映射、目录映射
# 在/root目录下创建nginx目录用于存储nginx数据信息
mkdir -p /docker-data/nginx/conf && cd /docker-data/nginx/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_s    ent "$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 80:80 \
-v /docker-data/nginx/conf/nginx.conf:/etc/nginx/nginx.conf \
-v /docker-data/nginx/logs:/var/log/nginx \
-v /docker-data/nginx/html:/usr/share/nginx/html \
nginx

5.参数说明


  • -p 80:80

    :将容器的 80端口映射到宿主机的 80 端口。


  • -v /docker-data/nginx/conf/nginx.conf:/etc/nginx/nginx.conf

    :将主机当前目录下的 /conf/nginx.conf 挂载到容器的 :/etc/nginx/nginx.conf。配置目录


  • -v /docker-data/nginx/logs:/var/log/nginx

    :将主机当前目录下的 logs 目录挂载到容器的/var/log/nginx。日志目录

6.使用外部机器访问nginx

cd /docker-data/nginx/html
# 文件随便写内容
mkdir index.html

宿主机id:80访问即可

5.Redis部署

在Docker容器中部署Redis,并通过外部机器访问Redis。
1.搜索Redis镜像
2.拉取Redis镜像
3.创建配置文件映射
4.创建容器
5.测试访问
1.搜索redis镜像

docker search redis
2.拉取redis镜像

docker pull redis:6.0.10

3.创建配置文件
mkdir -p /docker-data/redis/conf && cd /docker-data/redis/conf
vi redis.conf


bind 0.0.0.0
protected-mode yes
port 6379
tcp-backlog 511
timeout 0
tcp-keepalive 0
loglevel notice
logfile ""
databases 12
save 900 1
save 300 10
save 60 10000
stop-writes-on-bgsave-error yes
rdbcompression yes
rdbchecksum yes
dbfilename dump.rdb
dir ./
requirepass admin123

4.创建容器,设置端口映射
docker run -it -d --name redis -m 200m \
-p 36379:6379 --privileged=true \
--net mynet --ip 172.18.0.9 \
-v /docker-data/redis/conf:/usr/local/etc/redis \
-e TZ=Asia/Shanghai redis:6.0.10 \
redis-server /usr/local/etc/redis/redis.conf

5.使用redis客户端连接即可



版权声明:本文为adminBfl原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。