您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關使用Docker如何實現(xiàn)動態(tài)傳參到Springboot項目中,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
背景
最近有些初學Docker的朋友問到,想通過docker-compose.yml
來動態(tài)給微服務傳參,而不是每次都要在項目配置文件硬編碼,然后構建服務鏡像,最后打包發(fā)布經(jīng)過一些列流程才能更新配置,那能不能直接通過docker-compose.yml
里把一些配置項放到環(huán)境變量,然后springboot項目自動從環(huán)境變量獲取參數(shù)呢?
場景
假設現(xiàn)在有一個Springboot項目,它里面有一個數(shù)據(jù)庫的配置項,但是不同的數(shù)據(jù)庫測試環(huán)境(DEV\SIT\UAT),數(shù)據(jù)庫ip有多個,想使用同一個Springboot項目鏡像,可以隨時切換數(shù)據(jù)庫配置,簡單來說就是你的Springboot應用的數(shù)據(jù)庫配置應該是通過外部傳入,而不是hardcode.
Springboot應用里有個數(shù)據(jù)庫配置如下:
spring.datasource.url = jdbc:mysql://192.168.0.11:3306/db?useUnicode=true&characterEncoding=utf8 #配置數(shù)據(jù)庫用戶名 spring.datasource.username = sa #配置數(shù)據(jù)庫密碼 spring.datasource.password = sa
解決方案
利用SpEL
表達式,動態(tài)從環(huán)境變量獲取數(shù)據(jù)庫配置
接下來我們在Springboot配置文件把數(shù)據(jù)庫配置用spEL表達式替換
#配置數(shù)據(jù)庫鏈接 spring.datasource.url = jdbc:mysql://${DB_HOST}:${DB_PORT}/${DB_NAME}?useUnicode=true&characterEncoding=utf8 #配置數(shù)據(jù)庫用戶名 spring.datasource.username = ${DB_USER} #配置數(shù)據(jù)庫密碼 spring.datasource.password = ${DB_PASSWORD}
在docker-compose.yml
配置我們的數(shù)據(jù)庫參數(shù)
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)獲取數(shù)據(jù)庫配置了
以上就是使用Docker如何實現(xiàn)動態(tài)傳參到Springboot項目中,小編相信有部分知識點可能是我們?nèi)粘9ぷ鲿姷交蛴玫降摹OM隳芡ㄟ^這篇文章學到更多知識。更多詳情敬請關注億速云行業(yè)資訊頻道。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。