IDEA中進(jìn)行Docker項(xiàng)目部署的實(shí)現(xiàn)-創(chuàng)新互聯(lián)

IDEA中進(jìn)行Docker項(xiàng)目部署的實(shí)現(xiàn)?相信很多沒有經(jīng)驗(yàn)的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個(gè)問題。

創(chuàng)新互聯(lián)公司-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比攀枝花網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式攀枝花網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋攀枝花地區(qū)。費(fèi)用合理售后完善,10余年實(shí)體公司更值得信賴。
Docker配置

修改配置文件

打開Docker的配置文件:
vim /usr/lib/systemd/system/docker.service
將下面這行注釋掉:
# ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock
新寫一行:
ExecStart=/usr/bin/dockerd -H tcp://0.0.0.0:2375 -H unix:///var/run/docker.sock
重新加載配置文件和啟動(dòng):
systemctl daemon-reload
systemctl start docker

如下圖所示:

IDEA中進(jìn)行Docker項(xiàng)目部署的實(shí)現(xiàn)

IDEA配置Docker

安裝Docker插件

IDEA中進(jìn)行Docker項(xiàng)目部署的實(shí)現(xiàn)

配置Docker信息

在設(shè)置中進(jìn)行Docker配置,需要配置API URL,下面出現(xiàn)Connection successful即可:

IDEA中進(jìn)行Docker項(xiàng)目部署的實(shí)現(xiàn)

項(xiàng)目搭建

新建一個(gè)springboot項(xiàng)目

通過IDEA搭建項(xiàng)目,什么都不需要選擇,一直下一步就可以了:

IDEA中進(jìn)行Docker項(xiàng)目部署的實(shí)現(xiàn)

修改pom文件

最主要的就是兩點(diǎn):

1.properties標(biāo)簽中添加

<docker.image.prefix>demo</docker.image.prefix>

2.添加新的plugin標(biāo)簽

<plugin>
 <groupId>com.spotify</groupId>
 <artifactId>docker-maven-plugin</artifactId>
 <version>1.2.1</version>
 <configuration>
   <imageName>${docker.image.prefix}/${project.artifactId}</imageName>
   <dockerDirectory></dockerDirectory>
   <resources>
     <resource>
       <targetPath>/</targetPath>
       <directory>${project.build.directory}</directory>
       <include>${project.build.finalName}.jar</include>
     </resource>
   </resources>
 </configuration>
</plugin>

下面是完整的pom文件:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
 <modelVersion>4.0.0</modelVersion>
 <parent>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-parent</artifactId>
   <version>2.2.1.RELEASE</version>
   <relativePath/> <!-- lookup parent from repository -->
 </parent>
 <groupId>com.example</groupId>
 <artifactId>demo</artifactId>
 <version>0.0.1</version>
 <name>demo</name>
 <description>Demo project for Spring Boot</description>

 <properties>
   <java.version>1.8</java.version>
   <docker.image.prefix>demo</docker.image.prefix>
 </properties>

 <dependencies>

   <dependency>
     <groupId>org.springframework.boot</groupId>
     <artifactId>spring-boot-starter</artifactId>
   </dependency>

   <dependency>
     <groupId>org.springframework.boot</groupId>
     <artifactId>spring-boot-starter-web</artifactId>
   </dependency>

   <dependency>
     <groupId>org.springframework.boot</groupId>
     <artifactId>spring-boot-starter-test</artifactId>
     <scope>test</scope>
     <exclusions>
       <exclusion>
         <groupId>org.junit.vintage</groupId>
         <artifactId>junit-vintage-engine</artifactId>
       </exclusion>
     </exclusions>
   </dependency>
 </dependencies>

 <build>
   <plugins>
     <plugin>
       <groupId>org.springframework.boot</groupId>
       <artifactId>spring-boot-maven-plugin</artifactId>
     </plugin>
     <plugin>
       <groupId>com.spotify</groupId>
       <artifactId>docker-maven-plugin</artifactId>
       <version>1.2.1</version>
       <configuration>
         <imageName>${docker.image.prefix}/${project.artifactId}</imageName>
         <dockerDirectory></dockerDirectory>
         <resources>
           <resource>
             <targetPath>/</targetPath>
             <directory>${project.build.directory}</directory>
             <include>${project.build.finalName}.jar</include>
           </resource>
         </resources>
       </configuration>
     </plugin>
   </plugins>
 </build>

</project>

新建Dockerfile文件

需要在根目錄下新建Dockerfile文件

#指定基礎(chǔ)鏡像,在其上進(jìn)行定制
FROM java:8

#維護(hù)者信息
MAINTAINER zhouzhaodong <xiuaiba@163.com>

#這里的 /tmp 目錄就會在運(yùn)行時(shí)自動(dòng)掛載為匿名卷,任何向 /tmp 中寫入的信息都不會記錄進(jìn)容器存儲層
VOLUME /tmp

#復(fù)制上下文目錄下的target/demo-1.0.0.jar 到容器里
COPY target/demo-0.0.1.jar demo-1.0.0.jar

#bash方式執(zhí)行,使demo-1.0.0.jar可訪問
#RUN新建立一層,在其上執(zhí)行這些命令,執(zhí)行結(jié)束后, commit 這一層的修改,構(gòu)成新的鏡像。
RUN bash -c "touch /demo-1.0.0.jar"

#聲明運(yùn)行時(shí)容器提供服務(wù)端口,這只是一個(gè)聲明,在運(yùn)行時(shí)并不會因?yàn)檫@個(gè)聲明應(yīng)用就會開啟這個(gè)端口的服務(wù)
EXPOSE 8080

#指定容器啟動(dòng)程序及參數(shù)  <ENTRYPOINT> "<CMD>"
ENTRYPOINT ["java","-jar","demo-1.0.0.jar"]

新建controller文件

別忘記在pom文件中添加web依賴。

@RestController
public class testController {

  @RequestMapping("/")
  public String test(){
    return "test Docker";
  }

}

maven打包

install打包:

IDEA中進(jìn)行Docker項(xiàng)目部署的實(shí)現(xiàn)

生成jar包:

IDEA中進(jìn)行Docker項(xiàng)目部署的實(shí)現(xiàn)

新建配置

新建Dockerfile運(yùn)行配置:

IDEA中進(jìn)行Docker項(xiàng)目部署的實(shí)現(xiàn)

添加如下信息,找到自己寫的Dockerfile文件,配置端口映射:

IDEA中進(jìn)行Docker項(xiàng)目部署的實(shí)現(xiàn)

生成Docker鏡像并運(yùn)行

直接運(yùn)行剛才新建的Dockerfile運(yùn)行配置即可:

IDEA中進(jìn)行Docker項(xiàng)目部署的實(shí)現(xiàn)

運(yùn)行成功后log窗口會出現(xiàn)項(xiàng)目運(yùn)行的信息:

IDEA中進(jìn)行Docker項(xiàng)目部署的實(shí)現(xiàn)

訪問對應(yīng)的地址即可顯示我們輸入的信息:

IDEA中進(jìn)行Docker項(xiàng)目部署的實(shí)現(xiàn)

看完上述內(nèi)容,你們掌握IDEA中進(jìn)行Docker項(xiàng)目部署的實(shí)現(xiàn)的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道,感謝各位的閱讀!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

分享文章:IDEA中進(jìn)行Docker項(xiàng)目部署的實(shí)現(xiàn)-創(chuàng)新互聯(lián)
URL網(wǎng)址:http://www.muchs.cn/article16/piddg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站維護(hù)、品牌網(wǎng)站建設(shè)網(wǎng)站營銷、企業(yè)建站響應(yīng)式網(wǎng)站、全網(wǎng)營銷推廣

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

小程序開發(fā)