在前面的過程中,我們創建了4個project: "服務發現" 我們使用Eureka 作為服務發現組件,學習了 ,`Eureka Client`的使用。 Eureka Server 1. 加依賴 2. 加註解 3. 改配置 使用Sprint Boot 項目三部曲,我們可以快速添加一個新組件,並正常使用 ...
在前面的過程中,我們創建了4個project:
服務發現
我們使用Eureka 作為服務發現組件,學習了Eureka Server
,Eureka Client
的使用。
- Eureka Server
- 加依賴
<dependency> <groupId>org.springframework.cloud</groupId> <!--<artifactId>spring-cloud-netflix-eureka-server</artifactId>--> <artifactId>spring-cloud-starter-eureka-server</artifactId> <version>1.2.7.RELEASE</version> </dependency>
- 加註解
@SpringBootApplication @EnableEurekaServer public class DiscoveryApplication { public static void main(String[] args) { SpringApplication.run(DiscoveryApplication.class, args); } }
- 改配置
eureka: instance: hostname: server1 prefer-ip-address: false client: service-url: defaultZone: http://server2:8888/eureka/,http://server3:9999/eureka/
使用Sprint Boot 項目三部曲,我們可以快速添加一個新組件,並正常使用
- Nacos Server
這個我沒有在項目中實現,但是大家可以和Eureka一樣,三部曲搞定。
- 加依賴(因SC Alibaba即將畢業影響,會從Spring-Cloud家族依賴中移動到alibaba repository下,因此,大家在學習依賴的時候,一定要註意版本信息,github傳送門)
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
<version>0.9.0.RELEASE</version>
</dependency>
- 加註解
在早期版本中,我們需要添加@EnableDiscoveryClient
,但是在nacos 0.9之後,不需要我們顯示的添加註解了~,因此這步可以忽略。 - 改配置
spring:
cloud:
nacos:
discovery:
server-addr: localhost:8848 #前提是要啟動Nacos Server
metadata:
version: v1
# 指定namespace(profile)
#namespace: 404060ce-2e6c-4f72-8083-2beb4ca921ad
# 指定集群名稱
cluster-name: BJ
Nacos Server ,請大家自行搜索,可參考 Nacos Github
網關路由
- 加依賴(因為網關也需要註冊到
服務發現
上,因此它也是一個client,那麼需要引入spring-cloud-starter-netflix-eureka-client
)
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-zuul</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
</dependencies>
- 加註解
/**
* @SpringCloudApplication 是以下三個註解的組合註解
* @see SpringBootApplication // 標柱是Spring Boot 項目啟動
* @see EnableDiscoveryClient // 標柱為服務發現 client,引入Eureka依賴之後 等同於 @EnableEurekaClient
* @see EnableCircuitBreaker // 斷路器,後續我們會講解
*/
@SpringCloudApplication
@EnableZuulProxy //啟動網關代理服務
public class GatewayApplication {
public static void main(String[] args) {
SpringApplication.run(GatewayApplication.class, args);
}
}
- 改配置
zuul:
# ignored-services: '*' # 過濾所有請求,除了下麵routes中聲明過的服務
routes:
sponsor: #在路由中自定義服務路由名稱
path: /ad-sponsor/**
serviceId: mscx-ad-sponsor #微服務name
strip-prefix: false
search: #在路由中自定義服務路由名稱
path: /ad-search/**
serviceId: mscx-ad-search #微服務name
strip-prefix: false
prefix: /gateway/api
strip-prefix: true #不對 prefix: /gateway/api 設置的路徑進行截取,預設轉發會截取掉配置的首碼
具體的代碼,參考源代碼實現。
通用代碼庫
這個其實大家就可以當作是本項目內的工具類就行了,沒什麼特殊的需求。
廣告投放系統
該項目中,我們使用到的技術有:
- mysql 8
- Eureka client
- 代碼與資料庫的交互ORM
jpa
- flyway(資料庫版本管理工具)
後續我們要添加的技術
- Feign(微服務相互調用)
- Ribbon(調用的客戶端負載均衡)
- hystrix(服務容錯以及流控管理)
每一種技術都有一套完整的實現以及框架,想要深入學習的同學請自行索引,後期廣告系統結束之後,我會另起一個系列來和大家一起討論框架底層實現。