背景
最近有些初學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應用就可以在啟動容器服務的時候動態獲取數據庫配置了
到此這篇關于Docker如何給Springboot項目動態傳參的實現方法的文章就介紹到這了,更多相關Docker Springboot動態傳參內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!