开发者社区> 问答> 正文

jboot打包运行出错 400 请求报错 

使用appassembler-maven-plugin插件打包后,执行,使用idea直接运行是正常的,是打包配置出错了吗?@理工男海哥 显示空指针异常,如下:

yangyaos-MBP:bin yangyao$ ./component-system log4j:WARN No appenders could be found for logger (com.jfinal.kit.LogKit). log4j:WARN Please initialize the log4j system properly. log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.


| || \ / \ / \ | | |__ || o )| || || | | || || O || O ||| || / | || O || || | | |
\ ` || || || | | |
_
_||_| _/ _/ |__|

JbootConfig {version='1.6.3', mode='dev', bannerEnable=true, bannerFile='banner.txt', jfinalConfig='io.jboot.web.JbootAppConfig'} JbootServerConfig {type='${jboot.server.type}', host='${jboot.server.host}', port=8080, contextPath='${jboot.server.contextPath}'} JbootWebConfig {actionCacheEnable=true, actionCacheKeyGeneratorType='default', websocketEnable=false, websocketBufferPoolSize=100, cookieEncryptKey='JBOOT_DEFAULT_ENCRYPT_KEY'} Exception in thread "main" java.lang.NullPointerException at io.jboot.Jboot.startServer(Jboot.java:168) at io.jboot.Jboot.start(Jboot.java:149) at io.jboot.Jboot.run(Jboot.java:92) at com.jzdoctor.component.system.Application.main(Application.java:55) yangyaos-MBP:bin yangyao$

不知道是我的打包配置不对吗?附上我的打包插件配置
<plugin> <groupId>org.codehaus.mojo</groupId> <artifactId>appassembler-maven-plugin</artifactId> <version>1.10</version> <configuration> <encoding>UTF-8</encoding> <!-- 生成的应用目录 --> <assembleDirectory>${project.build.directory}/app</assembleDirectory> <!-- 输出的依赖包目录,基于assembleDirectory --> <repositoryName>lib</repositoryName> <!-- lib目录中jar的存放规则,默认是${groupId}/${artifactId}的目录格式,flat表示直接把jar放到lib目录 --> <repositoryLayout>flat</repositoryLayout> <!-- 生成的执行文件目录,基于assembleDirectory --> <binFolder>bin</binFolder> <!-- 生成的配置文件的目标目录的名称,基于assembleDirectory --> <configurationDirectory>configs</configurationDirectory> <!-- 应用程序配置文件目录 --> <configurationSourceDirectory>${project.basedir}/src/main/resources/</configurationSourceDirectory>

                <!-- 是否复制configurationSourceDirectory下的配置文件到configurationDirectory -->
                <copyConfigurationDirectory>true</copyConfigurationDirectory>
                <!-- 应用console日志输出目录,基于assembleDirectory -->
                <logsDirectory>logs</logsDirectory>
                <!-- 应用产生的临时文件目录,基于assembleDirectory -->
                <tempDirectory>temp</tempDirectory>

                <!-- 生成的应用程序配置 mvn package appassembler:assemble -->
                <programs>
                    <program>
                        <id>component-system</id>
                        <!-- 程序入口 -->
                        <mainClass>com.jzdoctor.component.system.Application</mainClass>
                        <!-- 生成的应用程序平台,支持unix,windows,all -->
                        <platforms>
                            <platform>unix</platform>
                            <platform>windows</platform>
                        </platforms>
                    </program>
                </programs>
                <!-- 生成的后台运行的应用配置 mvn clean package appassembler:generate-daemons -->
                <daemons>
                    <daemon>
                        <id>component-system</id>
                        <!-- 程序入口 -->
                        <mainClass>com.jzdoctor.component.system.Application</mainClass>
                        <platforms>
                            <platform>jsw</platform>
                        </platforms>
                        <!-- 包含的平台-->
                        <includes>
                            <include>linux-x86-32</include>
                            <include>linux-x86-64</include>
                            <include>windows-x86-32</include>
                            <include>windows-x86-64</include>
                            <include>macosx-universal-32</include>
                            <include>macosx-universal-64</include>
                        </includes>
                        <!-- 配置信息,参考http://www.mojohaus.org/appassembler/appassembler-maven-plugin/usage-daemon-generatorconfig.html -->
                        <configuration>
                            <property>
                                <name>configuration.directory.in.classpath.first</name>
                                <value>configs</value>
                            </property>
                            <property>
                                <name>wrapper.ping.timeout</name>
                                <value>120</value>
                            </property>
                            <property>
                                <name>set.default.REPO_DIR</name>
                                <value>lib</value>
                            </property>
                            <property>
                                <name>wrapper.logfile</name>
                                <value>logs/wrapper.log</value>
                            </property>
                        </configuration>
                        <!-- jvm设置 http://www.mojohaus.org/appassembler/appassembler-maven-plugin/usage-daemon-jvmsettings.html-->
                        <!--<jvmSettings></jvmSettings>-->
                    </daemon>
                </daemons>
            </configuration>
        </plugin></code></pre> 

 

展开
收起
kun坤 2020-05-30 14:29:04 565 0
1 条回答
写回答
取消 提交回答
  • 终于找到原因了,因为在pom.xml中配置了动态替换资源文件,最终生成的target目录中的classes目录中的内容是替换了的,但是不知为何,这个appassembler-maven-plugin插件打包生成的app/configs下的配置文件无法替换。 @理工男海哥 ######这个最终是怎么解决的呢,求分享######你的错误是什么呢?

    2020-05-30 14:29:14
    赞同 展开评论 打赏
问答分类:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载