您好,登錄后才能下訂單哦!
這篇文章主要介紹“Elasticsearch和MySQL之間的數據同步問題怎么解決”,在日常操作中,相信很多人在Elasticsearch和MySQL之間的數據同步問題怎么解決問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Elasticsearch和MySQL之間的數據同步問題怎么解決”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
Elasticsearch中的數據是來自于Mysql數據庫的,因此當數據庫中的數據進行增刪改后,Elasticsearch中的數據,索引也必須跟著做出改變。而對于管理服務(MySQL)和搜索服務(Elasticsearch)往往會在不同的微服務上。
可以通過微服務之間的同步調用來解決數據同步問題,雖然實現起來比較簡單,但是在搜索服務中引入管理服務時,業務的耦合度相對來說是比較高的。因此可以通過消息隊列的形式來異步通知管理服務的改變。這樣做的有優點是耦合度較低,但是依賴于消息隊列的耦合度。
首先在兩塊微服務中引入RabbitMQ的依賴:
引入依賴
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-amqp</artifactId> </dependency>
創建常量類,將交換機和隊列名稱設置為常量,使用時方便取名。
public class MqConstants { /** * 交換機名稱 */ public final static String HOTEL_EXCHANGE = "hotel.topic"; /** * 監聽新增和修改的隊列 */ public final static String HOTEL_INSERT_QUEUE = "hotel.insert.queue"; /** * 監聽刪除的隊列 */ public final static String HOTEL_DELETE_QUEUE = "hotel.delete.queue"; /** * 新增或修改的路由鍵 */ public final static String HOTEL_INSERT_KEY = "hotel.insert"; /** * 刪除的路由鍵 */ public final static String HOTEL_DELETE_KEY = "hotel.delete"; }
創建配置類,聲明交換機,并將路由鍵,隊列與交換機之間互相綁定:
@Configuration public class MqConfig { @Bean public TopicExchange topicExchange(){ return new TopicExchange(MqConstants.HOTEL_EXCHANGE,true,false); } @Bean public Queue insertQueue(){ return new Queue(MqConstants.HOTEL_INSERT_QUEUE,true); } @Bean public Queue deleteQueue(){ return new Queue(MqConstants.HOTEL_DELETE_QUEUE,true); } @Bean public Binding insertQueueBinding(){ return BindingBuilder.bind(insertQueue()).to(topicExchange()).with(MqConstants.HOTEL_INSERT_KEY); } @Bean public Binding deleteQueueBinding(){ return BindingBuilder.bind(deleteQueue()).to(topicExchange()).with(MqConstants.HOTEL_DELETE_KEY); } }
編寫controller層,將酒店數據保存到數據庫中,并將消息發送到消息隊列里:
@Autowired private IHotelService hotelService; @Autowired private RabbitTemplate rabbitTemplate; @PutMapping public void save(@RequestBody Hotel hotel){ hotelService.save(hotel); rabbitTemplate.convertAndSend(MqConstants.HOTEL_EXCHANGE,MqConstants.HOTEL_INSERT_KEY,hotel.getId()); } @DeleteMapping("/{id}") public void deleteById(@PathVariable("id") Long id){ hotelService.removeById(id); rabbitTemplate.convertAndSend(MqConstants.HOTEL_EXCHANGE,MqConstants.HOTEL_DELETE_KEY,id); }
在service中加入兩個方法,根據id增加和根據id刪除:
void insertById(Long id); void deleteById(Long id);
利用Ctrl+Alt+B的快捷鍵,在service的實現類里面重寫方法進行實現:
@Override public void insertById(Long id) { try { Hotel hotel = getById(id); HotelDoc hotelDoc = new HotelDoc(hotel); // 1.準備Request IndexRequest request = new IndexRequest("hotel").id(hotelDoc.getId().toString()); // 2.準備請求參數DSL,其實就是文檔的JSON字符串 request.source(JSON.toJSONString(hotelDoc), XContentType.JSON); // 3.發送請求 client.index(request, RequestOptions.DEFAULT); } catch (IOException e) { throw new RuntimeException(e); } } @Override public void deleteById(Long id) { try { DeleteRequest request = new DeleteRequest("hotel", id.toString()); // 2.發送請求 client.delete(request, RequestOptions.DEFAULT); } catch (IOException e) { throw new RuntimeException(e); } }
這樣即可完成Elasticsearch和MySQL之間的數據同步。
到此,關于“Elasticsearch和MySQL之間的數據同步問題怎么解決”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。