您的位置:首頁技術文章
文章詳情頁

Docker如何給Springboot項目動態傳參的實現方法

瀏覽:5日期:2023-11-27 10:09:42

背景

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

場景

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

Docker如何給Springboot項目動態傳參的實現方法

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表達式,動態從環境變量獲取數據庫配置

Docker如何給Springboot項目動態傳參的實現方法

接下來我們在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動態傳參內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Spring
相關文章:
国产综合久久一区二区三区