検索
ホームページJava&#&チュートリアルSpringBoot はどのようにして簡単なパッケージ化とデプロイメントを実行するのでしょうか?

この記事では、SpringBoot の簡単なパッケージ化とデプロイメントを実行する方法を説明します。 困っている友人は参考にしていただければ幸いです。

まえがき

この記事では主に、SpringBoot のパッケージ化とプロジェクトのデプロイメント、およびその際に発生するいくつかの問題の解決策を紹介します。

SpringBoot パッケージ化

SpringBoot パッケージ化では、パッケージ化に以前の Web プロジェクトを使用します。
最初に明確にする必要があるのは、プロジェクトが実行可能 jar パッケージにパッケージ化されているか、それとも tomcat で実行される war パッケージにパッケージ化されているかということです。
このプロジェクトはmavenを使用して構築されていますが、mavenでパッケージ化する方が便利ですが、ここではmavenでパッケージ化されていない通常のプロジェクトのパッケージ化方法も説明します。

Maven のパッケージ化

まず、maven メソッドを使用してパッケージ化します:
jar パッケージ の場合は、pom.xml でパッケージを指定する必要があります:

<packaging>jar</packaging>
pom.xml指定打成的包为:

<packaging>war</packaging>

如果是war包。
需在pom.xml指定打成的包为:

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

并通过<scope></scope>标签在打包的时候排除tomcat依赖

<build>
        <defaultGoal>compile</defaultGoal>
        <sourceDirectory>src</sourceDirectory>
        <finalName>springboot-package</finalName>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin </artifactId>
                <configuration>
                    <fork>true</fork>
                    <mainClass>com.pancm.App</mainClass>
                </configuration>
                <executions>
                    <execution>
                        <goals>
                            <goal>repackage</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>

然后添加SpringBoot自带的打包方式
示例如下:

<build>
    <plugins>
          <plugin>
            <groupId>org.apache.maven.plugins</groupId>  
            <artifactId>maven-assembly-plugin</artifactId>  
            <version>2.5.5</version>  
            <configuration>
                <archive>  
                    <manifest>  
                        <mainClass>com.pancm.App</mainClass>  
                    </manifest>  
                </archive>  
                <descriptorRefs>  
                    <descriptorRef>jar-with-dependencies</descriptorRef>  
                </descriptorRefs>  
            </configuration>  
        </plugin> 
       </plugins>
    </build>

注:<finalname></finalname>标签是指定打包之后的名称,<mainclass></mainclass>是指定main函数。

也可以不用SpringBoot自带的打包方式,使用mavenassembly插件进行打包。
示例如下:

mvn clean package

pom.xml中添加完相应的标签之后,我们只需在项目同级(pom.xml同级)输入

mvn clean package  -Dmaven.test.skip=true

即可完成打包
如果想排除测试代码,则可以输入:

logging.config=logback.xml

来进行打包。

一般我们是把application.propertieslogback.xml文件放在resources文件夹中,但是进行打包之后,它们也会包含在jarwar包中,如果我们想更改配置,则会比较麻烦。
如果想将它们和项目放在同级目录下,application.properties可以直接移出和项目同级的目录下,因为Spring程序会按优先级从下面这些路径来加载application.properties配置文件:

  • 当前目录下的/config目录

  • 当前目录

  • classpath里的/config目录

  • classpath 根目录

springboot默认加载的logback是在classpath目录下,这时我们只需要在application.properties配置文件指定logback.xml的路径即可。
添加如下:

mvn install:install-file -Dfile=lib/pancmtools.jar -DgroupId=com.panncm.utils -DartifactId=pancm-utils -Dversion=1.0 -Dpackaging=jar

如果引入了第三方的jar包,但是又无法通过maven私服进行下载,这时可以手动进行编译。
例如,我写了一个工具类为Mytools,然后把它打成了一个jar包,然后放在我的这个项目中lib目录下,并且需要引用它,那么此时便可以对该jar包进行编译到本地仓库中,然后再pom.xml添加相应的名称和版本号。
命令示例:

<dependency>
            <groupId>com.panncm.utils</groupId>
            <artifactId>pancm-utils</artifactId>
            <version>1.0</version>
</dependency>

pom.xml添加

<?xml version="1.0" encoding="UTF-8"?>
<project name="springboot-package" default="copyAll" basedir=".">
    <property name="build" value="build" />
    <property name="target" value="target" />
    <target name="clean">
        <delete dir="${target}" />
        <delete dir="${build}" />
    </target>

    <target name="create-path" depends="clean">
        <mkdir dir="${build}" />
    </target>

    <target name="mvn_package" depends="create-path">
        <exec executable="cmd" failonerror="true">
            <arg line="/c mvn install:install-file -Dfile=lib/pancmtools.jar -DgroupId=com.panncm.utils -DartifactId=pancm-utils -Dversion=1.0 -Dpackaging=jar" />
        </exec>
        <exec executable="cmd" failonerror="true">
            <arg line="/c mvn clean package" />
        </exec>
    </target>

    <target name="copyAll" depends="mvn_package">
        <copy todir="${build}" file="${target}/springboot-package.jar"></copy> 
        <copy todir="${build}" file="logback.xml"></copy>
        <copy todir="${build}" file="application.properties"></copy>
        <copy todir="${build}" file="run.bat"></copy>
    </target>
</project>

便可以进行打包了。

普通项目打包

如果是普通的项目,没有使用maven构建的话,可以使用eclipse等工具进行打包。
如果是jar
首先在eclipse中运行该项目(main方法运行),然后在eclipse中右键项目 export ->java -> runnable jar file-> package required libraries into generated jar 指定main方法,然后选择打包的名称以及打包的路径。点击finish完成打包。

如果是war
eclipse中右键项目 export ->web -> war fileそれが war パッケージの場合。

pom.xml でパッケージを

  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
    <java.version>1.8</java.version>
    <fastjson>1.2.41</fastjson>
    <maven.compiler.source>1.8</maven.compiler.source>
    <maven.compiler.target>1.8</maven.compiler.target>
  </properties>

として指定し、<scope></scope> タグを使用して

tomcat 依存関係

<build>  
        <plugins>  
            <plugin>  
                <groupId>org.apache.maven.plugins</groupId>  
                <artifactId>maven-compiler-plugin</artifactId>  
                <version>3.3</version>  
                <configuration>  
                    <source>1.8</source>  
                    <target>1.8</target>  
                </configuration>  
            </plugin>  
        </plugins>  
    </build>
を除外する必要があります。 SpringBoot に付属するパッケージ化メソッド
例は次のとおりです:
  <repositories>  
     <repository>  
            <id>spring-milestone</id>  
            <url>http://repo.spring.io/libs-release</url>  
     </repository>  
   </repositories>

注: <finalname></finalname> タグは、パッケージ化を指定した後の名前です。 mainClass> は main 関数を指定します。 🎜🎜🎜🎜SpringBoot🎜 独自のパッケージ化メソッドの代わりに、🎜maven🎜 の 🎜assembly🎜 プラグインをパッケージ化に使用することもできます。 🎜🎜例は次のとおりです:🎜🎜
java -jar springboot-package
🎜🎜pom.xml🎜に対応するタグを追加した後、プロジェクトピア(pom.コード)に🎜
@echo off
title "springboot-package"
java -jar springboot-package.jar
🎜を入力するだけで済みます。パッケージ化するには、🎜
nohup -jar springboot-package &amp;
🎜と入力できます。 。 🎜🎜通常、🎜application.properties🎜ファイルと🎜logback.xml🎜ファイルはリソースフォルダーに配置されますが、パッケージ化後、構成を変更したい場合は、🎜jar🎜または🎜war🎜パッケージにも含まれます。 、さらに面倒になります。 🎜それらをプロジェクトと同じディレクトリに置きたい場合は、Spring プログラムが 🎜application.properties🎜設定ファイルをロードするため、🎜application.properties🎜をプロジェクトと同じレベルのディレクトリから直接移動できます。優先度に応じて次のパスから:🎜
  • 🎜カレントディレクトリの /config ディレクトリ🎜
  • 🎜カレントディレクトリ🎜
  • 🎜/config in the classpath Directory🎜
  • 🎜classpath root directory🎜
🎜🎜springboot🎜 デフォルトでロードされる 🎜logback🎜 は、🎜classpath🎜 ディレクトリにあります。今回は 🎜application.properties を追加するだけです🎜設定ファイルは 🎜logback.xml🎜 へのパスを指定するだけです。 🎜以下を追加します:🎜
kill -9 pid(jar的进程id)
🎜 サードパーティの 🎜jar🎜 パッケージが導入されているが、🎜maven🎜 プライベート サーバー経由でダウンロードできない場合は、手動でコンパイルできます。 🎜たとえば、🎜Mytools🎜というツールクラスを作成し、それを🎜jar🎜パッケージにして、プロジェクトの🎜lib🎜ディレクトリに配置しました。それを参照する必要があるため、コンパイルできます。 🎜jar🎜 パッケージをローカル ウェアハウスに保存し、対応する名前とバージョン番号を 🎜pom.xml🎜 に追加します。 🎜コマンド例: 🎜
ln -s /home/jars/app/springboot-package.jar /etc/init.d/springboot-package
chmod +x /etc/init.d/springboot-package
🎜🎜pom.xml🎜🎜
service springboot-package start|stop|restart
🎜を追加するとパッケージ化できます。 🎜🎜通常のプロジェクトのパッケージ化🎜🎜 通常のプロジェクトで、🎜maven🎜を使用してビルドされていない場合は、🎜eclipse🎜やその他のツールを使用してパッケージ化できます。 🎜jar🎜 パッケージ🎜 の場合は、まず 🎜eclipse🎜 でプロジェクトを実行し (🎜main🎜 メソッドの実行)、次に 🎜eclipse🎜export ->java -> でプロジェクトを右クリックします。 file-> 生成された jar に必要なライブラリをパッケージ化します。 🎜main🎜 メソッドを指定し、パッケージ名とパッケージのパスを選択します。 🎜finish🎜 をクリックしてパッケージ化を完了します。 🎜war🎜 パッケージの場合は、🎜eclipse🎜 でプロジェクト export ->web ->war ファイル を右クリックし、パッケージ名とパッケージ パスを選択します。 🎜finish🎜 をクリックしてパッケージ化を完了します。 🎜🎜Antパッケージング🎜🎜 上記2種類のパッケージングを紹介した後、🎜ant🎜メソッドによるパッケージングを紹介します(🎜ant🎜環境をインストールする必要があります。インストール方法は基本的にmavenと同じです。パスを設定し、環境変数を設定します。これについてはここでは詳しく説明しません)。 🎜通常、パッケージ化した後、パッケージと設定ファイルをディレクトリに配置する必要があります。手動でコピーして貼り付けたくない場合は、🎜ant🎜 を使用してパッケージ化し、パッケージ化されたファイルを統合できます。 🎜ここで🎜build.xml🎜設定ファイルを記述します。 🎜
<?xml version="1.0" encoding="UTF-8"?>
<project name="springboot-package" default="copyAll" basedir=".">
    <property name="build" value="build" />
    <property name="target" value="target" />
    <target name="clean">
        <delete dir="${target}" />
        <delete dir="${build}" />
    </target>

    <target name="create-path" depends="clean">
        <mkdir dir="${build}" />
    </target>

    <target name="mvn_package" depends="create-path">
        <exec executable="cmd" failonerror="true">
            <arg line="/c mvn install:install-file -Dfile=lib/pancmtools.jar -DgroupId=com.panncm.utils -DartifactId=pancm-utils -Dversion=1.0 -Dpackaging=jar" />
        </exec>
        <exec executable="cmd" failonerror="true">
            <arg line="/c mvn clean package" />
        </exec>
    </target>

    <target name="copyAll" depends="mvn_package">
        <copy todir="${build}" file="${target}/springboot-package.jar"></copy> 
        <copy todir="${build}" file="logback.xml"></copy>
        <copy todir="${build}" file="application.properties"></copy>
        <copy todir="${build}" file="run.bat"></copy>
    </target>
</project>

注:<mkdir dir="${build}"></mkdir>是指定文件存放的文件夹,executable是使用cmd命令,line是执行的语句, 标签是将文件复制到指定的文件夹中。

然后再新建一个 build.bat文件,里面只需要填写 ant就行了。
准备完之后,只需双击build.bat,项目和配置文件就自动到build文件中了,省去了很多操作。

虽然现在流行通过jenkins进行打包部署,不过使用ant加maven进行打包也不错的,比较简单。

打包遇到的一些问题

问题:source-1.5 中不支持 diamond运算符

解决办法一:
在properties添加
<maven.compiler.source>1.8</maven.compiler.source><maven.compiler.target>1.8</maven.compiler.target>

  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
    <java.version>1.8</java.version>
    <fastjson>1.2.41</fastjson>
    <maven.compiler.source>1.8</maven.compiler.source>
    <maven.compiler.target>1.8</maven.compiler.target>
  </properties>

解决方案二:
在plugin中添加 <source>1.8</source><target>1.8</target>

<build>  
        <plugins>  
            <plugin>  
                <groupId>org.apache.maven.plugins</groupId>  
                <artifactId>maven-compiler-plugin</artifactId>  
                <version>3.3</version>  
                <configuration>  
                    <source>1.8</source>  
                    <target>1.8</target>  
                </configuration>  
            </plugin>  
        </plugins>  
    </build>

问题二:打包出现某jar包无法打入

实际是可以下载,但是无法将此打入包中

解决办法:
pom.xml中添加

  <repositories>  
     <repository>  
            <id>spring-milestone</id>  
            <url>http://repo.spring.io/libs-release</url>  
     </repository>  
   </repositories>

问题三:mvn clean 失败,出现Failed to execute goal

原因: 在clean的时候,target里面的文件被占用了。
解决办法: 不占用就行了。

SpringBoot部署

如果是jar项目
Windows系统在项目同级目录下输入:

java -jar springboot-package

即可启动项目。
关闭项目,只需关掉dos界面就可以了。
也可以写一个bat文件进行运行。
示例:

@echo off
title "springboot-package"
java -jar springboot-package.jar

Linux系统在项目同级目录下输入:

nohup -jar springboot-package &amp;

即可启动。
关闭输入:

kill -9 pid(jar的进程id)

也可以在init.d注册一个服务
示例:

ln -s /home/jars/app/springboot-package.jar /etc/init.d/springboot-package
chmod +x /etc/init.d/springboot-package

然后输入:

service springboot-package start|stop|restart

进行启动或者停止。
当然也可以编写xshell脚本进行启动和关闭。
示例:

#!/bin/bash
APPDIR=`pwd`
PIDFILE=$APPDIR/springboot-package.pid
if [ -f "$PIDFILE" ] && kill -0 $(cat "$PIDFILE"); then
echo "springboot-package is already running..."
exit 1
fi
nohup java -jar $APPDIR/springboot-package.jar >/dev/null 2>&1 &
echo $! > $PIDFILE
echo "start springboot-package..."

如果是war项目
war放在tomcat/webapp目录下,然后启动tomcat就可以了。Windows系统 在tomcat/bin目录下双击startup.bat即可启动,双击shutdown.bat关闭。
Linux系统则在tomcat/bin 目录下输入startup.sh即可启动, 输入shutdown.sh关闭
附SpringBoot打包部署的项目工程地址:
https://github.com/xuwujing/springBoot-study/tree/master/springboot-package

相关推荐:

Tomcat部署Web项目该如何实现?

编写简单的Mapreduce程序并部署在Hadoop2.2.0上运行

以上がSpringBoot はどのようにして簡単なパッケージ化とデプロイメントを実行するのでしょうか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

mPDF

mPDF

mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい