Docker如何給Springboot項目動態(tài)傳參的實現方法
背景
最近有些初學Docker的朋友問到,想通過docker-compose.yml來動態(tài)給微服務傳參,而不是每次都要在項目配置文件硬編碼,然后構建服務鏡像,最后打包發(fā)布經過一些列流程才能更新配置,那能不能直接通過docker-compose.yml里把一些配置項放到環(huán)境變量,然后springboot項目自動從環(huán)境變量獲取參數呢?
場景
假設現在有一個Springboot項目,它里面有一個數據庫的配置項,但是不同的數據庫測試環(huán)境(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表達式,動態(tài)從環(huán)境變量獲取數據庫配置

接下來我們在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應用就可以在啟動容器服務的時候動態(tài)獲取數據庫配置了
到此這篇關于Docker如何給Springboot項目動態(tài)傳參的實現方法的文章就介紹到這了,更多相關Docker Springboot動態(tài)傳參內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
cordon節(jié)點drain驅逐節(jié)點delete節(jié)點詳解
這篇文章主要為大家介紹了cordon節(jié)點drain驅逐節(jié)點delete節(jié)點詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-11-11
CentOS7使用docker部署Apollo配置中心的實現
這篇文章主要介紹了CentOS7使用docker部署Apollo配置中心的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-10-10

