最近需要打包項目給成員們進行測試,但打包運行后很影響開發(fā),于是打算使用docker
模擬生產(chǎn)環(huán)境運行打包后的項目,這樣就能既開發(fā),又能給成員進行測試了。
由于原項目過大,打算先拿軟件工程的大實驗試試水,軟件工程大實驗使用的是spring-boot,redis,mysql,angular,nginx
這些環(huán)境,先試了試后臺的spring-boot,redis,mysql
的docker
搭建。
docker-compose
compose
項目是Docker官方的開源項目,負責實現(xiàn)對Docker容器集群的快速編排。compose
定位是定義和運行多個docker容器的應用。
我們都知道,使用一個Dockerfile
模版文件就可以創(chuàng)建一個應用容器,但通常在一個項目中,需要多個應用容器,就像我的后臺,同時需要jdk8
、redis
、mysql
這些應用。docker-compose
剛好滿足了這樣的需求。它允許用戶通過一個單獨的docker-compose.yml
模版文件來定義一組相關(guān)聯(lián)的應用容器為一個項目。
服務(service):一個應用的容器,實際可以包括若干運行相同鏡像的容器實例。
compose
中兩個重要的概念:
項目(project):由一組關(guān)聯(lián)的應用容器組成的一個完整的業(yè)務單元,在docker-compose.yml
文件中定義。
服務就是我們需要的docker
容器,項目就是由許多服務構(gòu)成的,了解了docker-compose
之后就可以進行環(huán)境搭建了。
搭建spring-boot
為了編譯spring-boot
,基于以下流程:
構(gòu)建的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的容器構(gòu)建后,就可以使用docker-compose
集成spring-boot、redis、mysql
容器了。具體思路:
docker-compose.yml
文件:
version: '3.7' # 定義服務 services: # spring-boot服務 app-server: build: context: . # 配置需要構(gòu)建Dockerfile的路徑 相對于docker-compose.yml dockerfile: Dockerfile ports: - "8080:8080" # 將本機8080端口映射到容器8080端口 restart: always depends_on: - db # 需要依賴的服務 率先構(gòu)建 - 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: # 網(wǎng)絡 連接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)建項目容器:
使用docker-compose up
啟動容器:
當成功看到spring-boot啟動成功的日志,就成功配置好了。
后續(xù)
這次只構(gòu)建了后臺,希望能把前臺的angular、nginx
也構(gòu)建完畢,爭取一條docker
命令,就直接啟動應用程序。
參考鏈接:Spring Boot, Mysql, React docker compose example
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
標簽:大慶 長治 雅安 臺灣 安陽 興安盟 中衛(wèi) 清遠
巨人網(wǎng)絡通訊聲明:本文標題《docker-compose 配置spring環(huán)境的方法步驟》,本文關(guān)鍵詞 docker-compose,配置,spring,環(huán)境,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權(quán)與本站無關(guān)。