【问题标题】:Azure spring boot deployment - container problemAzure Spring Boot 部署 - 容器问题
【发布时间】:2019-03-30 08:35:15
【问题描述】:

我在 azure 上的 Spring Boot 部署有问题。我按照上的步骤 microsoft docs 我能够在本地启动我的网络服务。 我还部署了 microsoft 的示例,并使用了我的 mysql 数据库,该数据库也托管在 azure 上,没有任何问题。

我还将应用程序设置 WEBSITES_CONTAINER_START_TIME_LIMIT 设置为最大值。

这是我的 pom.xml

<groupId>groupId</groupId>
<artifactId>billSharingWebservice</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>jar</packaging>


<properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
    <java.version>1.8</java.version>
</properties>

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-jpa</artifactId>
        <version>2.0.6.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-security</artifactId>
        <version>2.0.6.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
        <version>2.0.6.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <version>2.0.6.RELEASE</version>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>org.springframework.security</groupId>
        <artifactId>spring-security-test</artifactId>
        <version>5.1.1.RELEASE</version>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>8.0.13</version>
    </dependency>
    <dependency>
        <groupId>io.springfox</groupId>
        <artifactId>springfox-swagger2</artifactId>
        <version>2.9.2</version>
    </dependency>
</dependencies>

<build>

    <plugins>

        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <version>3.1</version>
            <configuration>
                <source>1.8</source>
                <target>1.8</target>
            </configuration>
        </plugin>
        <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <version>2.0.6.RELEASE</version>
        </plugin>

    <plugin>
       <groupId>com.microsoft.azure</groupId>
       <artifactId>azure-webapp-maven-plugin</artifactId>
       <version>1.4.0</version>
       <configuration>
           <deploymentType>jar</deploymentType>

      <!-- Web App information -->
       <resourceGroup>billSharing</resourceGroup>
                <appName>billsharing</appName>
                <region>westeurope</region>  

           <!-- Java Runtime Stack for Web App on Linux-->
           <linuxRuntime>jre8</linuxRuntime>
       </configuration>
    </plugin>
    </plugins>
</build>

在 azure 上部署后,我得到以下日志:

2018-10-25 16:09:22.956 INFO  - Starting container for site
2018-10-25 16:09:22.958 INFO  - docker run -d -p 43892:8443 --name billsharing_0 -e PORT=8443 -e WEBSITE_SITE_NAME=billsharing -e WEBSITE_AUTH_ENABLED=False -e WEBSITE_ROLE_INSTANCE_ID=0 -e WEBSITE_INSTANCE_ID=96d743e51352785f93233abee2c7fb3857cba42475b37377d206d1fee114218f -e HTTP_LOGGING_ENABLED=1 appsvc/java:8-jre8_0000000000  
2018-10-25 16:10:26.869 ERROR - Container billsharing_0 for site billsharing has exited, failing site start

这并没有真正的帮助。

也许有人有想法可以帮助我 谢谢。

【问题讨论】:

    标签: java azure spring-boot maven-plugin azure-deployment


    【解决方案1】:

    我使用了您的pom.xml 并将WEBSITES_CONTAINER_START_TIME_LIMIT 设置为1800日志流 没有显示“Container XXX for XXX initialized successfully”并且该站点显示服务不可用。

    然后我尝试了pom.xml Microsoft 的推荐,效果很好。所以也许你可以试试我的设置。这是我的pom.xml

    <groupId>com.example</groupId>
    <artifactId>demo</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>jar</packaging>
    
    <name>demo</name>
    <description>Demo project for Spring Boot</description>
    
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.0.6.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    
    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
    </properties>
    
    <dependencies>
        <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>
        </dependency>
    
    
        <!-- servlet dependency. -->
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>javax.servlet-api</artifactId>
            <scope>provided</scope>
        </dependency>
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>jstl</artifactId>
        </dependency>
    
        <!-- tomcat support.-->
        <dependency>
            <groupId>org.apache.tomcat.embed</groupId>
            <artifactId>tomcat-embed-jasper</artifactId>
            <scope>provided</scope>
        </dependency>
    </dependencies>
    
    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
            <plugin>
                 <groupId>com.microsoft.azure</groupId>
                 <artifactId>azure-webapp-maven-plugin</artifactId>
                 <version>1.4.0</version>
                 <configuration>
                   <deploymentType>jar</deploymentType>
    
                   <!-- configure app to run on port 80, required by App Service -->
                    <appSettings>
                     <property> 
                       <name>JAVA_OPTS</name> 
                       <value>-Dserver.port=80</value> 
                     </property> 
                    </appSettings>
    
                   <!-- Web App information -->
                   <resourceGroup>myStorageGroup</resourceGroup>
                   <appName>mvntest03</appName>
                   <region>eastus</region>  
    
                   <!-- Java Runtime Stack for Web App on Linux-->
                   <linuxRuntime>jre8</linuxRuntime>
                 </configuration>
            </plugin>
        </plugins>
    </build>
    

    这是我的日志流page

    如果您还有其他设置或仍有疑问,请告诉我。

    【讨论】:

    • @Lenni2309 如果我的回答对你有帮助,你能接受我的回答吗?谢谢。
    猜你喜欢
    • 2015-02-06
    • 2020-01-09
    • 2020-08-28
    • 1970-01-01
    • 2022-11-21
    • 2016-02-15
    • 2021-01-14
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多