因為 rabbitmq 有重送機制或直到任務成功為止這功能,在任務未完成的時候可以送到依 server 能力 慢慢讓我們的 server 去消化這一大堆的 log,好吧開始。
引入rabbitmq依賴
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-amqp</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.amqp</groupId>
<artifactId>spring-rabbit-test</artifactId>
<scope>test</scope>
</dependency>
配置文件
provider,consumer,zuul 這些地方有想用 zipkin 的地方都要加上
eureka:
client:
serviceUrl:
defaultZone: http://localhost:8761/eureka/
spring:
application:
name: feign-consumer
zipkin:
base-url: http://192.168.0.146:9411
sender:
type: rabbit
rabbitmq:
addresses: 192.168.0.146:5672
password: test
username: test
queue: zipkin
feign:
hystrix:
enabled: true
server:
port: 9001
rabbitmq
https://x8795278.blogspot.com/2019/08/websocket-rabbitmq.html
上次玩到一半,這邊是安裝還要加上
上次玩到一半,這邊是安裝還要加上
sudo vim /etc/rabbitmq/rabbitmq.config
允許遠端訪問
[
{rabbit, [{tcp_listeners, [5672]}, {loopback_users, ["test"]}]}
].
sudo systemctl start rabbitmq-server
zipkin 啟動
java -jar zipkin.jar --zipkin.collector.rabbitmq.addresses=localhost
在執行可以先去消耗
也就是去觸發 我們的 provider
訊息會被 cache 在 我們的 rabbitmq
服務啟動後
然後springtool 好Lag我把它移到 vscode了
也就是去觸發 我們的 provider
訊息會被 cache 在 我們的 rabbitmq
服務啟動後
然後springtool 好Lag我把它移到 vscode了
還沒加其他數據每秒大概可以處理500次 反應時間136ms(吧?
http://localhost:9000/feign-consumer/hello/1/12?token=Bearer%20eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJleHAiOjE1Nzc3NzE5OTcsInVzZXJuYW1lIjoiamFjayJ9.-2DWFi3MbbuilGvl0B6jVnmb6TzIWQ_FbH0X2hF1XOU