前言
項目中沒有使用nacos官方提供的方式使用SpringBoot的集成方式來進行集成,而是使用了Alibaba Spring Cloud的依賴包進行集成。 原因是因為官網(wǎng)提供的SpringBoot集成方式中,同時使用配置中心和服務發(fā)現(xiàn)功能,會使得服務發(fā)現(xiàn)功能配置的部分屬性沖突不生效。最直接的就是配置中心和服務發(fā)現(xiàn)功能不可以配置2個不同的namespace,會默認選擇使用配置中心中配置的namespace作為服務發(fā)現(xiàn)的namespace。
另外一點就是可以很好的和Spring的注解兼容,無需額外的注解。例如@NacosValue注解。
maven依賴
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
<version>2.2.5.RELEASE</version>
</dependency>
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config-server</artifactId>
<version>2.2.5.RELEASE</version>
</dependency>
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo-spring-boot-starter</artifactId>
<version>2.7.9</version>
</dependency>
Nacos配置中心
配置文件
新建bootstrap.properties文件,在配置文件中配置nacos的配置信息。
# ============== nacos-config ============== # spring.cloud.nacos.config.server-addr=127.0.0.1:8848 spring.cloud.nacos.config.username=nacos spring.cloud.nacos.config.password=nacos spring.cloud.nacos.config.namespace=config-dev spring.cloud.nacos.config.group=demeter
注意:由于spring cloud alibaba nacos config的加載機制問題,配置信息如果寫在了application-{env}.properties的配置文件中無法被解析。所以如果需要分多環(huán)境動態(tài)加載,可以寫在bootstrap-{env}.properties文件中。 啟動的時候配置active profiles+ 環(huán)境就可以正確讀取配置了
動態(tài)配置
新建配置
在名為config-dev的namespace中新建配置demeter-application-admin。
配置中的data-id就不再多說了,這個可以查看資料,網(wǎng)上有很多資料進行了詳細描述。 data-id參考如下:
- demeter-application-admin
- demeter-application-admin.properties
- demeter-application-admin-dev.properties
配置實體類
DemeterAdminProperties.class
@Data
@Accessors(chain = true)
@ConfigurationProperties(prefix = "demeter.admin")
public class DemeterAdminProperties implements Serializable {
private static final long serialVersionUID = 1563821704172888362L;
private String name;
private String description;
private String time;
}
使配置生效。 @EnableConfigurationProperties注解使DemeterAdminProperties可以被實例化,自動注入到其他組件中。
@Configuration
@ComponentScan(value = {
"org.demeter.application.admin",
})
@Import(value = {AutoRedisConfiguration.class})
@EnableConfigurationProperties({DemeterAdminProperties.class})
public class AdminWebConfig {
}
訪問結果
Controller
結果
Nacos服務發(fā)現(xiàn)
配置文件
# ============== nacos-discovery ============== # spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848 spring.cloud.nacos.discovery.username=nacos spring.cloud.nacos.discovery.password=nacos spring.cloud.nacos.discovery.namespace=discovery-dev spring.cloud.nacos.discovery.group=demeter
使配置生效
使用@EnableDiscoveryClient注解使配置文件能夠生效.
結果
以上就是SpringBoot項目接入Nacos的實現(xiàn)步驟的詳細內容,更多關于SpringBoot項目接入Nacos的資料,請關注W3Cschool其它相關文章!