Spring boot(4)-應用打包部署
1、Spring Boot內建web
Spring Boot 其預設是整合web容器的,啟動方式由像普通Java程式一樣,main函式入口啟動。其內建Tomcat容器或Jetty容器,具體由配置來決定(預設Tomcat)。當然你也可以將專案打包成war包,放到獨立的web容器中(Tomcat、weblogic等等),當然在此之前你要對程式入口做簡單調整。
對server的幾個常用的配置做個簡單說明:
# 專案contextPath,一般在正式釋出版本中,我們不配置 server.context-path=/myspringboot # 錯誤頁,指定發生錯誤時,跳轉的URL。請檢視BasicErrorController原始碼便知 server.error.path=/error # 服務埠 server.port=9090 # session最大超時時間(分鐘),預設為30 server.session-timeout=60 # 該服務繫結IP地址,啟動伺服器時如本機不是該IP地址則丟擲異常啟動失敗,只有特殊需求的情況下才配置 # server.address=192.168.16.11
Tomcat
Tomcat為Spring Boot的預設容器,下面是幾個常用配置:
pom.xml依賴配置:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
<!--<scope>provided</scope>-->
</dependency>
Jetty# tomcat最大執行緒數,預設為200 server.tomcat.max-threads=800 # tomcat的URI編碼 server.tomcat.uri-encoding=UTF-8 # 存放Tomcat的日誌、Dump等檔案的臨時資料夾,預設為系統的tmp資料夾(如:C:\Users\Shanhy\AppData\Local\Temp) server.tomcat.basedir=H:/springboot-tomcat-tmp # 開啟Tomcat的Access日誌,並可以設定日誌格式的方法: #server.tomcat.access-log-enabled=true #server.tomcat.access-log-pattern= # accesslog目錄,預設在basedir/logs #server.tomcat.accesslog.directory= # 日誌檔案目錄 logging.path=H:/springboot-tomcat-tmp # 日誌檔名稱,預設為spring.log logging.file=myapp.log
如果你要選擇Jetty,也非常簡單,就是把pom中的tomcat依賴排除,並加入Jetty容器的依賴,如下:
<dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <exclusions> <exclusion> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-tomcat</artifactId> </exclusion> </exclusions> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-jetty</artifactId> </dependency> <dependencies>
專案構建我們使用Maven或Gradle,這將使專案依賴、jar包管理、以及打包部署變的非常方便。
2、Maven構建Spring Boot框架的可執行Jar包
在spring boot裡,很吸引人的一個特性是可以直接把應用打包成為一個jar/war,然後這個jar/war是可以直接啟動的,不需要另外配置一個Web Server。單獨的JAR包,然後通過java -jar <name>.jar
命令執行。
1.1 Maven
SpringBootMaven外掛為Maven提供SpringBoot支援,它允許你打包可執行jar或war存檔,然後就地執行應用。為了使用
它,你需要使用Maven3.2(或更高版本)。
Maven使用者可以繼承spring-boot-starter-parent專案來獲取合適的預設設定。該父專案提供以下特性:
1、預設編譯級別為Java1.6
2、原始碼編碼為UTF-8
3、一個依賴管理節點,允許你省略普通依賴的<version>標籤,繼承自 spring-boot-dependenciesPOM。
合適的資源過濾
4、合適的外掛配置(exec外掛,surefire,GitcommitID,shade)
5、針對application.properties和application.yml 的資源過濾
6、最後一點:由於預設配置檔案接收Spring風格的佔位符( ${...} ),Maven
filtering改用@[email protected]佔位符(你可以使用Maven屬性 resource.delimiter來覆蓋它)。
1.2繼承starter parent
想配置你的專案繼承
spring-boot-starter-parent只需要簡單地設定parent為:<!-- Inherit defaults from Spring Boot -->
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.3.0.BUILD-SNAPSHOT</version>
</parent>
注:你應該只需要在該依賴上指定SpringBoot版本。如他的starters,你可以放心的省略版本號。
1.3使用沒有父POM的SpringBoot
不是每個人都喜歡繼承spring-boot-starter-parentPOM。你可能需要使用公司標準parent,或你可能傾向於顯式宣告所有
Maven配置。
如果你不使用 spring-boot-starter-parent,通過使用一個scope=import 的依賴,你仍能獲取到依賴管理的好處:
<dependencyManagement>
<dependencies>
<dependency>
<!-- Import dependency management from Spring Boot -->
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>1.3.0.BUILD-SNAPSHOT</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
1.4改變Java版本
spring-boot-starter-parent選擇相當保守的Java相容策略。如果你遵循我們的建議,使用最新的Java版本,你可以新增一
個java.version屬性:
<properties>
<java.version>1.8</java.version>
</properties>
1.5 使用Spring Boot Maven外掛
SpringBoot包含一個Maven外掛,它可以將專案打包成一個可執行jar。如果想使用它,你可以將該外掛新增到<plugins>節
點處:
<?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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<!-- ... -->
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>1.3.0.BUILD-SNAPSHOT</version>
<executions>
<execution>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
</project>
注:如果使用Spring-Boot-tarter-parentpom,你只需要新增該外掛而無需配置它,除非你想改變定義在partent中的設定。
該配置會在Maven生命週期的 package階段重新打包一個jar或war。下面的示例顯示在target目錄下既有重新打包後的jar,
也有原始的jar:
1.6 linux下打包方法:
使用 mvn clean package 命令打包如果還沒有安裝maven :
yum -y install apache-maven
或者單獨下載安裝:wget http://apache.fayea.com/maven/maven-3/3.3.9/binaries/apache-maven-3.3.9-bin.tar.gz
tar zxvf apache-maven-3.3.9-bin.tar.gz
設定環境變數:
MVN_HOME=/usr/local/app/apache-maven-3.3.9
export PATH=$PATH:$MVN_HOME/bin
然後可以使用以下命令編譯:
mvn clean package
可以追加引數 -Dmaven.test.skip=true 跳過測試。
$mvn package
$ls target/*.ja
target/myproject-1.0.0.jartarget/myproject-1.0.0.jar.original1.6 使用Eclipse下打包方法:
開啟maven外掛的maven package,就可以打包了:
打包出來的檔案:
如果不包含像上面那樣的<execution/>,你可以自己執行該外掛(但只有在package目標也被使用的情況)。例如:
$ mvn package spring-boot:repackage
$ ls target/*.jar
target/myproject-1.0.0.jartarget/myproject-1.0.0.jar.original
如果使用一個里程碑或快照版本,你還需要新增正確的pluginRepository元素:
<pluginRepositories>
<pluginRepository>
<id>spring-snapshots</id>
<url>http://repo.spring.io/snapshot</url>
</pluginRepository>
<pluginRepository>
<id>spring-milestones</id>
<url>http://repo.spring.io/milestone</url>
</pluginRepository>
</pluginRepositories>
打包可執行jar和war檔案
一旦spring-boot-maven-plugin被包含到你的pom.xml中,它就會自動嘗試使用spring-boot:repackage目標重寫存檔以使它們能夠執行。為了構建一個jar或war,你應該使用常規的packaging元素配置你的專案:
<?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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<!-- ... -->
<packaging>jar</packaging>
<!-- ... -->
</project>
生成的存檔在 package 階段會被SpringBoot增強。你想啟動的main類即可以通過指定一個配置選項,也可以通過為manifest新增一個Main-Class屬性這種常規的方式實現。如果你沒有指定一個main類,該外掛會搜尋帶有publicstaticvoidmain(String[]args)方法的類。
為了構建和執行一個專案的artifact,你可以輸入以下命令:
$ mvn package
$ java -jar target/spring-boot01-1.0-SNAPSHOT.jar
這種方式,只要控制檯關閉,服務就不能訪問了。下面我們使得 jar 包在後臺執行:
java -jar spring-boot01-1.0-SNAPSHOT.jar > log.file 2>&1 &
為了構建一個即是可執行的,又能部署到一個外部容器的war檔案,你需要標記內嵌容器依賴為"provided",例如:
<?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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<!-- ... -->
<packaging>war</packaging>
<!-- ... -->
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
<scope>provided</scope>
</dependency>
<!-- ... -->
</dependencies>
</project>
4、打包為單個jar時,spring boot的啟動方式
maven打包之後,會生成兩個jar檔案:
demo-0.0.1-SNAPSHOT.jar
demo-0.0.1-SNAPSHOT.jar.original
其中demo-0.0.1-SNAPSHOT.jar.original是預設的maven-jar-plugin生成的包。
demo-0.0.1-SNAPSHOT.jar是spring boot maven外掛生成的jar包,裡面包含了應用的依賴,以及spring boot相關的類。下面稱之為fat jar。
先來檢視spring boot打好的包的目錄結構(不重要的省略掉):
├── META-INF
│ ├── MANIFEST.MF
├── application.properties
├── com
│ └── example
│ └── SpringBootDemoApplication.class
├── lib
│ ├── aopalliance-1.0.jar
│ ├── spring-beans-4.2.3.RELEASE.jar
│ ├── ...
└── org
└── springframework
└── boot
└── loader
├── ExecutableArchiveLauncher.class
├── JarLauncher.class
├── JavaAgentDetector.class
├── LaunchedURLClassLoader.class
├── Launcher.class
├── MainMethodRunner.class
├── ...
依次來看下這些內容。
MANIFEST.MF
Manifest-Version: 1.0
Start-Class: com.example.SpringBootDemoApplication
Implementation-Vendor-Id: com.example
Spring-Boot-Version: 1.3.0.RELEASE
Created-By: Apache Maven 3.3.3
Build-Jdk: 1.8.0_60
Implementation-Vendor: Pivotal Software, Inc.
Main-Class: org.springframework.boot.loader.JarLauncher
可以看到有Main-Class是org.springframework.boot.loader.JarLauncher ,這個是jar啟動的Main函式。
還有一個Start-Class是com.example.SpringBootDemoApplication,這個是我們應用自己的Main函式
@SpringBootApplication
public class SpringBootDemoApplication {
public static void main(String[] args) {
SpringApplication.run(SpringBootDemoApplication.class, args);
}
}
com/example 目錄
這下面放的是應用的.class檔案。
lib目錄
這裡存放的是應用的Maven依賴的jar包檔案。
比如spring-beans,spring-mvc等jar。
org/springframework/boot/loader 目錄
這下面存放的是Spring boot loader的.class檔案。
啟動:
我們直接啟動:java -jar demo-0.0.1-SNAPSHOT.jar
5、Maven新增本地Jar包
我們有時候專案依賴外部的jar,我們使用Eclipse開發的時候我們直接通過build path新增jar就可以,但是使用mvn 打包的時候就會缺少這個包。
1. 使用system scope
我們直接引入rabbitmq-client.jar。這個方式比較靈活,到新的伺服器上,無需做額外的操作。
<dependency>
<groupId>rabbitmq.client</groupId>
<artifactId>rabbitmq.client</artifactId>
<version>3.0</version>
<scope>system</scope>
<systemPath>${basedir}/src/main/WEB-INF/lib/rabbitmq-client.jar</systemPath>
</dependency>
1、groupId和artifactId以及version都是可以隨便填寫的 ,scope必須填寫為system,而systemPath我們現在我們jar包的目錄地址就可以了2、${basedir}就是專案根目錄
2. 將jar包安裝到本地repository中
這個需要在新機器上執行mvn install:install-file命令。
mvn install:install-file
-Dfile= jar檔案所存放的地址
-DgroupId= jar檔案所屬的group:包名
-DartifactId= jar的專案名 名稱,一般就是去掉字尾的檔名
-Dversion=版本號
-Dpackaging=jar:此包的打包形式,就是jar
-DgeneratePom=true
例如執行命令:mvn install:install-file -Dfile=D:\JAR_LIB\rabbitmq-client.jar -DgroupId=com.rabbitmq -DartifactId=client -Dversion=3.5.0 -Dpackaging=jar -DgeneratePom=true -DcreateChecksum=true
在專案中引用:
<dependency>
<groupId>com.rabbitmq</groupId>
<artifactId>client</artifactId>
<version>3.5.0</version>
</dependency>
3、新增 in project repository
設定專案的庫目錄
<repository>
<id>in-project</id>
<name>In Project Repo</name>
<url>file://${project.basedir}/lib</url>
</repository>
新增依賴:
<dependency>
<groupId>com.rabbitmq</groupId>
<artifactId>client</artifactId>
<version>3.5.0</version>
</dependency>
jar包及路徑必須嚴格遵循格式:
/groupId/artifactId/version/artifactId-verion.jar
本例中: lib/com/rabbitmq/client/3.5.0/rabbitmq-client-3.5.0.jar
6、部署到javaEE容器
修改啟動類,繼承 SpringBootServletInitializer 並重寫 configure 方法public class SpringBootSampleApplication extends SpringBootServletInitializer{
private static final Logger logger = LoggerFactory.getLogger(SpringBootSampleApplication.class);
@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder builder) {
return builder.sources(this.getClass());
}
}
修改pom檔案中jar 為 war
<!-- <packaging>jar</packaging> -->
<packaging>war</packaging>
修改pom,排除tomcat外掛 <dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
</exclusion>
</exclusions>
</dependency>
打包部署到容器 7、熱部署
在我們開發過程中,我們需要經常修改,為了避免重複啟動專案,我們可以啟用熱部署。Spring-Loaded專案提供了強大的熱部署功能,新增/刪除/修改 方法/欄位/介面/列舉 等程式碼的時候都可以熱部署,速度很快,很方便。
想在Spring Boot中使用該功能非常簡單,就是在spring-boot-maven-plugin外掛下面新增依賴:
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>springloaded</artifactId>
<version>1.2.5.RELEASE</version>
</dependency>
</dependencies>
新增以後,通過mvn spring-boot:run啟動就支援熱部署了。
注意:使用熱部署的時候,需要IDE編譯類後才能生效,你可以開啟自動編譯功能,這樣在你儲存修改的時候,類就自動重新載入了。
8、使用Profile區分環境
application.properties區分環境
spring boot 可以在 “配置檔案”、“Java程式碼類”、“日誌配置” 中來配置profile區分不同環境執行不同的結果
1、配置檔案
使用配置檔案application.yml 和 application.properties 有所區別
以application.properties 為例,通過檔名來區分環境 application-{profile}.properties
application.properties
app.name=MyApp
server.port=8080
spring.profiles.active=dev
application-dev.properties
server.port=8081
application-stg.properties
server.port=8082
在啟動程式的時候通過新增 –spring.profiles.active={profile} 來指定具體使用的配置
例如我們執行 java -jar demo.jar –spring.profiles.active=dev 那麼上面3個檔案中的內容將被如何應用?
Spring Boot 會先載入預設的配置檔案,然後使用具體指定的profile中的配置去覆蓋預設配置。
app.name 只存在於預設配置檔案 application.properties 中,因為指定環境中不存在同樣的配置,所以該值不會被覆蓋
server.port 預設為8080,但是我們指定了環境後,將會被覆蓋。如果指定stg環境,server.port 則為 8082
spring.profiles.active 預設指定dev環境,如果我們在執行時指定 –spring.profiles.active=stg 那麼將應用stg環境,最終 server.port 的值為8082
Maven環境配置
專案工程統一使用maven的profile外掛定義不同的專案構建環境(dev, alpha, beta, prod),通過filter外掛為不同環境下的配置項注入對應的引數值來實現動態配置目標。
2.3.1定義profile
在POM.xml中配置四個profile,對應專案所處的四個不同的環境-dev, alpha, beta, prod, profile的id屬性即為每個環境賦予一個唯一的標示,元素的內容則是以key-value的形式出現的鍵值對,如我們定義了一個變數,其值在不同的環境下(不同id)被賦予了不同的值(dev, test, pre-prod, prod),要啟用不同的環境打包,我們可以在命令列通過mvn package –P${profileId}來讓其執行,為了開發便利,預設啟用的是dev開發環境,即開發人員不需要通過命令列手動輸入-p引數也能執行dev環境的打包。
<profile>
<!-- 本地引數 -->
<id>dev</id>
<properties>
<server.port>8081</server.port>
<server.address>0.0.0.0</server.address>
<profileActive>dev</profileActive>
</properties>
<build>
<filters>
<filter>
<groupId>${basedir}/src/main/resources/dev.properties</groupId>
</filter>
</profile>
9、建立一個Linux 應用的sh指令碼
下面幾個指令碼僅供參考:
打包:clean.sh
#0、check user
TIME_STAMP=`date +%Y%m%d%H%M`
WHO=`whoami`
if [ "$WHO" != 'www' ]; then
echo 'current user is not www'
echo 'exit'
exit
fi
CODE_HOME=/home/www/app
PROJECTNAME=qrealtime
cd $CODE_HOME/$PROJECTNAME
git pull
mvn clean package
pid=`ps -ef |grep $PROJECTNAME |grep -v "grep" |awk '{print $2}' `
if [ $pid != "" ]; then
echo "App is running and pid=$pid"
else
echo "App is not running."
fi
start.sh
#0、check user
TIME_STAMP=`date +%Y%m%d%H%M`
WHO=`whoami`
if [ "$WHO" != 'www' ]; then
echo 'current user is not www'
echo 'exit'
exit
fi
CODE_HOME=/home/www/app
PROJECTNAME=qrealtime
cd $CODE_HOME/$PROJECTNAME
pid=`ps -ef |grep $PROJECTNAME |grep -v "grep" |awk '{print $2}'`
if [ $pid ]; then
echo "App is running and pid=$pid"
else
nohup java -jar $CODE_HOME/$PROJECTNAME/target/$<span style="font-family: 'microsoft yahei';">PROJECTNAME</span><span style="font-family: 'microsoft yahei';">-0.0.1-SNAPSHOT.jar > /dev/null 2>&1 &</span>
fi
stop.sh
#0、check user
TIME_STAMP=`date +%Y%m%d%H%M`
WHO=`whoami`
if [ "$WHO" != 'www' ]; then
echo 'current user is not www'
echo 'exit'
exit
fi
CODE_HOME=/home/www/app
PROJECTNAME=qrealtime
cd $CODE_HOME/$PROJECTNAME
pid=`ps -ef |grep $PROJECTNAME |grep -v "grep" |awk '{print $2}' `
if [ $pid ]; then
echo "App is running and pid=$pid"
kill -9 $pid
if [[ $? -eq 0 ]];then
echo "sucess to stop $PROJECTNAME "
else
echo "fail to stop $PROJECTNAME "
fi
fi
restart
#0、check user
TIME_STAMP=`date +%Y%m%d%H%M`
WHO=`whoami`
if [ "$WHO" != 'www' ]; then
echo 'current user is not www'
echo 'exit'
exit
fi
CODE_HOME=/home/www/app
PROJECTNAME=qrealtime
cd $CODE_HOME/$PROJECTNAME
pid=`ps -ef |grep $PROJECTNAME |grep -v "grep" |awk '{print $2}' `
if [ $pid ]; then
echo "App is running and pid=$pid"
kill -9 $pid
fi
nohup java -jar $CODE_HOME/$PROJECTNAME/target/$PROJECTNAME-0.0.1-SNAPSHOT.jar > /dev/null 2>&1 &
10、Spring Boot應用的docker化
首先看Spring Boot應用程式的docker化,由於Spring Boot內嵌了tomcat、Jetty等容器,因此我們對docker映象的要求就是需要java執行環境。我的應用程式碼的的Dockerfile檔案如下:
#基礎映象:倉庫是java,標籤用8u66-jdk
FROM java:8u66-jdk
#當前映象的維護者和聯絡方式
MAINTAINER duqi [email protected]
#將打包好的spring程式拷貝到容器中的指定位置
ADD target/bookpub-0.0.1-SNAPSHOT.jar /opt/bookpub-0.0.1-SNAPSHOT.jar
#容器對外暴露8080埠
EXPOSE 8080
#容器啟動後需要執行的命令
CMD java -Djava.security.egd=file:/dev/./urandom -jar /opt/bookpub-0.0.1-SNAPSHOT.jar
因為目前的示例程式比較簡單,這個dockerfile並沒有在將應用程式的資料存放在宿主機上。如果你的應用程式需要寫檔案系統,例如日誌,最好利用VOLUME /tmp
命令,這個命令的效果是:在宿主機的/var/lib/docker目錄下建立一個臨時檔案並把它連結到容器中的/tmp目錄。
把這個Dockerfile放在專案的根目錄下即可,後續通過docker-compose build
統一構建:基礎映象是隻讀的,然後會在該基礎映象上增加新的可寫層來供我們使用,因此java映象只需要下載一次。
docker-compose是用來做docker服務編排,參看《Docker從入門到實踐》中的解釋:
Compose 專案目前在 Github 上進行維護,目前最新版本是 1.2.0。Compose 定位是“defining and running complex applications with Docker”,前身是 Fig,相容 Fig 的模板檔案。
Dockerfile 可以讓使用者管理一個單獨的應用容器;而 Compose 則允許使用者在一個模板(YAML 格式)中定義一組相關聯的應用容器(被稱為一個 project,即專案),例如一個 Web 服務容器再加上後端的資料庫服務容器等。
單個docker用起來確實沒什麼用,docker技術的關鍵在於持續交付,通過與jekins的結合,可以實現這樣的效果:開發人員提交push,然後jekins就自動構建並測試剛提交的程式碼,這就是我理解的持續交付。
11、守護程序啟動
使用java命令執行應用非常簡單,但是通常我們都是通過ssh命令連線到伺服器並執行它,一旦ssh連線斷開,那麼由它fork的java子程序也就隨之銷燬了。所以我們必須藉助工具將應用作為服務執行在伺服器上:
Systemd
systemd 是Linux 下的一款系統和服務管理器。可以為Spring Boot應用編寫啟動指令碼:
[Unit]
Description=Spring Boot Application
[Service]
ExecStart=/usr/bin/java -jar location_of_jar_file.jar --spring.config.location=location_of_config.properties --spring.profiles.active=profile
User=${your expected user}
[Install]
WantedBy=multi-user.target
Supervisord
Supervisord配置:
[program:app]
command=/usr/bin/java -jar location_of_jar_file.jar --spring.config.location=location_of_config.properties --spring.profiles.active=profile
user=${your expected user}
autostart=true
autorestart=true
startsecs=10
startretries=3
12、生產環境運維支援
與開發和測試環境不同的是,當應用部署到生產環境時,需要各種運維相關的功能的支援,包括效能指標、執行資訊和應用管理等。所有這些功能都有很多技術和開源庫可以實現。Spring Boot 對這些運維相關的功能進行了整合,形成了一個功能完備和可定製的功能集,稱之為 Actuator。只需要在 POM 檔案中增加對 “org.springframe.boot:spring-boot-starter-actuator” 的依賴就可以新增 Actuator。Actuator 在新增之後,會自動暴露一些 HTTP 服務來提供這些資訊。這些 HTTP 服務的說明如表 2。
Spring Boot Actuator 所提供的 HTTP 服務
名稱 | 說明 | 是否包含敏感資訊 |
---|---|---|
autoconfig | 顯示 Spring Boot 自動配置的資訊。 | 是 |
beans | 顯示應用中包含的 Spring bean 的資訊。 | 是 |
configprops | 顯示應用中的配置引數的實際值。 | 是 |
dump | 生成一個 thread dump。 | 是 |
env | 顯示從 ConfigurableEnvironment 得到的環境配置資訊。 | 是 |
health | 顯示應用的健康狀態資訊。 | 否 |
info | 顯示應用的基本資訊。 | 否 |
metrics | 顯示應用的效能指標。 | 是 |
mappings |
顯示 Spring MVC 應用中通過“ @RequestMapping”新增的路徑對映。 |
是 |
shutdown | 關閉應用。 | 是 |
trace | 顯示應用相關的跟蹤(trace)資訊。 | 是 |
對於表中的每個服務,通過訪問名稱對應的 URL 就可以獲取到相關的資訊。如訪問“/info”就可以獲取到 info 服務對應的資訊。服務是否包含敏感資訊說明了該服務暴露出來的資訊是否包含一些比較敏感的資訊,從而確定是否需要新增相應的訪問控制,而不是對所有人都公開。所有的這些服務都是可以配置的,比如通過改變名稱來改變相應的 URL。下面對幾個重要的服務進行介紹。
health 服務
Spring Boot 預設提供了對應用本身、關係資料庫連線、MongoDB、Redis 和 Rabbit MQ 的健康狀態的檢測功能。當應用中添加了 DataSource 型別的 bean 時,Spring Boot 會自動在 health 服務中暴露資料庫連線的資訊。應用也可以提供自己的健康狀態資訊,如程式碼清單 7 所示。
health 服務
@Component public class AppHealthIndicator implements HealthIndicator { @Override public Health health() { return Health.up().build(); } }
應用只需要實現 org.springframework.boot.actuate.health.HealthIndicator 介面,並返回一個 org.springframework.boot.actuate.health.Health 物件,就可以通過 health 服務來獲取所暴露的資訊。health 服務返回的結果
{"status":"UP","app":{"status":"UP"},"db":{"status":"UP","database":"HSQL Database Engine","hello":1}}
info 服務
info 服務所暴露的資訊是完全由應用來確定的。應用中任何以“info.”開頭的配置引數會被自動的由 info 服務來暴露。只需要往 application.properties 中新增以“info.”開頭的引數即可,如:
info.app_name=My First Spring Boot Application info.app_version=1.0.0
當訪問“/info”時,訪問的 JSON 資料:
{"app_name":"My First Spring Boot Application","app_version":"1.0.0"}
metrics 服務
當訪問 metrics 服務時,可以看到 Spring Boot 通過 SystemPublicMetrics 預設提供的一些系統的效能引數值,包括記憶體、CPU、Java 類載入和執行緒等的基本資訊。應用可以記錄其他所需要的資訊。Spring Boot 預設提供了兩種型別的效能指標記錄方式:gauge 和 counter。gauge 用來記錄單個絕對數值,counter 用來記錄增量或減量值。比如在一個 Web 應用中,可以用 counter 來記錄當前線上的使用者數量。當用戶登入時,把 counter 的值加 1;當用戶退出時,把 counter 的值減 1。
示例:
@RestController public class GreetingsController { @Autowired private CounterService counterService; @RequestMapping("/greet") public String greet() { counterService.increment("myapp.greet.count"); return "Hello!"; } }
上面程式碼添加了對 Spring Boot 提供的 CounterService 的依賴。當 greet 方法被呼叫時,會把名稱為“myapp.greet.count”的計數器的值加 1。也就是當用戶每次訪問“/greet”時,該計算器就會被加 1。除了 CounterService 之外,還可以使用 GaugeService 來記錄絕對值。
感謝您的支援,我會繼續努力的! 掃碼打賞,你說多少就多少
相關推薦
Spring boot 4 應用打包部署
分享一下我老師大神的人工智慧教程!零基礎,通俗易懂!http://blog.csdn.net/jiangjunshow 也歡迎大家轉載本篇文章。分享知識,造福人民,實現我們中華民族偉大復興!  
Spring boot(4)-應用打包部署
1、Spring Boot內建web Spring Boot 其預設是整合web容器的,啟動方式由像普通Java程式一樣,main函式入口啟動。其內建Tomcat容器或Jetty容器,具體由配置來決定(預設Tomcat)。當然你也可以將專案打包成wa
spring boot(十二)打包部署
etc 命令 ring != tun packaging psi 基本 jetty 有很多網友會時不時的問我,spring boot項目如何測試,如何部署,在生產中有什麽好的部署方案嗎?這篇文章就來介紹一下spring boot 如何開發、調試、打包到最後的投產上線。
spring-boot(十二)spring-boot的測試打包部署
有很多網友會時不時的問我,spring boot專案如何測試,如何部署,在生產中有什麼好的部署方案嗎?這篇文章就來介紹一下spring boot 如何開發、除錯、打包到最後的投產上線。 開發階段 單元測試 在開發階段的時候最重要的是單元測試了,springboot對單元
Spring Boot (十):打包部署
springboot 打包與部署 一、jar 包 進入命令列模式 ,不管linux 還是windows 都是一樣的 1、編譯 進入專案目錄,使用如下命令: //命令打包(-Dmaven.test.skip=true 跳過測試)
Eclipse新建Spring-boot專案,打包部署並輸出HelloWord
Spring-boot因為其對jar包的高度整合以及簡化服務配置,快速部署等的優點,逐漸成為Java開發人員的熱衷的框架。下面演示一下怎麼在Eclipse中新建Spring-boot專案以及打包部署。 在Eclipse中建立Spring-boot有兩種方式
spring boot之專案打包部署
1.修改pom.xml打包方式以及包名相關資訊 <!--打包方式--> <packaging>war</packaging> <build> <
Spring boot-應用打包部署
1、Spring Boot內建web Spring Boot 其預設是整合web容器的,啟動方式由像普通Java程式一樣,main函式入口啟動。其內建Tomcat容器或Jetty容器,具體由配置來決定(預設Tomcat)。當然你也可以將專案打包成war包,放到獨立的we
SpringBoot進階篇4:Spring Boot EHCache應用
1、SpringBoot Cache Spring Boot 本身提供了一個基於ConcurrentHashMap 的快取機制,也集成了EhCache2.x、JCache CJSR-107、EhCache3.x、Infinispan ),還有Couchb
4.4 Spring-boot之idea熱部署 > 我的程式猿之路:第三十四章
1、點選: file ,Settings ,Build ,Execution,Deplment,compiler 然後記得apply,ok。 2、組合鍵:Shift+ALT+Ctrl+/ ,選擇“Registry”,找到“complier.automake.allow.when.app.running”
用idea打包spring boot專案,然後部署到Linux伺服器上
一、IDEA 配置在 IDEA 上 File--->Setting--->Project Structure選擇 Artifacts ,右上角加號新增--->jar選擇專案主類,點選 ok二、在 IDEA 上打包專案開啟側邊欄的 Maven Project 雙擊 Package這時候控制檯開
spring boot/cloud 應用監控
alt min .com cnblogs ima target 器監控 斷路器 htm 原文地址:http://www.cnblogs.com/skyblog/p/5633635.html 應用的監控功能,對於分布式系統非常重要。如果把分布式系統比作整個社會系統。那麽各個
【spring Boot】2.在Myecplise上把spring Boot項目打包 war包和jar包
aps let failed htm 報錯 聲明 執行 spa oss ========================================================第一部分=========================================
Spring Boot項目打包方式為war
ack ica tap web gin div err let builder spring boot項目默認是使用內嵌的tomcat打包為jar的方式,我們可以進行一些修改讓其打包方式為war包: 修改maven的pom.xml <packaging>war
spring boot 項目打包到maven倉庫供其它模塊使用
apache ng- targe plugins artifact gin -c 進行 pos 在對spring boot項目進行打包發布的時候發現其它spring boot項目服務真正引用使用該spring boot包中的類 需對打包插件做如下修改: <build&
基於Spring Boot構建應用開發規範
SpringBoot 項目規範 1.規範的意義和作用 編碼規範可以最大限度的提高團隊開發的合作效率 編碼規範可以盡可能的減少一個軟件的維護成本 , 並且幾乎沒有任何一個軟件,在其整個生命周期中,均由最初的開發人員來維護 編碼規範可以改善軟件的可讀性,可以讓開發人員盡快而徹底地理解新的代碼 規範性編碼
使用spring-boot-maven-plugin打包
maven plugin uil tid spring plugins 打包 使用 pri <build> <plugins> <plugin> <groupId>org.spring
spring boot項目打包成war並在tomcat上運行的步驟
oot uil packaging api AC initial cat figure 部署 把spring-boot項目按照平常的web項目一樣發布到tomcat容器下 一、修改打包形式 在pom.xml裏設置 <packaging>war</pa
spring boot入門之——熱部署
配置 xtend java類 throw not catch arr 直接 路徑 場景:本地調試(頻繁的啟動/停止服務器)線上發布(每次都需要啟動/停止服務器)優點:無論本地還是線上,都適用無需重啟服務器,提高開發、調試效率;提升發布、運維效率,降低運維成本java實現熱部
Spring Boot 企業級應用開發實戰
-o .com 註解 ping 折騰 jar 服務 開啟 blog Spring Boot 企業級應用開發實戰【下載地址:https://pan.baidu.com/s/1SbB-auGkUN6r2i6dtv7t_w 】 Spring Boot是目前Spring技術體系中炙