資料庫中間件mycat安裝與使用

来源:https://www.cnblogs.com/SimonWu/archive/2018/09/30/9728429.html
-Advertisement-
Play Games

1.下載 2.安裝 3.配置schema.xml mycat就是把跨庫的資料庫表,彙集到schema(新庫)中,然後就可以join查詢了 4.配置server.xml 5.啟動mycat 6.查看mycat狀態 7.使用mysql客戶端連接mycat 然後就可以使用mysql語法查詢了 8. 兩個表 ...


1.下載

# wget http://dl.mycat.io/1.6-RELEASE/Mycat-server-1.6-RELEASE-20161028204710-linux.tar.gz

2.安裝

# tar -zxvf ~/Mycat-server-1.6-RELEASE-20161028204710-linux.tar.gz -C /usr/local

3.配置schema.xml

# cd /usr/local/mycat/conf
# vim schema.xml
<?xml version="1.0"?>
<!DOCTYPE mycat:schema SYSTEM "schema.dtd">
<mycat:schema xmlns:mycat="http://io.mycat/">
<!--schema 資料庫-->
<schema name="testMyCat" checkSQLschema="false" sqlMaxLimit="100">
<!--table 表名-->
<table name="order" type="global" dataNode="order" /> <table name="orderDetail" type="global" dataNode="orderDetail" /> <table name="commodity" type="global" dataNode="order" /> </schema>
<!---datanode數據節點,database對應各個datahost中的資料庫名,datahost用於配置資料庫伺服器地址->
<dataNode name="order" dataHost="host2" database="jxtest" /> <dataNode name="orderDetail" dataHost="host1" database="usercenter" /> <dataHost name="host1" maxCon="1000" minCon="10" balance="0" writeType="0" dbType="mysql" dbDriver="native" switchType="1" slaveThreshold="100"> <heartbeat>select user()</heartbeat> <writeHost host="hostM1" url="192.168.3.30:3306" user="root" password="Gaia@Works12345^&amp;*()" /> </dataHost> <dataHost name="host2" maxCon="1000" minCon="10" balance="0" writeType="0" dbType="mysql" dbDriver="native" switchType="1" slaveThreshold="100"> <heartbeat>select user()</heartbeat> <writeHost host="hostM2" url="192.168.3.62:4000" user="root" password="" /> </dataHost> </mycat:schema>

mycat就是把跨庫的資料庫表,彙集到schema(新庫)中,然後就可以join查詢了

4.配置server.xml

# vim server.xml       #然後找到user節點配置
<user name="root">
        <property name="password">123456</property>
        <property name="schemas">testMyCat</property>
    </user>
<!--user.name登陸用戶名,password登錄密碼,schemas該用戶可使用的資料庫名,testMayCat對應schema.xml文件中配置的schema-->

5.啟動mycat

# cd /usr/local/mycat/bin
# ./mycat start

6.查看mycat狀態

# ./mycat status
Mycat-server is running (29287).

7.使用mysql客戶端連接mycat

然後就可以使用mysql語法查詢了

8. 兩個表的join

/*!mycat:catlet=io.mycat.catlets.ShareJoin */
SELECT
*
FROM t_order t
INNER JOIN order_detail td ON t.orderId = td.orderId

9.三個表的join

/*!mycat:catlet=io.mycat.catlets.ShareJoin */
SELECT
*
FROM t_order t
INNER JOIN order_detail td ON t.orderId = td.orderId
INNER JOIN commodity c ON td.commodityId = c.id

可見,三個表的join,mycat是不支持的

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 大概是CSS3吧,出了一個叫CSS變數的東西,也叫自定義屬性,還是比較有用的東東,可以用JavaScript靈活控制,變數作用 我們來實現一個div跟隨滑鼠滾動的小東西用來說明如何自定義變數 HTML代碼如下: JavaScript代碼,我們來寫一段監聽,處理變數值 這樣就實現了我們想要的效果,當然 ...
  • 3d建築,3d消防,消防演習模擬,3d庫房,3d檔案室,3d密集架,webGL,threejs,3d機房,bim管理系統 ...
  • 不同公司和組織之間的測試效率迥異。在這個富交互和響應式處理隨處可見的時代,很多組織都使用敏捷的方式來開發應用,因此測試自動化也成為軟體項目的必備部分。測試自動化意味著使用軟體工具來反覆運行項目中的測試,併為回歸測試提供反饋。 端到端測試又簡稱E2E(End-To-End test)測試,它不同於單元 ...
  • 某些手機上 fixed 元素在頁面滾動時會消失,某些 IOS 設備上觸發不了點擊事件,IOS 設備上點擊事件有 300ms 延遲,IOS 設備上 fixed 元素在鍵盤彈起時位置會變幻不定,在彈窗上滑動時底部頁面也跟著動,兩年移動端前端開發,我TM都經歷了什麼 ...
  • N-blog 使用 Express + MongoDB 搭建多人博客 原文地址: https://github.com/nswbmw/N-blog 建議初學者,研究下整個項目。 這裡節選了一些內容為筆記 : nrm 是一個管理 npm 源的工具。用來切換官方 npm 源和國內的 npm 源(如: c ...
  • BFC 即為Block formatting context 的縮寫,BFC 主要用來將一個盒子設置為一個隔離的容器,不管盒子內部的元素具有什麼屬性,都不會影響到盒子的外面。 1、哪些元素能產生BFC 不是所有的元素都能產生BFC的,只有display 屬性為 block, list-item, t ...
  • 一、阻止刷新頁面 在表單中的提交按鈕<button></button>標簽改為<input type="button">或者在<button>中添加屬性 type="button" 二、阻止表單的預設提交 1、使用preventDefault() 2、使用return false; ...
  • 微服務是一種系統架構的設計風格,它主旨在於將一個原本獨立的系統,拆分成多個獨立運行的小型服務。不同服務之間通過Restful介面進行通訊協作。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...