• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    Docker下Tomcat容器中使用Mysql的方法

    在这里我们使用Tomcat容器来运行war包,不过作为一个网站一个程序,如果需要用到数据库的,那么Tomcat容器中如何连接Mysql呢?

    已经pull了tomcat和mysql镜像,可以使用docker的连接系统(–link)连接多个容器方式解决tomcat容器中使用mysql

    [root@izbp1b5k5bjps0dw8owk7tz ~]# docker images
    REPOSITORY      TAG         IMAGE ID      CREATED       SIZE
    tomcat        latest       2d084b11164d    7 days ago     463MB
    mysql        5.7.22       66bc0f66b7af    2 weeks ago     372MB
    [root@izbp1b5k5bjps0dw8owk7tz ~]# docker ps
    CONTAINER ID    IMAGE        COMMAND       CREATED       STATUS       PORTS        NAMES
    [root@izbp1b5k5bjps0dw8owk7tz ~]# 

    先启动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:5.7.221

    命令说明:

    •–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:以守护进程方式运行

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

    运行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 tomcat1

    命令说明:

    •–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
    [root@izbp1b5k5bjps0dw8owk7tz 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:5.7.22
    c7378e84c19b0baa448d687c089ef8cc0ce058f71b2f79d8801fc9be7bd2c5b4
    [root@izbp1b5k5bjps0dw8owk7tz mysql]# docker ps
    CONTAINER ID    IMAGE        COMMAND         CREATED       STATUS       PORTS          NAMES
    c7378e84c19b    mysql:5.7.22    "docker-entrypoint.s…"  6 seconds ago    Up 5 seconds    0.0.0.0:3306->3306/tcp  mysql
    [root@izbp1b5k5bjps0dw8owk7tz logs]# 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
    1458f532ef36e12ad49b4a5d90ff9b38abed00986094225354594a5fe7591362
    [root@izbp1b5k5bjps0dw8owk7tz logs]# docker ps
    CONTAINER ID    IMAGE        COMMAND         CREATED       STATUS       PORTS          NAMES
    1458f532ef36    tomcat       "catalina.sh run"    3 seconds ago    Up 2 seconds    0.0.0.0:8080->8080/tcp  tomcat
    c7378e84c19b    mysql:5.7.22    "docker-entrypoint.s…"  About a minute ago  Up About a minute  0.0.0.0:3306->3306/tcp  mysql

    总结

    以上所述是小编给大家介绍的Docker中Tomcat容器使用Mysql容器的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

    上一篇:docker守护进程的配置和操作的方法
    下一篇:Nginx + Tomcat实现请求动态数据和请求静态资源的分离详解
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    Docker下Tomcat容器中使用Mysql的方法 Docker,下,Tomcat,容器,中,使用,