您好,登錄后才能下訂單哦!
本篇內容主要講解“docker-compose啟動springboot項目連接mysql問題怎么解決”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“docker-compose啟動springboot項目連接mysql問題怎么解決”吧!
開發工具:idea
注意:mysql配置使用的是docker中的鏡像名,不是ip地址
如下:
這里使用idea自帶maven打包(jar)
(我這里為ssm_dockerfile),與上一步打包好的jar包放同一目錄。
ADD的jar包是上一步打包好的jar包名,后面可以起別名
如下:
FROM frolvlad/alpine-oraclejdk8:slim VOLUME /tmp ADD ssmdemo-0.0.1-SNAPSHOT.jar ssm.jar RUN sh -c 'touch /ssm.jar' ENV JAVA_OPTS="" ENTRYPOINT [ "sh", "-c", "java $JAVA_OPTS -Djava.security.egd=file:/dev/./urandom -jar /ssm.jar" ]
與jar包和dockerfile放同一目錄。
如下:
version : '2' services: learn2: build: context: . dockerfile: ssm_dockerfile ports: - "8080:8080" volumes: - .:/vol/development depends_on: - c_mysql c_mysql: image: docker.io/mysql:5 ports: - "3306:3306" environment: MYSQL_DATABASE: blogdb MYSQL_ROOT_PASSWORD: root MYSQL_ROOT_HOST: '%' restart: always
解釋:
springboot工程的配置,context,dockerfile對應dockerfile的位置,ports端口映射,volumes表示將物理機的當前目錄映射到docker虛擬機/vol/development里面,depends_on依賴mysql 控制容器啟動順序讓mysql先啟。
mysql的配置,直接從docker hub下載,image 對應的就是docker hub的鏡像, ports 對應端口映射,與docker -p差不多一個意思,environment 配置mysql創建的庫,root的密碼,還有允許訪問的IP配為%,restart 每次都重新啟動。
在docker-compose.yml所在目錄下運行 docker-compose up命令,如果后臺運行加一個-d,會發現mysql先從docker hub下載并啟動,然后啟動springboot工程。
訪問結果如下:
到此,相信大家對“docker-compose啟動springboot項目連接mysql問題怎么解決”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。