您好,登錄后才能下訂單哦!
原創(chuàng)文章,歡迎轉載。轉載請注明:轉載自IT人故事會,謝謝!
原文鏈接地址:『高級篇』docker之調整微服務適應mesos(25)上次已經搭建了mesos的集群環(huán)境,這次看看如何把mesos運行在集群之上,首選需要考慮的問題服務的發(fā)現(xiàn),之前用docker-compose是如何在同一臺機器上做的,是不是通過link的名稱,link的前提就是需要在同一臺主機上,我們當時是在同一臺虛擬機上,通過link服務讓他們都運行起來,通過名字就可以互相的訪問,我們在代碼的配置上,也是通過名字讓他們彼此之間可以相互的訪問,但是現(xiàn)在的情況,我們有2臺slave,1臺master,我們運行其中任何一個配置的時候都有可能分配到slave中的一個,所以用docker自帶的link機制肯定是有問題的。源碼:https://github.com/limingios/msA-docker mesos分支
基于marathon-lb的發(fā)現(xiàn)機制,它需要給每個服務定義一個服務端口,注冊到marathon-lb上,我們通過訪問marathon-lb的時候,就會轉發(fā)到服務提供者的ip和端口,比較集中式的服務發(fā)現(xiàn),所有的服務都是通過marathon-lb,他們的區(qū)別就是端口不同。
既然服務的機制跟之前的不同的,我們的代碼肯定要做下調整。下面我就一起改下。
一種6個微服務。一個一個來吧。
message-thrift-python-service
對外提供的9090,它是服務內部的。因為它不需要訪問任何服務,不需要修改配置。
user-thrift-service
里面的mysql是公共組件不需要進行修改,它也不需要依賴任何服務,不需要修改配置。
里面的redis是公共組件不需要進行修改。
通過域名的方式來訪問,然后在每個slave機器上綁定一個host
server.name=user-edge-service
server.port=8082
thrift.user.ip=lb.idig88.com
#thrift.user.ip=127.0.0.1
thrift.user.port=10001
thrift.message.ip=lb.idig88.com
thrift.message.port=10002
#redis config
spring.redis.host=${redis.address}
#spring.redis.host=127.0.0.1
spring.redis.port=6379
spring.redis.password=liming
spring.redis.timeout=30000
user-edge-service-client
無配置文件不需要考慮。
修改配置文件
server.port=8081
#dubbo config
spring.dubbo.application.name=course-dubbo-service
spring.dubbo.registry.address=zookeeper://${zookeeper.address}:2181
#spring.dubbo.registry.address=zookeeper://127.0.0.1:2181
spring.dubbo.scan=com.idig8.course
user.edge.service.addr=lb.idig88.com:10003
zookeeper 和 mysql 公共組件不需要修改
#dubbo 配置
spring.dubbo.application.name=course-dubbo-service
spring.dubbo.registry.address=zookeeper://${zookeeper.address}:2181
#spring.dubbo.registry.address=zookeeper://127.0.0.1:2181
spring.dubbo.protocol.name=dubbo
spring.dubbo.protocol.port=20880
#spring.dubbo.protocol.host=127.0.0.1
spring.dubbo.scan=com.idig8.course
#數(shù)據(jù)源的配置
spring.datasource.url=jdbc:mysql://${mysql.address}:3306/db_course
#spring.datasource.url=jdbc:mysql://127.0.0.1:3306/db_course
spring.datasource.username=root
spring.datasource.password=root
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
thrift.user.ip=lb.idig88.com
#thrift.user.ip=127.0.0.1
thrift.user.port=10001
server:
port: 8080
spring:
application:
name: gateway-zuu
cloud:
gateway:
routes:
- id: course-edge-service
uri: http://lb.idig88.com:10004
predicates:
- Path=/course/**
- id: user-edge-service
uri: http://lb.idig88.com:10003
predicates:
- Path=/user/**
logging:
level:
org.springframework.cloud.gateway: debug
一共6個微服務,中間2個服務可以通過的是dubbo來控制的,服務注冊給zookeeper,調用者也可以通過zookeeper來獲取服務地址,我們就不需要關心服務發(fā)現(xiàn)的東西了,所以5個服務就夠了。
# 服務名稱=新端口/老端口
user-thrift-service=10001/7911
message-thrift-python-service=10002/9000
user.edge.service=10003/8082
course-edge-service=10004/8081
gayway-zuul-service=10005:
PS:代碼的微服務調整已經完畢,下一步連接mesos開始部署。
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經查實,將立刻刪除涉嫌侵權內容。