Docker如何給Springboot項目動態傳參


背景

最近有些初學Docker的朋友問到,想通過docker-compose.yml來動態給微服務傳參,而不是每次都要在項目配置文件硬編碼,然后構建服務鏡像,最后打包發布經過一些列流程才能更新配置,那能不能直接通過docker-compose.yml里把一些配置項放到環境變量,然后springboot項目自動從環境變量獲取參數呢?


場景

假設現在有一個Springboot項目,它里面有一個數據庫的配置項,但是不同的數據庫測試環境(DEV\SIT\UAT),數據庫ip有多個,想使用同一個Springboot項目鏡像,可以隨時切換數據庫配置,簡單來說就是你的Springboot應用的數據庫配置應該是通過外部傳入,而不是hardcode.

Springboot應用里有個數據庫配置如下:

spring.datasource.url = jdbc:mysql://192.168.0.11:3306/db?useUnicode=true&characterEncoding=utf8
#配置數據庫用戶名
spring.datasource.username = sa
#配置數據庫密碼
spring.datasource.password = sa

解決方案

利用SpEL表達式,動態從環境變量獲取數據庫配置
接下來我們在Springboot配置文件把數據庫配置用spEL表達式替換

#配置數據庫鏈接
spring.datasource.url = jdbc:mysql://${DB_HOST}:${DB_PORT}/${DB_NAME}?useUnicode=true&characterEncoding=utf8
#配置數據庫用戶名
spring.datasource.username = ${DB_USER}
#配置數據庫密碼
spring.datasource.password = ${DB_PASSWORD}

docker-compose.yml配置我們的數據庫參數

version: '3'
services:
  web:
    restart: always
    depends_on:
      - db
    image: springboot-app-image
    build: .
    ports:
      - 8080:8080
    environment:
      - DB_HOST=192.168.0.11
      - DB_PORT=3306
      - DB_USER=root
      - DB_PASSWORD=123456
      - DB_NAME=db
    networks:
      - credit-facility-net
    deploy:
      mode: replicated
      replicas: 3
      restart_policy:
        condition: on-failure
        delay: 5s
        max_attempts: 3
      update_config:
        parallelism: 1
        delay: 10s

這樣我們的Springboot應用就可以在啟動容器服務的時候動態獲取數據庫配置了


有興趣的朋友,歡迎加我公眾號一起交流,有問題可以留言,平時工作比較忙,我也抽時間盡量回復每位朋友的留言,謝謝!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM