WHCSRL 技术网

Docker 部署 MySQL & Tomcat 容器

1.部署 MySQL 容器

docker run --name mysql -p 3306:3306 -v /home/mysql/conf:/etc/mysql/conf.d -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql

命令说明:

  • –name:自定义别名

  • -p 3306:3306:将容器的 3306 端口映射到主机的 3306 端口

  • -v /home/mysql/conf:/etc/mysql/conf.d:将主机 /home/mysql/conf/my.cnf 挂载到容器的 /etc/mysql/my.cnf

  • -v /home/mysql/data:/var/lib/mysql :将主机 /home/mysql/data 目录挂载到容器的 /var/lib/mysql

  • -e MYSQL_ROOT_PASSWORD=123456:初始化 root 用户的密码

  • -d:以守护进程方式运行

2.部署 Tomcat 容器

docker run --name tomcat -p 8080:8080 -v /etc/localtime:/etc/localtime:ro -v /home/tomcat/logs:/usr/local/tomcat/logs -d --link mysql:db tomcat

注:运行的mysql暴露端口(-p 3306:3306),如果在生产环境,为了安全也可以不向外暴露端口,之后在运行tomcat容器可以通过(--link)指定容器来使用mysql

命令说明:

  • –name:自定义别名

  • -p 8080:8080:将容器的 8080 端口映射到主机的 8080 端口

  • -v /etc/localtime:/etc/localtime:ro:挂载localtime文件到容器内,保证两者所采用的时区是一致的

  • -v /home/tomcat/logs:/usr/local/tomcat/logs:将主机 /home/tomcat/logs 目录挂载到容器的 /usr/local/tomcat/logs

  • -d:以守护进程方式运行

  • –link mysql:db:告诉当前容器需要使用mysql容器,并命名为db

注:tomcat容器中通过db访问mysql了

附: Java中数据库连接参考语句:

jdbc_url=jdbc:mysql://db:3306/databasename?useUnicode=true&characterEncoding=utf8
推荐阅读