Close

Spring Core - Understanding Profiles Interface

[Last Updated: Jan 31, 2026]

Profiles is a functional interface (since Spring 5.1) which is used to evaluate whether a given set of active profiles matches a profile expression. It is essentially the programmatic engine behind annotations like @Profile and methods like Environment#acceptsProfiles(...).

Source

Definition of Profiles

Version: 6.2.13
 package org.springframework.core.env;
 @FunctionalInterface
 public interface Profiles {
     boolean matches(Predicate<String> isProfileActive); 1
     static Profiles of(String... profileExpressions); 2
 }
1Test if this Profiles instance matches against the given predicate.
2Create a new Profiles instance that checks for matches against the given profile expressions.

Following expressions are supported when creating Profiles instance:

  • ! (A logical NOT of the profile name or compound expression)
  • & (A logical AND of the profile names or compound expressions)
  • | (A logical OR of the profile names or compound expressions)

Examples

Configuration

package com.logicbig.example;

import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;

@Configuration
@ComponentScan(basePackages = "com.logicbig.example")
public class AppConfig {
}

1) Using Profiles

package com.logicbig.example;

import org.springframework.core.env.Environment;
import org.springframework.core.env.Profiles;
import org.springframework.stereotype.Component;

import java.util.Arrays;

@Component
public class ProfileChecker {

    private final Environment env;

    public ProfileChecker(Environment env) {
        this.env = env;
    }

    public void checkProfiles() {
        System.out.println("Active profiles: " +
                                   Arrays.toString(env.getActiveProfiles()));

        // Create a Profiles object for the "dev" OR "staging" environment
        Profiles devOrStaging = Profiles.of("dev|staging");

        if (env.acceptsProfiles(devOrStaging)) {
            System.out.println("Running in a non-production environment "
                                       + "(dev or staging).");
        } else {
            System.out.println("Not running in dev or staging.");
        }

        // Example of a more complex expression: "dev & !cloud"
        Profiles devAndNotCloud = Profiles.of("dev & !cloud");
        System.out.println("dev & !cloud matched? " +
                                   env.acceptsProfiles(devAndNotCloud));
    }
}
package com.logicbig.example;

import org.springframework.context.annotation.AnnotationConfigApplicationContext;

public class ProfilesMain {
    public static void main(String[] args) {
        // Activate a typical development setup
        AnnotationConfigApplicationContext ctx =
                new AnnotationConfigApplicationContext();
        ctx.getEnvironment().setActiveProfiles("dev");
        ctx.register(AppConfig.class);
        ctx.refresh();

        try {
            ProfileChecker checker = ctx.getBean(ProfileChecker.class);
            checker.checkProfiles();
        } finally {
            ctx.close();
        }
    }
}

Output

Active profiles: [dev]
Running in a non-production environment (dev or staging).
dev & !cloud matched? true

2) Using Profiles in Java 8 Streams

package com.logicbig.example;

import org.springframework.core.env.Environment;
import org.springframework.core.env.Profiles;
import org.springframework.stereotype.Component;
import java.util.Arrays;
import java.util.List;
import java.util.stream.Collectors;

@Component
public class StreamProfileService {

    private final Environment env;

    public StreamProfileService(Environment env) {
        this.env = env;
    }

    public void processEnvironmentSpecificTasks() {
        List<String> requiredConfigs = Arrays.asList(
                "aws",
                "mongodb",
                "redis",
                "local-db",
                // demonstrate expression usage within stream
                "dev & !cloud"
        );

        List<String> activeConfigs =
                requiredConfigs.stream()
                               // Profiles.of returns the Profiles functional interface
                               // Environment.acceptsProfiles consumes it
                               .filter(expr -> env.acceptsProfiles(Profiles.of(expr)))
                               .collect(Collectors.toList());

        System.out.println("Active profiles (stream check): "
                                   + Arrays.toString(env.getActiveProfiles()));
        System.out.println("Active configurations for this environment: " +
                                   activeConfigs);
    }
}
package com.logicbig.example;

import org.springframework.context.annotation.AnnotationConfigApplicationContext;

public class ProfilesStreamsMain {
    public static void main(String[] args) {
        // Simulate an environment with multiple active profiles
        AnnotationConfigApplicationContext ctx =
                new AnnotationConfigApplicationContext();
        ctx.getEnvironment().setActiveProfiles("dev", "redis");
        ctx.register(AppConfig.class);
        ctx.refresh();

        try {
            StreamProfileService svc =
                    ctx.getBean(StreamProfileService.class);
            svc.processEnvironmentSpecificTasks();
        } finally {
            ctx.close();
        }
    }
}

Output

Active profiles (stream check): [dev, redis]
Active configurations for this environment: [redis, dev & !cloud]

Key takeaways

  • Use Profiles.of(...) to build a matcher from simple names or logical expressions.
  • Call Environment.acceptsProfiles(Profiles) to evaluate against the current active profiles.
  • Prefer this over manual string checks of Environment#getActiveProfiles() to leverage Spring's expression parsing and stay consistent with @Profile semantics.
  • Because Profiles is a functional interface, it fits naturally into APIs that accept lambdas and can be used with streams for concise filtering.

Example Project

Dependencies and Technologies Used:

  • spring-context 6.2.13 (Spring Context)
     Version Compatibility: 5.1.0.RELEASE - 6.2.13Version List
    ×

    Version compatibilities of spring-context with this example:

    • 5.1.0.RELEASE
    • 5.1.1.RELEASE
    • 5.1.2.RELEASE
    • 5.1.3.RELEASE
    • 5.1.4.RELEASE
    • 5.1.5.RELEASE
    • 5.1.6.RELEASE
    • 5.1.7.RELEASE
    • 5.1.8.RELEASE
    • 5.1.9.RELEASE
    • 5.1.10.RELEASE
    • 5.1.11.RELEASE
    • 5.1.12.RELEASE
    • 5.1.13.RELEASE
    • 5.1.14.RELEASE
    • 5.1.15.RELEASE
    • 5.1.16.RELEASE
    • 5.1.17.RELEASE
    • 5.1.18.RELEASE
    • 5.1.19.RELEASE
    • 5.1.20.RELEASE
    • 5.2.0.RELEASE
    • 5.2.1.RELEASE
    • 5.2.2.RELEASE
    • 5.2.3.RELEASE
    • 5.2.4.RELEASE
    • 5.2.5.RELEASE
    • 5.2.6.RELEASE
    • 5.2.7.RELEASE
    • 5.2.8.RELEASE
    • 5.2.9.RELEASE
    • 5.2.10.RELEASE
    • 5.2.11.RELEASE
    • 5.2.12.RELEASE
    • 5.2.13.RELEASE
    • 5.2.14.RELEASE
    • 5.2.15.RELEASE
    • 5.2.16.RELEASE
    • 5.2.17.RELEASE
    • 5.2.18.RELEASE
    • 5.2.19.RELEASE
    • 5.2.20.RELEASE
    • 5.2.21.RELEASE
    • 5.2.22.RELEASE
    • 5.2.23.RELEASE
    • 5.2.24.RELEASE
    • 5.2.25.RELEASE
    • 5.3.0
    • 5.3.1
    • 5.3.2
    • 5.3.3
    • 5.3.4
    • 5.3.5
    • 5.3.6
    • 5.3.7
    • 5.3.8
    • 5.3.9
    • 5.3.10
    • 5.3.11
    • 5.3.12
    • 5.3.13
    • 5.3.14
    • 5.3.15
    • 5.3.16
    • 5.3.17
    • 5.3.18
    • 5.3.19
    • 5.3.20
    • 5.3.21
    • 5.3.22
    • 5.3.23
    • 5.3.24
    • 5.3.25
    • 5.3.26
    • 5.3.27
    • 5.3.28
    • 5.3.29
    • 5.3.30
    • 5.3.31
    • 5.3.32
    • 5.3.33
    • 5.3.34
    • 5.3.35
    • 5.3.36
    • 5.3.37
    • 5.3.38
    • 5.3.39
    • Compatible Java Version: 17+
    • 6.0.0
    • 6.0.1
    • 6.0.2
    • 6.0.3
    • 6.0.4
    • 6.0.5
    • 6.0.6
    • 6.0.7
    • 6.0.8
    • 6.0.9
    • 6.0.10
    • 6.0.11
    • 6.0.12
    • 6.0.13
    • 6.0.14
    • 6.0.15
    • 6.0.16
    • 6.0.17
    • 6.0.18
    • 6.0.19
    • 6.0.20
    • 6.0.21
    • 6.0.22
    • 6.0.23
    • 6.1.0
    • 6.1.1
    • 6.1.2
    • 6.1.3
    • 6.1.4
    • 6.1.5
    • 6.1.6
    • 6.1.7
    • 6.1.8
    • 6.1.9
    • 6.1.10
    • 6.1.11
    • 6.1.12
    • 6.1.13
    • 6.1.14
    • 6.1.15
    • 6.1.16
    • 6.1.17
    • 6.1.18
    • 6.1.19
    • 6.1.20
    • 6.1.21
    • 6.2.0
    • 6.2.1
    • 6.2.2
    • 6.2.3
    • 6.2.4
    • 6.2.5
    • 6.2.6
    • 6.2.7
    • 6.2.8
    • 6.2.9
    • 6.2.10
    • 6.2.11
    • 6.2.12
    • 6.2.13

    Versions in green have been tested.

  • JDK 25
  • Maven 3.9.11

Spring Profiles Functional Interface Example Select All Download
  • spring-profiles-interface-example
    • src
      • main
        • java
          • com
            • logicbig
              • example
                • StreamProfileService.java

    See Also

    Join