docker-compose 配置spring環(huán)境的方法步驟
最近需要打包項(xiàng)目給成員們進(jìn)行測試,但打包運(yùn)行后很影響開發(fā),于是打算使用docker模擬生產(chǎn)環(huán)境運(yùn)行打包后的項(xiàng)目,這樣就能既開發(fā),又能給成員進(jìn)行測試了。
由于原項(xiàng)目過大,打算先拿軟件工程的大實(shí)驗(yàn)試試水,軟件工程大實(shí)驗(yàn)使用的是spring-boot,redis,mysql,angular,nginx這些環(huán)境,先試了試后臺的spring-boot,redis,mysql的docker搭建。
docker-compose
compose項(xiàng)目是Docker官方的開源項(xiàng)目,負(fù)責(zé)實(shí)現(xiàn)對Docker容器集群的快速編排。compose定位是定義和運(yùn)行多個docker容器的應(yīng)用。
我們都知道,使用一個Dockerfile模版文件就可以創(chuàng)建一個應(yīng)用容器,但通常在一個項(xiàng)目中,需要多個應(yīng)用容器,就像我的后臺,同時需要jdk8、redis、mysql這些應(yīng)用。docker-compose剛好滿足了這樣的需求。它允許用戶通過一個單獨(dú)的docker-compose.yml模版文件來定義一組相關(guān)聯(lián)的應(yīng)用容器為一個項(xiàng)目。
服務(wù)(service):一個應(yīng)用的容器,實(shí)際可以包括若干運(yùn)行相同鏡像的容器實(shí)例。
compose中兩個重要的概念:
項(xiàng)目(project):由一組關(guān)聯(lián)的應(yīng)用容器組成的一個完整的業(yè)務(wù)單元,在docker-compose.yml文件中定義。
服務(wù)就是我們需要的docker容器,項(xiàng)目就是由許多服務(wù)構(gòu)成的,了解了docker-compose之后就可以進(jìn)行環(huán)境搭建了。
搭建spring-boot
為了編譯spring-boot,基于以下流程:
- 基于jdk8鏡像
- 將spring-boot下的mvnw、pom.xml復(fù)制到容器中,導(dǎo)入maven依賴
- 將src目錄下的源碼復(fù)制到容器中,使用maven打包spring-boot項(xiàng)目
- 使用jre8環(huán)境運(yùn)行項(xiàng)目
構(gòu)建的Dockerfile文件:
#### 建立spring-boot項(xiàng)目
FROM openjdk:8-jdk-alpine as build
# 設(shè)置項(xiàng)目在docker容器中工作目錄
WORKDIR /app
# 將 maven 可執(zhí)行程序復(fù)制到容器中
COPY mvnw .
COPY .mvn .mvn
# 復(fù)制pom.xml文件
COPY pom.xml .
# 導(dǎo)入所有maven依賴
RUN ./mvnw dependency:go-offline -B
# 復(fù)制項(xiàng)目源代碼
COPY src src
# 打包應(yīng)用程序
RUN ./mvnw package -DskipTests
RUN mkdir -p target/dependency && (cd target/dependency; jar -xf ../*.jar)
#### 設(shè)置能運(yùn)行應(yīng)用程序的最小docker容器
FROM openjdk:8-jre-alpine
ARG DEPENDENCY=/app/target/dependency
# Copy project dependencies from the build stage
COPY --from=build ${DEPENDENCY}/BOOT-INF/lib /app/lib
COPY --from=build ${DEPENDENCY}/META-INF /app/META-INF
COPY --from=build ${DEPENDENCY}/BOOT-INF/classes /app
ENTRYPOINT ["java","-cp","app:app/lib/*","com.xiang.airTicket.AirTicketApplication"]
docker-compose 集成項(xiàng)目服務(wù)
完成了spring-boot的容器構(gòu)建后,就可以使用docker-compose集成spring-boot、redis、mysql容器了。具體思路:
- 聲明項(xiàng)目
- 聲明項(xiàng)目需要集成的服務(wù)
docker-compose.yml文件:
version: '3.7' # 定義服務(wù) services: # spring-boot服務(wù) app-server: build: context: . # 配置需要構(gòu)建Dockerfile的路徑 相對于docker-compose.yml dockerfile: Dockerfile ports: - "8080:8080" # 將本機(jī)8080端口映射到容器8080端口 restart: always depends_on: - db # 需要依賴的服務(wù) 率先構(gòu)建 - redis environment: # 設(shè)置環(huán)境變量 SPRING_DATASOURCE_URL: jdbc:mysql://db:3306/airTicket?useSSL=false&serverTimezone=UTC&useLegacyDatetimeCode=false SPRING_DATASOURCE_USERNAME: root SPRING_DATASOURCE_PASSWORD: 123456 SPRING_REDIS.HOST: redis networks: # 網(wǎng)絡(luò) 連接mysql和redis - backend db: image: mysql:5.6 ports: - "3306:3306" restart: always environment: MYSQL_DATABASE: airTicket MYSQL_USER: htx MYSQL_PASSWORD: 123456 MYSQL_ROOT_PASSWORD: 123456 volumes: - db-data:/var/lib/mysql networks: - backend redis: image: redis command: [ "redis-server", "--protected-mode", "no" ] hostname: redis ports: - "6379:6379" networks: - backend volumes: db-data: networks: backend:
使用docker-compose build構(gòu)建項(xiàng)目容器:

使用docker-compose up啟動容器:

當(dāng)成功看到spring-boot啟動成功的日志,就成功配置好了。
后續(xù)
這次只構(gòu)建了后臺,希望能把前臺的angular、nginx也構(gòu)建完畢,爭取一條docker命令,就直接啟動應(yīng)用程序。
參考鏈接:Spring Boot, Mysql, React docker compose example
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
zabbix監(jiān)控docker容器狀態(tài)【推薦】
這篇文章主要介紹了zabbix監(jiān)控docker容器狀態(tài)的相關(guān)資料,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-06-06
Docker中運(yùn)行PostgreSQL并推薦幾款連接工具
PostgreSQL支持大部分的SQL標(biāo)準(zhǔn)并且提供了很多其他現(xiàn)代特性,如復(fù)雜查詢、外鍵、觸發(fā)器、視圖、事務(wù)完整性、多版本并發(fā)控制等,今天給大家介紹Docker中運(yùn)行PostgreSQL并推薦幾款連接工具,需要的朋友參考下吧2021-06-06
Dockerfile如何使用alpine系統(tǒng)制作haproxy鏡像
這篇文章主要介紹了Dockerfile如何使用alpine系統(tǒng)制作haproxy鏡像問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-05-05
解決docker拉取鏡像報(bào)錯:error pulling image configurat
在使用Docker拉取Kafka鏡像時可能會遇到"error pulling image configuration"的錯誤,這可以通過編輯Docker配置文件并重啟Docker服務(wù)來解決,具體步驟包括:1. 編輯Docker配置文件;2. 使用命令systemctl restart docker重啟Docker服務(wù)2024-11-11
打包docker鏡像推送到遠(yuǎn)程服務(wù)器并部署到k8s的方法步驟
本文主要介紹了打包docker鏡像推送到遠(yuǎn)程服務(wù)器并部署到k8s的方法步驟,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-11-11

