docker-compose 配置spring環(huán)境的方法步驟
最近需要打包項目給成員們進行測試,但打包運行后很影響開發(fā),于是打算使用docker
模擬生產環(huán)境運行打包后的項目,這樣就能既開發(fā),又能給成員進行測試了。
由于原項目過大,打算先拿軟件工程的大實驗試試水,軟件工程大實驗使用的是spring-boot,redis,mysql,angular,nginx
這些環(huán)境,先試了試后臺的spring-boot,redis,mysql
的docker
搭建。
docker-compose
compose
項目是Docker官方的開源項目,負責實現對Docker容器集群的快速編排。compose
定位是定義和運行多個docker容器的應用。
我們都知道,使用一個Dockerfile
模版文件就可以創(chuàng)建一個應用容器,但通常在一個項目中,需要多個應用容器,就像我的后臺,同時需要jdk8
、redis
、mysql
這些應用。docker-compose
剛好滿足了這樣的需求。它允許用戶通過一個單獨的docker-compose.yml
模版文件來定義一組相關聯的應用容器為一個項目。
服務(service):一個應用的容器,實際可以包括若干運行相同鏡像的容器實例。
compose
中兩個重要的概念:
項目(project):由一組關聯的應用容器組成的一個完整的業(yè)務單元,在docker-compose.yml
文件中定義。
服務就是我們需要的docker
容器,項目就是由許多服務構成的,了解了docker-compose
之后就可以進行環(huán)境搭建了。
搭建spring-boot
為了編譯spring-boot
,基于以下流程:
- 基于jdk8鏡像
- 將spring-boot下的mvnw、pom.xml復制到容器中,導入maven依賴
- 將src目錄下的源碼復制到容器中,使用maven打包spring-boot項目
- 使用jre8環(huán)境運行項目
構建的Dockerfile
文件:
#### 建立spring-boot項目 FROM openjdk:8-jdk-alpine as build # 設置項目在docker容器中工作目錄 WORKDIR /app # 將 maven 可執(zhí)行程序復制到容器中 COPY mvnw . COPY .mvn .mvn # 復制pom.xml文件 COPY pom.xml . # 導入所有maven依賴 RUN ./mvnw dependency:go-offline -B # 復制項目源代碼 COPY src src # 打包應用程序 RUN ./mvnw package -DskipTests RUN mkdir -p target/dependency && (cd target/dependency; jar -xf ../*.jar) #### 設置能運行應用程序的最小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 集成項目服務
完成了spring-boot的容器構建后,就可以使用docker-compose
集成spring-boot、redis、mysql
容器了。具體思路:
- 聲明項目
- 聲明項目需要集成的服務
docker-compose.yml
文件:
version: '3.7' # 定義服務 services: # spring-boot服務 app-server: build: context: . # 配置需要構建Dockerfile的路徑 相對于docker-compose.yml dockerfile: Dockerfile ports: - "8080:8080" # 將本機8080端口映射到容器8080端口 restart: always depends_on: - db # 需要依賴的服務 率先構建 - redis environment: # 設置環(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: # 網絡 連接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
構建項目容器:
使用docker-compose up
啟動容器:
當成功看到spring-boot啟動成功的日志,就成功配置好了。
后續(xù)
這次只構建了后臺,希望能把前臺的angular、nginx
也構建完畢,爭取一條docker
命令,就直接啟動應用程序。
參考鏈接:Spring Boot, Mysql, React docker compose example
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
使用DockerFile構建docker鏡像掛載目錄,數據卷同步問題
這篇文章主要介紹了使用DockerFile構建docker鏡像掛載目錄,數據卷同步問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-07-07用Docker swarm快速部署Nebula Graph集群的教程
這篇文章主要介紹了用Docker swarm快速部署Nebula Graph集群的方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-09-09Docker系列學習之Swarm mode管理節(jié)點常用命令詳解
這篇文章主要為大家介紹了Docker系列學習之Swarm mode管理節(jié)點常用命令詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-10-10使用Docker部署MySQL 5.7&8.0主從集群的方法步驟
這篇文章主要介紹了使用Docker部署MySQL 5.7&8.0主從集群的方法步驟,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-03-03docker無法刪除鏡像報Error:?No?such?container的錯誤問題
docker無法刪除鏡像的解決方法很簡單,只需要簡單三步即可完美解決docker刪除鏡像過程中,一直報Error:?No?such?container的錯誤問題,感興趣的朋友跟隨小編一起看看吧2023-01-01