主頁 > 知識庫 > 利用Dockerfile部署SpringBoot項(xiàng)目的方法

利用Dockerfile部署SpringBoot項(xiàng)目的方法

熱門標(biāo)簽:湖北ai智能電銷機(jī)器人 高德地圖標(biāo)注論壇 北海市地圖標(biāo)注app 新科美甲店地圖標(biāo)注 外呼系統(tǒng)打哪顯哪 蘭州ai電銷機(jī)器人招商 江西外呼系統(tǒng) AI電銷機(jī)器人 源碼 新邵電銷機(jī)器人企業(yè)

1、創(chuàng)建一個SpringBooot項(xiàng)目并且打成jar包

2、在Linux中創(chuàng)建一個文件夾,來做docker測試

[root@izwz90lvzs7171wgdhul8az ~]# mkdir /root/docker_test

3、將jar包上傳到Linux中

創(chuàng)建存放jar包的文件夾

[root@izwz90lvzs7171wgdhul8az docker_test]# mkdir /root/docker_test/jar

然后利用XShell上傳jar包到上面的文件夾中

4、編寫Dockerfile文件

# 基于java鏡像創(chuàng)建新鏡像
FROM java:8
# 作者
MAINTAINER Howinfun
# 將jar包添加到容器中并更名為app.jar
ADD jar/app.jar /root/docker_test/app.jar
# 運(yùn)行jar包
ENTRYPOINT ["nohup","java","-jar","/root/docker_test/app.jar","&"]

注意:ADD 、 COPY 指令用法一樣,唯一不同的是 ADD 支持將歸檔文件(tar, gzip, bzip2, etc)做提取和解壓操作。還有需要注意的是,COPY 指令需要復(fù)制的目錄一定要放在 Dockerfile 文件的同級目錄下。

5、制作鏡像

[root@izwz90lvzs7171wgdhul8az docker_test]# docker build -t sbdemo .

命令參數(shù):

-t:指定新鏡像名
.:表示Dockfile在當(dāng)前路徑

如果我們的 Dockerfile 文件路徑不在這個目錄下,或者有另外的文件名,我們可以通過 -f 選項(xiàng)單獨(dú)給出 Dockerfile 文件的路徑

[root@izwz90lvzs7171wgdhul8az docker_test]# docker build -t sbdemo -f /root/docker_test/Dockerfile /root/docker_test/

命令參數(shù):

-f:第一個參數(shù)是Dockerfile的路徑 第二個參數(shù)是Dockerfile所在文件夾制作完成后通過docker images命令查看我們制作的鏡像:

[root@izwz90lvzs7171wgdhul8az docker_test]# docker images | grep sbdemo
sbdemo       latest       7efac46ef997    4 hours ago     686MB

6、啟動容器

[root@izwz90lvzs7171wgdhul8az docker_test]# docker run -d -p 8888:8888 --name mysbdemo sbdemo:latest

命令參數(shù):

-d:后臺運(yùn)行
-p:公開指定端口號
--name:給容器命名

啟動后可通過docker ps查看正在運(yùn)行的容器:

[root@izwz90lvzs7171wgdhul8az docker_test]# docker ps
CONTAINER ID    IMAGE        COMMAND         CREATED       STATUS       PORTS          NAMES
5096c8c7b36f    sbdemo       "nohup java -jar /ro??  4 seconds ago    Up 2 seconds    0.0.0.0:8888->8888/tcp  mysbdemo

7、查看容器啟動日志

我們可以通過 docker logs 查看指定容器的日志:

[root@izwz90lvzs7171wgdhul8az docker_test]# docker logs mysbdemo

 .  ____     _      __ _ _
 /\\ / ___'_ __ _ _(_)_ __ __ _ \ \ \ \

( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \

 \\/ ___)| |_)| | | | | || (_| | ) ) ) )
 ' |____| .__|_| |_|_| |_\__, | / / / /
 =========|_|==============|___/=/_/_/_/
 :: Spring Boot ::    (v2.1.6.RELEASE)

2019-10-11 02:10:46.264 INFO 1 --- [      main] com.hyf.DatabaseApplication       : Starting DatabaseApplication v0.0.1-SNAPSHOT on 6d85ac5d8751 with PID 1 (/root/docker_test/app.jar started by root in /)
2019-10-11 02:10:46.267 DEBUG 1 --- [      main] com.hyf.DatabaseApplication       : Running with Spring Boot v2.1.6.RELEASE, Spring v5.1.8.RELEASE
2019-10-11 02:10:46.268 INFO 1 --- [      main] com.hyf.DatabaseApplication       : No active profile set, falling back to default profiles: default
2019-10-11 02:10:49.139 WARN 1 --- [      main] o.m.s.mapper.ClassPathMapperScanner   : Skipping MapperFactoryBean with name 'bookMapper' and 'com.hyf.mapper.BookMapper' mapperInterface. Bean already defined with the same name!
2019-10-11 02:10:49.139 WARN 1 --- [      main] o.m.s.mapper.ClassPathMapperScanner   : No MyBatis mapper was found in '[com.hyf]' package. Please check your configuration.
2019-10-11 02:10:49.246 INFO 1 --- [      main] .s.d.r.c.RepositoryConfigurationDelegate : Multiple Spring Data modules found, entering strict repository configuration mode!
2019-10-11 02:10:49.257 INFO 1 --- [      main] .s.d.r.c.RepositoryConfigurationDelegate : Bootstrapping Spring Data repositories in DEFAULT mode.
2019-10-11 02:10:49.328 INFO 1 --- [      main] .s.d.r.c.RepositoryConfigurationDelegate : Finished Spring Data repository scanning in 39ms. Found 0 repository interfaces.
2019-10-11 02:10:50.345 INFO 1 --- [      main] trationDelegate$BeanPostProcessorChecker : Bean 'org.springframework.transaction.annotation.ProxyTransactionManagementConfiguration' of type [org.springframework.transaction.annotation.ProxyTransactionManagementConfiguration$$EnhancerBySpringCGLIB$$2c6b335] is not eligible for getting processed by all BeanPostProcessors (for example: not eligible for auto-proxying)
2019-10-11 02:10:51.255 INFO 1 --- [      main] o.s.b.w.embedded.tomcat.TomcatWebServer : Tomcat initialized with port(s): 8888 (http)
2019-10-11 02:10:51.359 INFO 1 --- [      main] o.apache.catalina.core.StandardService  : Starting service [Tomcat]
2019-10-11 02:10:51.359 INFO 1 --- [      main] org.apache.catalina.core.StandardEngine : Starting Servlet engine: [Apache Tomcat/9.0.21]
2019-10-11 02:10:51.778 INFO 1 --- [      main] o.a.c.c.C.[Tomcat].[localhost].[/]    : Initializing Spring embedded WebApplicationContext
2019-10-11 02:10:51.779 INFO 1 --- [      main] o.s.web.context.ContextLoader      : Root WebApplicationContext: initialization completed in 5104 ms
2019-10-11 02:10:54.164 INFO 1 --- [      main] o.s.s.concurrent.ThreadPoolTaskExecutor : Initializing ExecutorService 'applicationTaskExecutor'
2019-10-11 02:10:56.081 INFO 1 --- [      main] o.s.b.w.embedded.tomcat.TomcatWebServer : Tomcat started on port(s): 8888 (http) with context path ''
2019-10-11 02:10:56.090 INFO 1 --- [      main] com.hyf.DatabaseApplication       : Started DatabaseApplication in 11.49 seconds (JVM running for 12.624)

8、訪問接口

容器啟動后,我們嘗試使用postman或者其他http工具去訪問部署在容器中的應(yīng)用接口。

總結(jié)

以上所述是小編給大家介紹的利用Dockerfile部署SpringBoot項(xiàng)目的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

標(biāo)簽:海南 黃石 阿克蘇 南陽 池州 大理 黔東 自貢

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《利用Dockerfile部署SpringBoot項(xiàng)目的方法》,本文關(guān)鍵詞  利用,Dockerfile,部署,SpringBoot,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《利用Dockerfile部署SpringBoot項(xiàng)目的方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于利用Dockerfile部署SpringBoot項(xiàng)目的方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章