- Spring Boot 教程
- Spring Boot - 首页
- Spring Boot - 简介
- Spring Boot - 快速入门
- Spring Boot - 引导
- Spring Tool Suite
- Spring Boot - Tomcat 部署
- Spring Boot - 构建系统
- Spring Boot - 代码结构
- Spring Bean 与依赖注入
- Spring Boot - 运行器
- Spring Boot - 启动器
- Spring Boot - 应用属性
- Spring Boot - 配置
- Spring Boot - 注解
- Spring Boot - 日志
- 构建 RESTful Web 服务
- Spring Boot - 异常处理
- Spring Boot - 拦截器
- Spring Boot - Servlet 过滤器
- Spring Boot - Tomcat 端口号
- Spring Boot - Rest 模板
- Spring Boot - 文件处理
- Spring Boot - 服务组件
- Spring Boot - Thymeleaf
- 使用 RESTful Web 服务
- Spring Boot - CORS 支持
- Spring Boot - 国际化
- Spring Boot - 定时任务
- Spring Boot - 启用 HTTPS
- Spring Boot - Eureka 服务器
- 使用 Eureka 注册服务
- 网关代理服务器和路由
- Spring Cloud 配置服务器
- Spring Cloud 配置客户端
- Spring Boot - Actuator
- Spring Boot - Admin 服务器
- Spring Boot - Admin 客户端
- Spring Boot - 启用 Swagger2
- Spring Boot - 使用 SpringDoc OpenAPI
- Spring Boot - 创建 Docker 镜像
- 追踪微服务日志
- Spring Boot - Flyway 数据库
- Spring Boot - 发送邮件
- Spring Boot - Hystrix
- Spring Boot - Web Socket
- Spring Boot - 批处理服务
- Spring Boot - Apache Kafka
- Spring Boot - Twilio
- Spring Boot - 单元测试用例
- Rest Controller 单元测试
- Spring Boot - 数据库处理
- 保护 Web 应用
- Spring Boot - 使用 JWT 的 OAuth2
- Spring Boot - Google Cloud Platform
- Spring Boot - Google OAuth2 登录
- Spring Boot 资源
- Spring Boot - 快速指南
- Spring Boot - 有用资源
- Spring Boot - 讨论
Spring Boot - 云配置服务器
Spring Cloud 配置服务器是一个集中式应用程序,用于管理所有与应用程序相关的配置属性。在本节中,您将详细了解如何创建 Spring Cloud 配置服务器。
创建 Spring Cloud 配置服务器
首先,从 Spring Initializer 页面下载 Spring Boot 项目,并选择 Spring Cloud Config Server 依赖项。请观察下面的屏幕截图:
现在,按照如下说明在您的构建配置文件中添加 Spring Cloud Config 服务器依赖项:
Maven 用户可以将以下依赖项添加到 pom.xml 文件中。
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-config-server</artifactId> </dependency>
Gradle 用户可以将以下依赖项添加到 build.gradle 文件中。
compile('org.springframework.cloud:spring-cloud-config-server')
现在,在您的主 Spring Boot 应用程序类文件中添加 `@EnableConfigServer` 注解。`@EnableConfigServer` 注解使您的 Spring Boot 应用程序充当配置服务器。
主 Spring Boot 应用程序类文件如下所示:
ConfigserverApplication.java
package com.tutorialspoint.configserver;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.config.server.EnableConfigServer;
@SpringBootApplication
@EnableConfigServer
public class ConfigserverApplication {
public static void main(String[] args) {
SpringApplication.run(ConfigserverApplication.class, args);
}
}
现在,将以下配置添加到您的 application.properties 文件中。请观察以下代码:
application.properties
server.port = 8888 spring.cloud.config.server.git.uri=file:///E:/Dev/config/
配置服务器运行在 Tomcat 端口 8888 上,应用程序配置属性从基于 Git 的本地文件系统搜索位置加载。
创建 Git 仓库
初始化 Git 仓库
转到 **E:/Dev/config/** 文件夹,并运行以下 git 命令将其初始化为 git 仓库。
git init
添加属性文件
现在,在 **E:/Dev/config/** 中,放置您的客户端应用程序 - application.properties 文件。例如,您的客户端应用程序名称为 **config-client**,然后将您的 application.properties 文件重命名为 **config-client.properties** 并将属性文件放置在 **E:/Dev/config/** 路径上。
config-client 属性文件的代码如下所示:
welcome.message = Welcome to Spring cloud config server
运行以下 git 命令来暂存所有更改。
E:\Dev\config> git add .
提交更改
运行以下 git 命令来提交更改。
E:\Dev\config> git commit -m "First Checkin"
验证更改
运行以下 git 命令来检查已提交的更改。
E:\Dev\config> git log
commit 8081e552232ca5b1af29cef56e6acc6e1a5bd2e3 (HEAD -> master)
Author: maheshparashar84 <mahesh.kumar@tutorialspoint.com>
Date: Thu Sep 12 11:38:28 2024 +0530
First Checkin
E:\Dev\config>
完整的构建配置文件如下所示:
Maven 用户可以使用以下 **pom.xml**:
pom.xml
<?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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>3.3.3</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.tutorialspoint</groupId>
<artifactId>configserver</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>configserver</name>
<description>Demo project for Spring Boot</description>
<url/>
<licenses>
<license/>
</licenses>
<developers>
<developer/>
</developers>
<scm>
<connection/>
<developerConnection/>
<tag/>
<url/>
</scm>
<properties>
<java.version>21</java.version>
<spring-cloud.version>2023.0.3</spring-cloud.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-config-server</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
Gradle 用户可以使用以下 build.gradle 文件:
build.gradle
<scope>import</scope>
</dependency>
</dependencies>
buildscript {
ext {
springBootVersion = '3.3.3'
}
repositories {
mavenCentral()
}
dependencies {
classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
}
}
apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'
group = 'com.tutorialspoint'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 21
repositories {
mavenCentral()
}
ext {
springCloudVersion = '2023.0.3'
}
dependencies {
compile('org.springframework.cloud:spring-cloud-config-server')
testCompile('org.springframework.boot:spring-boot-starter-test')
}
dependencyManagement {
imports {
mavenBom "org.springframework.cloud:spring-cloud-dependencies:${springCloudVersion}"
}
}
编译和执行
现在,创建一个可执行 JAR 文件,并使用以下 Maven 或 Gradle 命令运行 Spring Boot 应用程序:
对于 Maven,使用以下命令:
mvn clean install
“BUILD SUCCESS”后,您可以在 target 目录下找到 JAR 文件。
对于 Gradle,使用以下命令:
gradle clean build
“BUILD SUCCESSFUL”后,您可以在 build/libs 目录下找到 JAR 文件。
使用以下命令运行 JAR 文件:
java –jar <JARFILE>
现在,应用程序已在 Tomcat 端口 8888 上启动,如下所示:
. ____ _ __ _ _ /\\ / ___'_ __ _ _(_)_ __ __ _ \ \ \ \ ( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \ \\/ ___)| |_)| | | | | || (_| | ) ) ) ) ' |____| .__|_| |_|_| |_\__, | / / / / =========|_|==============|___/=/_/_/_/ [32m :: Spring Boot :: [39m [2m (v3.3.3)[0;39m [2m2024-09-12T11:42:15.720+05:30[0;39m [32m INFO[0;39m [35m13108[0;39m [2m---[0;39m [2m[ main][0;39m [2m[0;39m[36mc.t.c.ConfigserverApplication [0;39m [2m:[0;39m Starting ConfigserverApplication using Java 21.0.3 with PID 13108 (E:\Dev\configserver\target\classes started by Tutorialspoint in E:\Dev\configserver) [2m2024-09-12T11:42:15.724+05:30[0;39m [32m INFO[0;39m [35m13108[0;39m [2m---[0;39m [2m[ main][0;39m [2m[0;39m[36mc.t.c.ConfigserverApplication [0;39m [2m:[0;39m No active profile set, falling back to 1 default profile: "default" [2m2024-09-12T11:42:16.619+05:30[0;39m [32m INFO[0;39m [35m13108[0;39m [2m---[0;39m [2m[ main][0;39m [2m[0;39m[36mo.s.cloud.context.scope.GenericScope [0;39m [2m:[0;39m BeanFactory id=f7967b62-068c-32b4-9d6a-b8da96911a03 [2m2024-09-12T11:42:16.896+05:30[0;39m [32m INFO[0;39m [35m13108[0;39m [2m---[0;39m [2m[ main][0;39m [2m[0;39m[36mo.s.b.w.embedded.tomcat.TomcatWebServer [0;39m [2m:[0;39m Tomcat initialized with port 8888 (http) [2m2024-09-12T11:42:16.918+05:30[0;39m [32m INFO[0;39m [35m13108[0;39m [2m---[0;39m [2m[ main][0;39m [2m[0;39m[36mo.apache.catalina.core.StandardService [0;39m [2m:[0;39m Starting service [Tomcat] [2m2024-09-12T11:42:16.918+05:30[0;39m [32m INFO[0;39m [35m13108[0;39m [2m---[0;39m [2m[ main][0;39m [2m[0;39m[36mo.apache.catalina.core.StandardEngine [0;39m [2m:[0;39m Starting Servlet engine: [Apache Tomcat/10.1.28] [2m2024-09-12T11:42:16.978+05:30[0;39m [32m INFO[0;39m [35m13108[0;39m [2m---[0;39m [2m[ main][0;39m [2m[0;39m[36mo.a.c.c.C.[Tomcat].[localhost].[/] [0;39m [2m:[0;39m Initializing Spring embedded WebApplicationContext [2m2024-09-12T11:42:16.978+05:30[0;39m [32m INFO[0;39m [35m13108[0;39m [2m---[0;39m [2m[ main][0;39m [2m[0;39m[36mw.s.c.ServletWebServerApplicationContext[0;39m [2m:[0;39m Root WebApplicationContext: initialization completed in 1197 ms [2m2024-09-12T11:42:17.716+05:30[0;39m [32m INFO[0;39m [35m13108[0;39m [2m---[0;39m [2m[ main][0;39m [2m[0;39m[36mo.s.b.w.embedded.tomcat.TomcatWebServer [0;39m [2m:[0;39m Tomcat started on port 8888 (http) with context path '/' [2m2024-09-12T11:42:17.739+05:30[0;39m [32m INFO[0;39m [35m13108[0;39m [2m---[0;39m [2m[ main][0;39m [2m[0;39m[36mc.t.c.ConfigserverApplication [0;39m [2m:[0;39m Started ConfigserverApplication in 2.497 seconds (process running for 4.133) [2m2024-09-12T11:42:43.468+05:30[0;39m [32m INFO[0;39m [35m13108[0;39m [2m---[0;39m [2m[nio-8888-exec-1][0;39m [2m[0;39m[36mo.a.c.c.C.[Tomcat].[localhost].[/] [0;39m [2m:[0;39m Initializing Spring DispatcherServlet 'dispatcherServlet' [2m2024-09-12T11:42:43.468+05:30[0;39m [32m INFO[0;39m [35m13108[0;39m [2m---[0;39m [2m[nio-8888-exec-1][0;39m [2m[0;39m[36mo.s.web.servlet.DispatcherServlet [0;39m [2m:[0;39m Initializing Servlet 'dispatcherServlet' [2m2024-09-12T11:42:43.468+05:30[0;39m [32m INFO[0;39m [35m13108[0;39m [2m---[0;39m [2m[nio-8888-exec-1][0;39m [2m[0;39m[36mo.s.web.servlet.DispatcherServlet [0;39m [2m:[0;39m Completed initialization in 0 ms [2m2024-09-12T11:42:47.289+05:30[0;39m [33m WARN[0;39m [35m13108[0;39m [2m---[0;39m [2m[nio-8888-exec-1][0;39m [2m[0;39m[36m.c.s.e.MultipleJGitEnvironmentRepository[0;39m [2m:[0;39m Could not merge remote for master remote: null [2m2024-09-12T11:42:47.364+05:30[0;39m [32m INFO[0;39m [35m13108[0;39m [2m---[0;39m [2m[nio-8888-exec-1][0;39m [2m[0;39m[36mo.s.c.c.s.e.NativeEnvironmentRepository [0;39m [2m:[0;39m Adding property source: Config resource 'file [E:\Dev\config\config-client.properties]' via location 'file:/E:/Dev/config/'
现在,在您的 Web 浏览器上访问 URL **https://:8888/config-client/default/master**,您将看到您的 config-client 应用程序配置属性,如下所示。