欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

Spring項目中如何使用Profile

Spring項目中如何使用Profile?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。

我們提供的服務(wù)有:成都做網(wǎng)站、成都網(wǎng)站建設(shè)、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、沭陽ssl等。為1000+企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的沭陽網(wǎng)站制作公司

前言

Spring中的Profile功能其實早在Spring 3.1的版本就已經(jīng)出來,它可以理解為我們在Spring容器中所定義的Bean的邏輯組名稱,只有當(dāng)這些Profile被激活的時候,才會將Profile中所對應(yīng)的Bean注冊到Spring容器中。

看到Profile這個關(guān)鍵字,或許你從來沒有正眼瞧過他,又或者腦海中有些模糊的印象,比如除了這里Springmvc中的Profile,maven中也有Profile的標(biāo)簽。

從字面意思來看,Profile表示側(cè)面,那什么情況下才會用到側(cè)面這個功能呢,而側(cè)面具體又有什么含義呢

打一個比方,對于數(shù)據(jù)庫的配置問題,在開發(fā)的眼中可以使用嵌入的數(shù)據(jù)庫,并且加載測試數(shù)據(jù)(后面會給出代碼示例)。但是在測試的眼中,可能會配一個數(shù)據(jù)庫連接池類似這樣

@Bean(destroyMethod="close")
public DataSource dataSource () {
 BasicDataSource dataSource = new BasicDataSource();
 dataSource.setUrl("jdbc:h3:tcp://dbserver/~/test");
 dataSource.setDriverClassName("org.h3.Driver");
 dataSource.setUsername("sa");
 dataSource.setPassword("password");
 dataSource.setInitialSize(20);
 dataSource.setMaxActive(30);
 return dataSource; 
}

當(dāng)然還有產(chǎn)品環(huán)境下的配置等等。對于這種百花齊放的配置方式你還能說什么,默默的為這一套套的環(huán)境都部署相應(yīng)的配置文件啊,沒有profile這套我們一直都是這么做。

但是現(xiàn)在有了Profile,我們就多了一種選擇,一種更加智能省心的配置方式。通過Profile配置,Spring可以在根據(jù)環(huán)境在運行階段來決定bean的創(chuàng)建與否,先舉例如下,主要從Profile bean的配置和激活來展開。

Profile bean的配置

通過注解@Profile配置

對于上面比方中的第一種情況,在開發(fā)環(huán)境中我們配置一個數(shù)據(jù)源可能是這樣的

@Bean(destroyMethod = "shutdown")
public DataSource embeddedDataSource() {
 return new EmbeddedDatabaseBuilder()
 .addScript("classpath:schema.sql")
 .addScript("classpath:test-data.sql")
 .build();
 }

這里會使用EmbeddedDatabaseBuilder創(chuàng)建一個嵌入式數(shù)據(jù)庫,模式定義在類文件下的schema.sql文件中

schema.sql

create table Things (
 id identity,
 name varchar(100)
);

這里定義了一張Things表包含了兩個字段

除了模式文件,還需要通過test-data.sql加載測試數(shù)據(jù)

test-data.sql

insert into Things (name) values ('A')

對于這個@Bean完全不知道是放在開發(fā)的環(huán)境下創(chuàng)建還是產(chǎn)品的環(huán)境下。所以我們這里可以使用注解@Profile幫助我們?yōu)檫@個bean打上標(biāo)識。

從Spring 3.1版本中就引入了bean profile的功能,可以讓你將不同的bean定義到一個或者多個profile里,然后在部署應(yīng)用時告知要激活那個profile,則相應(yīng)的bean就會被創(chuàng)建。

比如這里

@Configuration
@Profile("dev")
public class DevelopmentProfileConfig {

 @Bean(destroyMethod = "shutdown")
 public DataSource embeddedDataSource() {
 return new EmbeddedDatabaseBuilder()
 .setType(EmbeddedDatabaseType.H2)
 .addScript("classpath:schema.sql")
 .addScript("classpath:test-data.sql")
 .build();
 }
}

通過@Profile("dev")為EmbedderDataSource bean標(biāo)記為dev環(huán)境下要創(chuàng)建的bean。

注意:1. @Profile被加載類級別上,如果dev profile沒有被激活,那么類中對應(yīng)的所有bean就不會被創(chuàng)建

         2. 如果當(dāng)前是dev環(huán)境被激活了,那么對于沒有使用@Profile的bean都會被創(chuàng)建,被標(biāo)記為其他的profile如prod,則不會創(chuàng)建相應(yīng)的bean

         3. 從3.2開始@Profile不僅僅可以加載類級別上,還可以加載方法上,具體代碼如下

package com.myapp;

import javax.sql.DataSource;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Profile;
import org.springframework.jdbc.datasource.embedded.EmbeddedDatabaseBuilder;
import org.springframework.jdbc.datasource.embedded.EmbeddedDatabaseType;
import org.springframework.jndi.JndiObjectFactoryBean;

@Configuration
public class DataSourceConfig {
 
 @Bean(destroyMethod = "shutdown")
 @Profile("dev")
 public DataSource embeddedDataSource() {
 return new EmbeddedDatabaseBuilder()
 .setType(EmbeddedDatabaseType.H2)
 .addScript("classpath:schema.sql")
 .addScript("classpath:test-data.sql")
 .build();
 }

 @Bean
 @Profile("prod")
 public DataSource jndiDataSource() {
 JndiObjectFactoryBean jndiObjectFactoryBean = new JndiObjectFactoryBean();
 jndiObjectFactoryBean.setJndiName("jdbc/myDS");
 jndiObjectFactoryBean.setResourceRef(true);
 jndiObjectFactoryBean.setProxyInterface(javax.sql.DataSource.class);
 return (DataSource) jndiObjectFactoryBean.getObject();
 }

}

通過xml配置文件配置

除了簡單的注解方式,我們哈可以通過在xml配置文件中聲明的方式,具體配置如下

datasource-config.xml

<&#63;xml version="1.0" encoding="UTF-8"&#63;>
<beans xmlns="http://www.springframework.org/schema/beans"
 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:jdbc="http://www.springframework.org/schema/jdbc"
 xmlns:jee="http://www.springframework.org/schema/jee" xmlns:p="http://www.springframework.org/schema/p"
 xsi:schemaLocation="
 http://www.springframework.org/schema/jee
 http://www.springframework.org/schema/jee/spring-jee.xsd
 http://www.springframework.org/schema/jdbc
 http://www.springframework.org/schema/jdbc/spring-jdbc.xsd
 http://www.springframework.org/schema/beans
 http://www.springframework.org/schema/beans/spring-beans.xsd">

 <beans profile="dev">
 <jdbc:embedded-database type="H2">
 <jdbc:script location="classpath:schema.sql" />
 <jdbc:script location="classpath:test-data.sql" />
 </jdbc:embedded-database>
 </beans>
 
 <beans profile="prod">
 <jee:jndi-lookup 
 lazy-init="true"
 jndi-name="jdbc/myDatabase"
 resource-ref="true"
 proxy-interface="javax.sql.DataSource" />
 </beans>
</beans>

這里分別聲明了兩種環(huán)境以及對應(yīng)的profile。

profile激活

雖然我們已經(jīng)配置好了profile,但是如何激活相應(yīng)的環(huán)境呢。這里我們需要兩個屬性spring.profile.active以及spring.profile.default

如果spring.profile.active被賦值了,則spring.profile.default就不會起作用,如果spring.profie.active沒有賦值,則使用默認(rèn)的spring.profile.default設(shè)置的值。當(dāng)然,如果兩者都沒有設(shè)置的話,則只會創(chuàng)建那些定義在相應(yīng)的profile中的bean。

設(shè)置這兩個屬性的方式有很多:

作為DispactcherServlet的初始化參數(shù)

作為Web應(yīng)用上下文參數(shù)

作為JNDI條目

作為環(huán)境變量

作為JVM的系統(tǒng)屬性

在集成測試類上,使用@ActiveProfiles注解設(shè)置

比如我們在web.xml中可以聲明代碼如下

<&#63;xml version="1.0" encoding="UTF-8"&#63;>
<web -app version="2.5"
...>

 //為上下文設(shè)置默認(rèn)的profile
 <context-param>
 <param-name>spring.profile.default</param-name>
 <param-value>dev</param-value>
 </context-param>

...

 <servlet>
 ...
 //為Serlvet設(shè)置默認(rèn)的profile
 <init-param>
  <param-name>spring-profiles.default</param-name>
  <param-value>dev</param-value>
 </init-prama>

...
<web-app>

這樣就可以指定需要啟動那種環(huán)境,并準(zhǔn)備相應(yīng)的bean。

另外對于測試,spring為什么提供了一個簡單的注解可以使用@ActiveProfiles,它可以指定運行測試的時候應(yīng)該要激活那個profile。比如這里的測試類DevDataSourceTest

package profiles;

import static org.junit.Assert.*;

import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.List;

import javax.sql.DataSource;

import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowMapper;
import org.springframework.test.context.ActiveProfiles;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;

import com.myapp.DataSourceConfig;

public class DataSourceConfigTest {

 @RunWith(SpringJUnit4ClassRunner.class)
 @ContextConfiguration(classes=DataSourceConfig.class)
 @ActiveProfiles("dev")
 public static class DevDataSourceTest {
 @Autowired
 private DataSource dataSource;
 
 @Test
 public void shouldBeEmbeddedDatasource() {
 assertNotNull(dataSource);
 JdbcTemplate jdbc = new JdbcTemplate(dataSource);
 List<String> results = jdbc.query("select id, name from Things", new RowMapper<String>() {
 @Override
 public String mapRow(ResultSet rs, int rowNum) throws SQLException {
  return rs.getLong("id") + ":" + rs.getString("name");
 }
 });
 
 assertEquals(1, results.size());
 assertEquals("1:A", results.get(0));
 }
 }

 @RunWith(SpringJUnit4ClassRunner.class)
 @ContextConfiguration(classes=DataSourceConfig.class)
 @ActiveProfiles("prod")
 public static class ProductionDataSourceTest {
 @Autowired
 private DataSource dataSource;
 
 @Test
 public void shouldBeEmbeddedDatasource() {
 // should be null, because there isn't a datasource configured in JNDI
 assertNull(dataSource);
 }
 }
 
 @RunWith(SpringJUnit4ClassRunner.class)
 @ContextConfiguration("classpath:datasource-config.xml")
 @ActiveProfiles("dev")
 public static class DevDataSourceTest_XMLConfig {
 @Autowired
 private DataSource dataSource;
 
 @Test
 public void shouldBeEmbeddedDatasource() {
 assertNotNull(dataSource);
 JdbcTemplate jdbc = new JdbcTemplate(dataSource);
 List<String> results = jdbc.query("select id, name from Things", new RowMapper<String>() {
 @Override
 public String mapRow(ResultSet rs, int rowNum) throws SQLException {
  return rs.getLong("id") + ":" + rs.getString("name");
 }
 });
 
 assertEquals(1, results.size());
 assertEquals("1:A", results.get(0));
 }
 }

 @RunWith(SpringJUnit4ClassRunner.class)
 @ContextConfiguration("classpath:datasource-config.xml")
 @ActiveProfiles("prod")
 public static class ProductionDataSourceTest_XMLConfig {
 @Autowired(required=false)
 private DataSource dataSource;
 
 @Test
 public void shouldBeEmbeddedDatasource() {
 // should be null, because there isn't a datasource configured in JNDI
 assertNull(dataSource);
 }
 }

}

運行shouldBeEmbeddedDatasource方法,測試通過

Spring項目中如何使用Profile

看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識有進(jìn)一步的了解或閱讀更多相關(guān)文章,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對創(chuàng)新互聯(lián)的支持。

網(wǎng)站標(biāo)題:Spring項目中如何使用Profile
URL地址:http://aaarwkj.com/article38/peidsp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站導(dǎo)航、微信小程序、標(biāo)簽優(yōu)化、App開發(fā)域名注冊、靜態(tài)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

小程序開發(fā)
老熟妇奂伦一区二区三区| 精品国产无遮挡污污网站| 国产精品福利手机在线观看| 粉嫩av蜜臀一区二区三区| 中文字幕亚洲入口久久| 人人妻人人澡人人爽人人dvd| 狼人综合狼人综合网站| 黄色成人av在线网站| 亚洲av激情码国产一区| 亚洲免费观看视频一区二区三区| 亚洲av毛片在线免费播放| 日本不卡一区二区视频| 日韩欧美亚洲另类激情一区| 亚洲人妻av一区二区| 一区二区三区日韩国产电影| 欧美一区二区三区精美| 欧美日韩午夜福利视频| 婷婷中文字幕在线视频| 国产一级二级三级亚洲| 日本又色又爽又黄又高潮| 91精品人妻互换一区二区| 白浆视频在线免费观看| 日日骚国产欧美一区二区| 好吊毛片一区二区三区| 91精品国产在线观看| 最新日本人妻中文字幕| 色男人天堂亚洲男人天堂| 蜜桃免费观看在线视频| 日韩av大片一区二区三区| 亚洲高清成人在线观看| 成人免费激情在线观看| 色婷婷亚洲一区二区三区| 日韩精品熟妻人女亚洲一区| 精华国产一区二区三区| 日韩传媒在线观看视频| 欧美成人午夜福利在线视频| 日韩在线视频观看一区二区三区 | 91精品国内手机在线高清| 国产免费久久黄av片| 美女床上激情啪啪网页| 午夜福利视频在线观看|