docker部署java项目,如何docker-compose内的jdk版本与本地版本保持一致

目录结构

/var
└── data
    ├──  docker-compose.yml 
    └── docker
        ├── Dockerfile
        └── jdk-8u401-linux-x64.tar.gz


dockerfile文件

FROM ubuntu:latest

# 拷贝本地服务器上的 JDK 安装包到 Docker 镜像中
COPY jdk-8u401-linux-x64.tar.gz /jdk-8u401-linux-x64.tar.gz

# 创建目标目录
RUN mkdir -p /usr/lib/jvm

# 解压 JDK 安装包
RUN tar -zxvf /jdk-8u401-linux-x64.tar.gz  -C /usr/lib/jvm

# 设置环境变量
ENV JAVA_HOME /usr/lib/jvm/jdk1.8.0_401
ENV PATH $PATH:$JAVA_HOME/bin

# 这里可以添加其他必要的配置或依赖项

CMD ["/bin/bash"]

docker-compose.yml 文件

version: '2'

networks:
  network:
    ipam:
      driver: default
      config:
        - subnet: '177.7.0.0/16'

services:
  java:
    build:
      context: ./docker  // docker-compose文件所在的下一级目录 docker
      dockerfile: Dockerfile
    container_name: java
    ports:
      - 8080:8080
    privileged: true
    networks:
      network:
        ipv4_address: 177.7.0.13
    depends_on:
      - redis
      - mysql
    restart: unless-stopped
    volumes:
      - /var/data/java/server.jar:/server.jar
      - /var/data/java/logs:/logs
      - /etc/localtime:/etc/localtime
    environment:
      TZ: Asia/Shanghai
    entrypoint: java -jar -Xms4096M -Xmx4096M -Xmn256M -Xss256K /server.jar --spring.profiles.active=prod

解决策略
要解决这个问题,你可以尝试以下步骤:

检查和设置 JVM 的默认字符编码
在启动 JVM 时,你可以通过设置 -Dfile.encoding=UTF-8 来明确指定字符编码。例如,可以在 Java 应用的启动命令中添加这个参数:

java -Dfile.encoding=UTF-8 -jar your-application.jar

启动后发现日志乱码
在这里插入图片描述

检查和更新日志配置
检查你的日志配置文件(如 log4j.properties, log4j2.xml, logback.xml),确保日志 Appender 使用的字符编码是 UTF-8 或其他适当的编码。例如,对于 Logback,你可以在配置文件中这样设置:

<configuration>
    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <charset>UTF-8</charset>
            <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
        </encoder>
    </appender>

    <root level="debug">
        <appender-ref ref="STDOUT" />
    </root>
</configuration>

清理和重试
更改设置后,确保重启应用程序以应用新的配置,并观察日志输出是否正常。

测试不同的环境
如果问题仅在特定环境中出现(如只在生产环境中出现乱码),尝试检查该环境的特定配置或终端显示设置。

编码检测工具
使用工具(如 Linux 的 file 命令或在线编码检测工具)检查日志文件的实际编码,确认是否与预期一致。

通过这些步骤,你应该能够诊断并解决因 JDK 版本更改引起的日志乱码问题。如果问题仍然存在,可能需要更详细地检查应用程序的代码,特别是那些处理字符串和日志输出的部分。

### 使用 Docker Compose 配置 JDK 17 运行 Java 应用程序 #### 准备工作 为了确保能够顺利使用 Docker Compose部署基于 JDK 17 的 Java 应用,需提前完成如下准备工作: - **安装 DockerDocker Compose**:依据不同操作系统的要求来安装这两个工具。对于 CentOS 用户来说,可以参照特定的指南进行操作[^2]。 #### 创建必要的文件结构 在目标项目根目录创建以下子目录和文件: - `app/`:放置源码的位置。 - `Dockerfile`:定义构建镜像所需的指令集。 - `docker-compose.yml`:描述服务及其依赖关系的配置文件。 #### 编写 Dockerfile 编写一个简单的 Dockerfile 文件用于指定基础镜像以及设置环境变量等必要参数: ```dockerfile FROM eclipse-temurin:17-jdk-alpine WORKDIR /usr/src/app COPY . . CMD ["java", "-jar", "your-application.jar"] ``` 此段代码选择了官方提供的 Eclipse Temurin 发布版作为基础镜像,并指定了工作路径默认执行命令[^1]。 #### 构建 docker-compose.yml 文件 接下来,在同一级目录下新建名为 `docker-compose.yml` 的 YAML 格式的文档,其内容应类似于下面这样: ```yaml version: '3' services: app-service: build: . ports: - "8080:8080" environment: JAVA_OPTS: "" volumes: - ./app:/usr/src/app ``` 上述配置说明了要建立的服务名称 (`app-service`) ,并设置了端口映射、环境变量以及其他选项;同时通过 `build:` 字段告知 Docker Compose 将当前目录下的上下文发送给 Docker Daemon 并按照其中的 Dockerfile 构建新镜像。 #### 启动应用 当所有的前置条件都已满足之后,只需在一个终端窗口内切换到包含有 `docker-compose.yml` 文件所在的目录位置,接着输入命令 `docker-compose up --build` 即可启动整个流程,这会自动拉取所需的基础镜像(如果本地不存在的话),然后根据所提供的 Dockerfile 制作自定义镜像最后运行容器化后的 Java 应用程序实例。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值