Chris Beams bloggar om nya features från milestone-release nummer ett av kommande Spring Framework 3.1. I den första artikeln visar han ”Bean Definition Profiles”. Ett användningsområde för profiler är att kunna scopa in och ut komponenter beroende på om du exekverar din applikation i utvecklingsmiljön eller i produktionsmiljön. Han exemplifierar med klassikern att använda olika datakällor för utveckling och produktion:

<beans profile="dev">
    <jdbc:embedded-database id="dataSource">
        <jdbc:script
            location="classpath:com/bank/config/sql/schema.sql"/>
        <jdbc:script
            location="classpath:com/bank/config/sql/test-data.sql"/>
    </jdbc:embedded-database>
</beans>
<beans profile="production">
    <jee:jndi-lookup
        id="dataSource"
        jndi-name="java:comp/env/jdbc/datasource"/>
</beans>

Det finns olika sätt att aktivera dessa profiler – exempelvis via web.xml, direkt i javakoden eller som en system-property.

<servlet>
    <servlet-name>dispatcher</servlet-name>
    <servlet-class>
      org.springframework.web.servlet.DispatcherServlet
    </servlet-class>
    <init-param>
        <param-name>spring.profiles.active</param-name>
        <param-value>production</param-value>
    </init-param>
</servlet>
ctx.getEnvironment().setActiveProfiles("test");
-Dspring.profiles.active="active"

Den andra artikeln visar hur man snyggt kan använda profiler mha annoteringen @Profile och visar lite exempel javabaserad konfiguration via @Configuration.

Läsvärt!