springboot开发应用程序 (spring boot怎么运行服务器)

springboot配置文件加载顺序,springboot集成web

1. 端口号

在主要独立应用程序中,主 HTTP 端口默认为 8080;我们可以轻松地将 Boot 配置为使用不同的端口:

server.port=8083

对于基于 YAML 的配置:

server:
    port: 8083

我们还可以通过编程方式自定义服务器端口:

@Component
public class CustomizationBean implements
  WebServerFactoryCustomizer<ConfigurableServletWebServerFactory> {
 
    @Override
    public void customize(ConfigurableServletWebServerFactory container) {
        container.setPort(8083);
    }
}

2. 上下文路径

默认情况下,上下文路径为“/”。如果这不理想并且您需要将其更改为类似 / app_name 的内容,以下是通过属性执行此操作的快速简单方法:

server.servlet.contextPath=/springbootapp

对于基于 YAML 的配置:

server:
    servlet:
        contextPath:/springbootapp

最后 – 更改也可以以编程方式完成:

@Component
public class CustomizationBean
  implements WebServerFactoryCustomizer<ConfigurableServletWebServerFactory> {
 
    @Override
    public void customize(ConfigurableServletWebServerFactorycontainer) {
        container.setContextPath("/springbootapp");
    }
}

3. 白标错误页面

如果你没有在配置中指定任何自定义实现,Spring Boot 会自动注册一个 BasicErrorController bean。

但是,当然可以配置此默认控制器:

public class MyCustomErrorController implements ErrorController {
 
    private static final String PATH = "/error";
    
    @GetMapping(value=PATH)
    public String error() {
        return "Error haven";
    }
}

4.自定义错误消息

默认情况下,Boot 提供 /error 映射,以合理的方式处理错误。如果要配置更具体的错误页面,可以很好地支持统一的Java DSL来自定义错误处理:

@Component
public class CustomizationBean
  implements WebServerFactoryCustomizer<ConfigurableServletWebServerFactory> {
 
    @Override
    public void customize(ConfigurableServletWebServerFactorycontainer) {        
        container.addErrorPages(new ErrorPage(HttpStatus.BAD_REQUEST, "/400"));
        container.addErrorPages(new ErrorPage("/errorHaven"));
    }
}

在这里,我们专门处理 了错误请求 以匹配 /400 路径,并处理所有其他路径以匹配公共路径。还有一个非常简单的 /errorHaven 实现:

@GetMapping("/errorHaven")
String errorHeaven() {
    return "You have reached the haven of errors!!!";
}

输出:

You have reached the haven of errors!!!

5. 以编程方式关闭启动应用程序

您可以在 SpringApplication 的帮助下以编程方式关闭 Boot 应用程序。这有一个静态 exit() 方法,它接受两个参数: ApplicationContext 和一个 ExitCodeGenerator

@Autowired
public void shutDown(ExecutorServiceExitCodeGenerator exitCodeGenerator) {
    SpringApplication.exit(applicationContext, exitCodeGenerator);
}

正是通过这个实用程序方法,我们可以关闭应用程序。

6. 配置日志记录级别

您可以在引导应用程序中轻松调整日志记录级别;从版本 1.2.0 开始,您可以在主属性文件中配置日志级别:

logging.level.org.springframework.web: DEBUG
logging.level.org.hibernate: ERROR

就像标准的Spring应用程序一样,您可以通过在类路径中添加自定义XML或属性文件并在pom中定义库来激活不同的日志记录系统,如 Logback log4j,log4j2 等。

7. 注册一个新的 Servlet

如果您在嵌入式服务器的帮助下部署应用程序,则可以通过在常规配置中将它们公开为bean来在boot应用程序中注册新的Servlet:

@Bean
public HelloWorldServlet helloWorld() {
    return new HelloWorldServlet();
}

或者,您可以使用 ServletRegistrationBean

@Bean
public SpringHelloServletRegistrationBean servletRegistrationBean() {
 
    SpringHelloServletRegistrationBean bean = new SpringHelloServletRegistrationBean(
      new SpringHelloWorldServlet(), "/springHelloWorld/*");
    bean.setLoadOnStartup(1);
    bean.addInitParameter("message", "SpringHelloWorldServlet special message");
    return bean;
}

8. 在Boot Application中配置 Jetty or Undertow

Spring Boot 启动器通常使用 Tomcat 作为默认的嵌入式服务器。如果需要更改 - 您可以排除Tomcat依赖项并改为包含Jetty或Undertow:

配置 Jetty

<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>
@Bean
public JettyEmbeddedServletContainerFactory  jettyEmbeddedServletContainerFactory() {
    JettyEmbeddedServletContainerFactory jettyContainer = 
      new JettyEmbeddedServletContainerFactory();
    jettyContainer.setPort(9000);
    jettyContainer.setContextPath("/springbootapp");
    return jettyContainer;
}

配置Undertow

<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-undertow</artifactId>
</dependency>
@Bean
public UndertowEmbeddedServletContainerFactory embeddedServletContainerFactory() {
    UndertowEmbeddedServletContainerFactory factory = 
      new UndertowEmbeddedServletContainerFactory();
    
    factory.addBuilderCustomizers(new UndertowBuilderCustomizer() {
        @Override
        public void customize(io.undertow.Undertow.Builder builder) {
            builder.addHttpListener(8080, "0.0.0.0");
        }
    });
    
    return factory;
}