玩轉spring boot——結合阿里雲持續交付


前言

  在互聯網項目中,項目測試、部署往往需要花費大量時間。傳統方式是在本地打包、測試完畢程序,然后通過ftp上傳至服務器,再把測試的配置文件修改為生產環境的配置文件,最后重新運行服務。這一過程如果交給人工完成往往容易出錯,如項目有大量的配置,而僅有一處配置不正確將會發生重大的災難,因此項目的持續集成和持續交付則尤為重要。之前,筆者的項目是通過git+maven+tomcat+jenkins來完成的,而如今阿里雲推出了持續交付平台,筆者來為大家踩坑。

 

一、准備工作(spring boot+maven的項目)


 

package com.github.carter659.springskill01;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;

/**
 * 入口類 博客出處:http://www.cnblogs.com/GoodHelper/
 *
 */
@SpringBootApplication
@Controller
public class App {

    @Value("${name}")
    private String name;

    public static void main(String[] args) {
        SpringApplication.run(App.class, args);
    }

    @GetMapping("/")
    public String index(Model model) {
        model.addAttribute("name", name);
        return "index";
    }
}
App.java

 

<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title>玩轉spring boot——結合阿里雲持續交付</title>
</head>
<body>
    <h1>玩轉spring boot——結合阿里雲持續交付</h1>
    <h4>
        <a href="http://www.cnblogs.com/GoodHelper/">from 劉冬的博客</a>
    </h4>
    <h3 th:text="'環境為:' + ${name}"></h3>
    <br />
    <a href="http://www.cnblogs.com/GoodHelper/">點擊訪問原版博客(www.cnblogs.com/GoodHelper)</a>
</body>
</html>
index.html
<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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.github.carter659</groupId>
    <artifactId>springskill01</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>jar</packaging>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>1.4.3.RELEASE</version>
    </parent>

    <name>springskill01</name>
    <url>http://maven.apache.org</url>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <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-thymeleaf</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <optional>true</optional>
        </dependency>
    </dependencies>


    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
        <finalName>spring-skill-01</finalName>
    </build>
</project>
pom.xml

build節點配置生成的jar名“<finalName>spring-skill-01</finalName>”,之后的腳步中會執行java -jar命令的jar的名稱就是“spring-skill-01”

 

增加三個配置文件:

application.properties:

## dev | prod | test
spring.profiles.active=dev

 

application-dev.properties:

name=\u5F00\u53D1\u73AF\u5883

 

application-prod.properties:

name=\u751F\u4EA7\u73AF\u5883

分別演示開發、生產環境的不同配置

 

項目結構為:

 

本地運行效果為:

 

二、配置linux服務器


 

mkdir /opt/java
mkdir /opt/run
vi /opt/run/run.sh

“/opt/java”路徑是之后阿里雲持續交付平台上傳文件的路徑

 

創建項目的目錄和運行項目的腳步文件

“/opt/run/run.sh”文件為:
#!/bin/bash
cd /opt/java
ps aux | grep spring | xargs kill -9
tar -xzf package.tgz
java -jar /opt/java/spring-skill-01.jar --spring.profiles.active=prod

目的是:解壓阿里雲持續交付平台上傳的項目,執行java -jar運行並生產環境的spring boot的jar,而“spring-skill-01.jar”就是之前在pom.xml節點<finalName>spring-skill-01</finalName>配置的。

 

三、配置阿里雲持續交付平台


 

首先,登錄阿里雲git庫“https://code.aliyun.com/” 創建git項目

 

選擇一個私有項目

 

創建完項目后,選擇持續交付平台菜單

 

 

創建持續交付項目

 

 

 

為該項目創建工作流

 

選擇默認模板並輸入名稱

 

 

配置工作流節點“打包”,執行“mvn package”命令

 

配置部署節點,設置之前在服務器創建的路徑“/opt/java”

配置運行腳本的路徑

 

配置機器授權

 

點擊拷貝按鈕,復制所拷貝的key

 

在服務器新建文件和key文件

mkdir $HOME/.ssh/
vi $HOME/.ssh/authorized_keys

在“$HOME/.ssh/authorized_keys”文件中粘帖復制的key

 

四、運行效果


 

執行git命令push代碼

git add. 
git commit -m 'ok'
git push

 

由於push代碼會觸發持續交付平台的工作流

 

所以會按照之前設定好的腳本運行

 

 

部署完畢后,訪問服務器中項目:

 

 


 總結

   持續交付的整個簡單過程就演示完了,但上述方案並不完美。問題出在執行的腳本上,正式項目需要把spring boot創建成服務,使用服務停止的命令終止進程,而不是使用kill來殺死進程。另外,正式項目還需要部署多個web容器,以便於讓用戶不間斷和在察覺不到的情況下更新程序,需要與nginx聯合使用。

 


 

代碼:https://github.com/carter659/spring-boot-skill-01.git

 

如果你覺得我的博客對你有幫助,可以給我點兒打賞,左側微信,右側支付寶。

有可能就是你的一點打賞會讓我的博客寫的更好:)

 

返回玩轉spring boot系列目錄


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM