前面的《配置中心》和《服務(wù)注冊&服務(wù)提供者》這兩篇分別講解了配置中心和服務(wù)提供者,但是服務(wù)提供者使用的配置文件還是本地的,沒有使用配置中心的配置文件。今天看看如何實(shí)現(xiàn)服務(wù)提供者使用配置中心的配置文件。
創(chuàng)新互聯(lián)堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都網(wǎng)站設(shè)計、成都網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的貴溪網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
1、 新建項(xiàng)目sc-eureka-client-provider-config,項(xiàng)目對應(yīng)的pom.xml文件如下
4.0.0
spring-cloud
sc-eureka-client-provider-config
0.0.1-SNAPSHOT
jar
sc-eureka-client-provider-config
http://maven.apache.org
org.springframework.boot
spring-boot-starter-parent
2.0.4.RELEASE
org.springframework.cloud
spring-cloud-dependencies
Finchley.RELEASE
pom
import
UTF-8
1.8
1.8
org.springframework.cloud
spring-cloud-starter-netflix-eureka-client
org.springframework.boot
spring-boot-starter-web
org.apache.tomcat
tomcat-jdbc
com.zaxxer
HikariCP
MySQL
mysql-connector-java
org.mybatis
mybatis-spring
1.3.2
org.mybatis.spring.boot
mybatis-spring-boot-starter
1.3.2
org.springframework.cloud
spring-cloud-starter-config
備注:可以看到pom.xml中引入了spring-cloud-starter-config,這個引入在《如何獲取配置中心的配置》博文中說到。引入這個配置項(xiàng)說明只要在配置文件中做相應(yīng)的配置就可以獲取到配置中心的配置項(xiàng)。
2、 新建springboot啟動類型ProviderConfigApplication.java
package sc.provider.config;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
@EnableEurekaClient
@SpringBootApplication
@MapperScan(basePackages="sc.provider.config.dao")
public class ProviderConfigApplication {
public static void main(String[] args) {
SpringApplication.run(ProviderConfigApplication.class, args);
}
}
3、 新建配置文件bootstrap.yml
server:
port: 8500
eureka:
client:
serviceUrl:
defaultZone: http://localhost:5001/eureka/
spring:
application:
name: sc-eureka-client-provider-config
cloud:
config:
name: sc-eureka-client-provider-config
label: master # 配置文件所在分支
#uri: http://127.0.0.1:8100/ #配置服務(wù)中心
profile: dev # dev根據(jù)具體情況來修改
#profile: prd # dev根據(jù)具體情況來修改
discovery:
serviceId: sc-config-server #配置服務(wù)實(shí)例名稱
enabled: true #開啟配置服務(wù)發(fā)現(xiàn)
備注:配置文件用有如下配置項(xiàng)
該配置項(xiàng)將會作為配置中心config server的配置文件bootstrap.yml中的search-paths的一個占位符{application}的值
4、 其他項(xiàng)目文件如下圖
5、 修改配置中心sc-config-server的配置文件bootstrap.yml
#服務(wù)端口
server:
port: 8100
#服務(wù)注冊中心
eureka:
client:
registerWithEureka: true #是否將自己注冊到Eureka服務(wù)中,默認(rèn)為true
fetchRegistry: true #是否從Eureka中獲取注冊信息,默認(rèn)為true
serviceUrl:
defaultZone: http://localhost:5001/eureka/
instance:
prefer-ip-address: true #將自己的ip地址注冊到Eureka服務(wù)中
ipAddress: 127.0.0.1
spring:
application:
name: sc-config-server #服務(wù)名稱
cloud:
config:
label: master #配置文件所在的分支
server:
git:
#uri: https://gitee.com/hjj520/spring-cloud-2.x.git #服務(wù)的git倉庫地址
uri: https://gitee.com/hjj520/spring-cloud-2.x #服務(wù)的git倉庫地址
#git倉庫的用戶名
#username: huangjinjin
#git倉庫的密碼
#password: ********
#search-paths: /config-repos/sc-consumer-config #配置文件所在的目錄
#search-paths: /config-repos/sc-config-client
#search-paths: /config-repos/sc-eureka-client-provider-config
search-paths: /config-repos/{application}
6、 在git倉庫新建如下內(nèi)容,并提交到git倉庫中
applicaton-dev.yml和application-prd.yml的內(nèi)容是一樣的(dev代表開發(fā)環(huán)境,prd代表生產(chǎn)環(huán)境,實(shí)際項(xiàng)目中這兩個文件一定是不一樣的)
spring:
datasource:
driverClassName: com.mysql.jdbc.Driver
url: jdbc:mysql://localhost:3306/sc?serverTimezone=UTC&useUnicode=true&characterEncoding=UTF-8
username: root
password: root
type: com.zaxxer.hikari.HikariDataSource
hikari:
minimum-idle: 5
maximum-pool-size: 15
auto-commit: true
idle-timeout: 30000
pool-name: DatebookHikariCP
max-lifetime: 1800000
connection-timeout: 30000
connection-test-query: SELECT 1
7、 先分別啟動注冊中心sc-eureka-server和配置中心sc-config-server
8、 啟動sc-eureka-client-provider-config項(xiàng)目在控制臺可以看到如下輸出
說明項(xiàng)目已經(jīng)通過配置中心獲取git倉庫的配置文件,如果看到如下輸出說明啟動成功
9、 通過postman訪問相關(guān)restful接口驗(yàn)證是否能正常訪問
查詢:
http://127.0.0.1:8500/user/getUser/4
列表:
http://127.0.0.1:8500/user/listUser/
添加:
http://127.0.0.1:8500/user/addUser
更新:
http://127.0.0.1:8500/user/updateUser
刪除:
http://127.0.0.1:8500/user/deleteUser/7