gpt4 book ai didi

mysql - docker : accessing MySQL container during Tomcat image build

转载 作者:行者123 更新时间:2023-11-29 10:23:19 26 4
gpt4 key购买 nike

我正在尝试创建 Jahia CMS(数字体验管理器)的 Docker 安装。

我需要:

  1. 一个MySQL容器
  2. 一个 Jahia 容器(嵌入 Tomcat)

诀窍是,在 Jahia 容器构建期间(使用 Expect 安装产品),我需要访问 MySQL 容器(需要连接检查)。

MySQL Dockerfile:

FROM mysql:5.6

Jahia Dockefile:

FROM centos:centos6

# Install dependencies
RUN yum -y update && yum -y install ...

# Download Digital Experience Manager 7.1.1
RUN wget -q https://www.jahia.com/downloads/jahia/digitalexperiencemanager7.1.1/DigitalExperienceManager-EnterpriseDistribution-7.1.1.0-r53717.3663.jar -O /tmp/DigitalExperienceManager.jar

# Download MySQL connector (only needed for standalone db installation)
RUN wget -q http://central.maven.org/maven2/mysql/mysql-connector-java/5.1.44/mysql-connector-java-5.1.44.jar -O /usr/lib/mysql-connector-java-5.1.44.jar

# Launch installation using Expect to automate user input
COPY jahia_conf.exp /tmp/configuration.exp
RUN expect /tmp/configuration.exp

# Start Jahia
/opt/DigitalExperienceManager-EnterpriseDistribution-7.1.1.0/tomcat/bin/catalina.sh jpda run

预期脚本 (jahia_conf.exp)

#!/bin/sh
#!/usr/bin/expect

spawn java -jar /tmp/DigitalExperienceManager.jar -console

# Installation directory
expect "Select target path"
send "/opt/DigitalExperienceManager-EnterpriseDistribution-7.1.1.0\r"

# MySQL connector JAR file
expect "Specify the path to the downloaded driver JAR file"
send "/usr/lib/mysql-connector-java-5.1.44.jar\r"

# Database configuration
expect "Database URL (*)"
send "jdbc:mysql://mysql:3306/jahia?useUnicode=true&characterEncoding=UTF-8&useServerPrepStmts=false\r"

当然,我在镜像构建过程中遇到错误,因为它在数据库 URL 输入后立即检查连接:

An error occurred while establishing the connection to the database com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure

The last packet sent successfully to the server was 0 milliseconds ago. The driver has not received any packets from the server..

事实上,我只是构建 Jahia 镜像,因此 mysql 容器尚无法访问(即使正在运行)。

如何处理这种情况(构建过程中需要访问另一个容器时)?

最佳答案

由于 MySQL 服务器也将位于容器中,我认为您不应该在构建时配置它,因为您不能假设数据库将会启动。

不幸的是,我不知道“expect”工具是如何工作的,但理想情况下,您应该仅在容器启动时链接 Jahia 容器中的数据库。这可以通过配置注入(inject)(环境变量或启动容器时可以注入(inject)的其他内容)来完成

这意味着 MySQL 容器应该将数据库安装在单独的进程中。例如,在我们这边,我们通过直接在数据库上运行 jahia 代码中提供的 SQL 脚本来做到这一点。

使用此解决方案,您可以确保在构建时不需要预安装数据库。

编辑:确实,Jahia 在构建时对数据库进行一些检查,但您可以添加输入,这样 Jahia 实际上不需要在数据库上执行操作。它使用 izpack 自动播放文件。这允许重播安装。

数据库设置部分如下:

<com.izforge.izpack.panels.UserInputPanel id="dbSettings">
<userInput>
<entry key="dbSettings.connection.url.mssql" value="jdbc:sqlserver://DB_SERVER;DatabaseName=DB_NAME;"/>
<entry key="dbSettings.dbms.createTables" value="false"/>
<entry key="dbSettings.connection.username" value="DB_USER"/>
<entry key="dbSettings.dbms.storeFilesInDB" value="false"/>
<entry key="dbSettings.connection.driver.mssql" value="com.microsoft.sqlserver.jdbc.SQLServerDriver"/>
<entry key="dbSettings.connection.password" value="DB_PASSWORD"/>
</userInput>
</com.izforge.izpack.panels.UserInputPanel>

不幸的是,这假设您在某处有一个数据库服务器。在我们这边,我们使用一个假实例,因为我们要求在构建期间不进行安装。

关于mysql - docker : accessing MySQL container during Tomcat image build,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48827265/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com