PXC5.7集群部署

来源:http://www.cnblogs.com/lizhi221/archive/2017/05/10/6834954.html
-Advertisement-
Play Games

PXC三節點安裝: node1:10.157.26.132 node2:10.157.26.133 node3:10.157.26.134 配置伺服器ssh登錄無密碼驗證 ssh-keygen實現三台主機之間相互免密鑰登錄,保證三台主機之間能ping通 1)在所有的主機上執行: # ssh-keyg ...


PXC三節點安裝: node1:10.157.26.132 node2:10.157.26.133 node3:10.157.26.134   配置伺服器ssh登錄無密碼驗證 ssh-keygen實現三台主機之間相互免密鑰登錄,保證三台主機之間能ping通 1)在所有的主機上執行: # ssh-keygen -t rsa 2)將所有機子上公鑰(id_rsa.pub)導到一個主機的/root/.ssh/authorized_keys文件中,然後將authorized_keys分別拷貝到所有主機上 cat /root/.ssh/id_rsa.pub >> /root/.ssh/authorized_keys ssh 10.157.26.133 cat /root/.ssh/id_rsa.pub >> /root/.ssh/authorized_keys ssh 10.157.26.134 cat /root/.ssh/id_rsa.pub >> /root/.ssh/authorized_keys scp /root/.ssh/authorized_keys 10.157.26.133:/root/.ssh/authorized_keys scp /root/.ssh/authorized_keys 10.157.26.134:/root/.ssh/authorized_keys 測試:ssh 10.157.26.133/10.157.26.134   安裝依賴包: yum install -y git scons gcc gcc-c++ openssl check cmake bison boost-devel asio-devel libaio-devel ncurses-devel readline-devel pam-devel socat 若socat無法用yum安裝,可下載源碼包安裝 wget http://www.dest-unreach.org/socat/download/socat-1.7.3.2.tar.gz tar zxvf socat-1.7.3.2.tar.gz cd socat-1.7.3.2 ./configure make && make install   1、將二進位包解壓,添加mysql賬號,做軟連接【三個節點都要操作】: wget https://www.percona.com/downloads/Percona-XtraDB-Cluster-LATEST/Percona-XtraDB-Cluster-5.7.17-29.20/binary/tarball/Percona-XtraDB-Cluster-5.7.17-rel13-29.20.3.Linux.x86_64.ssl101.tar.gz mkdir /opt/mysql cd /opt/mysql tar zxvf /data/src/Percona-XtraDB-Cluster-5.7.17-rel13-29.20.3.Linux.x86_64.ssl101.tar.gz cd /usr/local ln -s /opt/mysql/Percona-XtraDB-Cluster-5.7.17-rel13-29.20.3.Linux.x86_64.ssl101/ mysql groupadd mysql useradd -M -g mysql -s /sbin/nologin/ -d /usr/local/mysql mysql   2、新建文件夾請授權【三個節點都要操作】 : mkdir -p /data/mysql/mysql_3306/{data,logs,tmp} mkdir -p /data/mysql/mysql_3306/logs/binlog chown -R mysql:mysql /data/mysql/ chown -R mysql:mysql /usr/local/mysql   3、配置文件my.cnf 132的配置文件:      default_storage_engine=Innodb      #pxc      wsrep_provider = /usr/local/mysql/lib/libgalera_smm.so    #庫文件位置      wsrep_cluster_address = gcomm://10.157.26.132,10.157.26.133,10.157.26.134    #集群中所有節點的ip      wsrep_node_name = node132     #本節點的名字      wsrep_node_address = 10.157.26.132    #本節點的ip        wsrep_cluster_name = pxc_sampson    #集群名字      wsrep_sst_auth = sst:sampson     #sst模式需要的用戶名和密碼      wsrep_sst_method = xtrabackup-v2     #採用什麼方式複製數據。還支持mysqldump,rsync      wsrep_slave_threads = 2     # 開啟的複製線程數,建議cpu核數*2 ,解決apply_cb跟不上問題      pxc_strict_mode = ENFORCING     #pxc嚴厲模式,還有DISABLED、PERMISSIVE、MASTER可選      innodb_autoinc_lock_mode = 2     #自增鎖的優化      wsrep_provider_options = "debug=1;gcache.size=1G"      #打開調試模式 133的配置文件:      default_storage_engine=Innodb      #pxc      wsrep_provider = /usr/local/mysql/lib/libgalera_smm.so      wsrep_cluster_address = gcomm://10.157.26.132,10.157.26.133,10.157.26.134      wsrep_node_name = node133      wsrep_node_address = 10.157.26.133      wsrep_cluster_name = pxc_sampson      wsrep_sst_auth = sst:sampson      wsrep_sst_method = rsync      wsrep_slave_threads = 2      pxc_strict_mode = ENFORCING      innodb_autoinc_lock_mode = 2      wsrep_provider_options = "debug=1;gcache.size=1G" 134的配置文件:      default_storage_engine=Innodb      #pxc      wsrep_provider = /usr/local/mysql/lib/libgalera_smm.so      wsrep_cluster_address = gcomm://10.157.26.132,10.157.26.133,10.157.26.134      wsrep_node_name = node134      wsrep_node_address = 10.157.26.134           wsrep_cluster_name = pxc_sampson      wsrep_sst_auth = sst:sampson      wsrep_sst_method = rsync      wsrep_slave_threads = 2        pxc_strict_mode = ENFORCING      innodb_autoinc_lock_mode = 2      wsrep_provider_options = "debug=1;gcache.size=1G"   【註:本來所有節點的wsrep_sst_method均配置為xtrabackup-v2,但是添加第二個節點時報錯:WSREP_SST: [ERROR] Error while getting data from donor node: exit codes: 137 0,換成了rsync後,就沒有問題了,待驗證是否是xtrabackup的版本問題,我之前用的是2.4.7】 4、啟動節點1【132上執行】: /usr/local/mysql/bin/mysqld --defaults-file=/data/mysql/mysql_3306/my_3306.cnf --wsrep-new-cluster   【註:當node1啟動的時候,它會先嘗試加入一個已存在的集群,但是現在集群並不存在,pxc必須從0開始,所以node1的啟動必須加上命令--wsrep-new-cluster,用於新建一個新的集群。node1正常啟動之後,其他的node就可以使用平時的啟動方式,它們都會自動連接上primary node】   在error.log里看到 [Note] WSREP: Shifting JOINED -> SYNCED (TO: 7) [Note] WSREP: Waiting for SST/IST to complete. [Note] WSREP: New cluster view: global state: f71affa6-2b55-11e7-b8db-6afbe908670d:7, view# 1: Primary, number of nodes: 1, my index: 0, protocol version 3 則啟動成功,登錄mysql -S /tmp/mysql_3306.sock -p 節點一密碼在error.log中: [root@dpstcmsweb00 ~]# cat /data/mysql/mysql_3306/logs/error.log |grep password 2017-05-09T02:46:25.724852Z 1 [Note] A temporary password is generated for root@localhost: worQi;aYF9eQ 登錄進去後修改root密碼:mysql>set password=password('mysql');   主節點添加賬號: grant usage on *.* to 'pxc-monitor'@'%' identified by 'pxc-monitor'; grant all privileges on *.* to 'sst'@'%' identified by 'sampson';   5、啟動剩下的兩個節點【133/134上執行】 : /usr/local/mysql/bin/mysqld --defaults-file=/data/mysql/mysql_3306/my_3306.cnf & 查看對應的error.log,能看到 [Note] WSREP: Shifting JOINER -> JOINED (TO: 7) [Note] WSREP: Member 1.0 (node3307) synced with group. [Note] WSREP: Shifting JOINED -> SYNCED (TO: 7) [Note] WSREP: Synchronized with group, ready for connections 則表示node啟動並加入cluster集群成功。 啟動成功後,直接使用節點1上的賬號密碼登錄即可,這裡是mysql -uroot -pmysql 6、查看節點個數: "root@localhost:mysql_3306.sock  [(none)]>show global status like 'wsrep_cluster_size'; +--------------------+-------+ | Variable_name      | Value | +--------------------+-------+ | wsrep_cluster_size | 3     | +--------------------+-------+ 1 row in set (0.00 sec)   7、查看集群狀態 "root@localhost:mysql_3306.sock  [(none)]>show global status like 'wsrep%'; +------------------------------+----------------------------------------------------------+ | Variable_name                | Value                                                    | +------------------------------+----------------------------------------------------------+ | wsrep_local_state_uuid       | bed19806-3465-11e7-85af-731d83552ec6                     | | wsrep_protocol_version       | 7                                                        | | wsrep_last_committed         | 4                                                        | | wsrep_replicated             | 3                                                        | | wsrep_replicated_bytes       | 732                                                      | | wsrep_repl_keys              | 3                                                        | | wsrep_repl_keys_bytes        | 93                                                       | | wsrep_repl_data_bytes        | 447                                                      | | wsrep_repl_other_bytes       | 0                                                        | | wsrep_received               | 36                                                       | | wsrep_received_bytes         | 3494                                                     | | wsrep_local_commits          | 0                                                        | | wsrep_local_cert_failures    | 0                                                        | | wsrep_local_replays          | 0                                                        | | wsrep_local_send_queue       | 0                                                        | | wsrep_local_send_queue_max   | 1                                                        | | wsrep_local_send_queue_min   | 0                                                        | | wsrep_local_send_queue_avg   | 0.000000                                                 | | wsrep_local_recv_queue       | 0                                                        | | wsrep_local_recv_queue_max   | 2                                                        | | wsrep_local_recv_queue_min   | 0                                                        | | wsrep_local_recv_queue_avg   | 0.027778                                                 | | wsrep_local_cached_downto    | 2                                                        | | wsrep_flow_control_paused_ns | 0                                                        | | wsrep_flow_control_paused    | 0.000000                                                 | | wsrep_flow_control_sent      | 0                                                        | | wsrep_flow_control_recv      | 0                                                        | | wsrep_flow_control_interval  | [ 173, 173 ]                                             | | wsrep_flow_control_status    | OFF                                                      | | wsrep_cert_deps_distance     | 1.000000                                                 | | wsrep_apply_oooe             | 0.000000                                                 | | wsrep_apply_oool             | 0.000000                                                 | | wsrep_apply_window           | 1.000000                                                 | | wsrep_commit_oooe            | 0.000000                                                 | | wsrep_commit_oool            | 0.000000                                                 | | wsrep_commit_window          | 1.000000                                                 | | wsrep_local_state            | 4                                                        | | wsrep_local_state_comment    | Synced                                                   | | wsrep_cert_index_size        | 1                                                        | | wsrep_cert_bucket_count      | 22                                                       | | wsrep_gcache_pool_size       | 2932                                                     | | wsrep_causal_reads           | 0                                                        | | wsrep_cert_interval          | 0.000000                                                 | | wsrep_ist_receive_status     |                                                          | | wsrep_incoming_addresses     | 10.157.26.134:3306,10.157.26.132:3306,10.157.26.133:3306 | | wsrep_desync_count           | 0                                                        | | wsrep_evs_delayed            |                                                          | | wsrep_evs_evict_list         |                                                          | | wsrep_evs_repl_latency       | 0/0/0/0/0                                                | | wsrep_evs_state              | OPERATIONAL                                              | | wsrep_gcomm_uuid             | 5665b42e-3467-11e7-94ff-9e77d0294b5e                     | | wsrep_cluster_conf_id        | 17                                                       | | wsrep_cluster_size           | 3                                                        | | wsrep_cluster_state_uuid     | bed19806-3465-11e7-85af-731d83552ec6                     | | wsrep_cluster_status         | Primary                                                  | | wsrep_connected              | ON                                                       | | wsrep_local_bf_aborts        | 0                                                        | | wsrep_local_index            | 1                                                        | | wsrep_provider_name          | Galera                                                   | | wsrep_provider_vendor        | Codership Oy <[email protected]>                        | | wsrep_provider_version       | 3.20(r)                                                  | | wsrep_ready                  | ON                                                       | +------------------------------+----------------------------------------------------------+ 62 rows in set (0.00 sec)   註: wsrep_cluster_status: 1.OPEN: 節點啟動成功,嘗試連接到集群,如果失敗則根據配置退出或創建新的集群 2.PRIMARY: 節點處於集群pc中,嘗試從集群中選取donor進行數據同步 3.JOINER: 節點處於等待接收/接收數據文件狀態,數據傳輸完成後在本地載入數據 4.JOINED: 節點完成數據同步工作,嘗試保持和集群進度一致 5.SYNCED:節點正常提供服務:數據的讀寫,集群數據的同步,新加入節點的sst請求 6.DONOR(貢獻數據者):節點處於為新節點準備或傳輸集群全量數據狀態,對客戶端不可用。   PXC相關文檔將持續更新。。。
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1.將一個資料庫的表複製到另一個資料庫,複製表結構及數據; 前提:兩個資料庫在同一個伺服器 語法:SELECT * INTO db1.dbo.tb1 FROM db2.dbo.tb2 說明:db1--目標資料庫;tb1--目標表,且目標資料庫無此表;db2--源資料庫;tb2--源表(需複製的表) ...
  • --單表遞歸 由於項目中經常用到 , 隨筆以作下次使用 例如:找ProductType表 下ID為1的分類的所有子級 with result as --result為別名( select * from TB_ProductType where Id=1 --查詢ID為1 的數據 union all ...
  • 1。到apache官網下載Thrift源碼, http://thrift.apache.org/download,我這裡下載的是thrift-0.10.0 2。到apach官網下載thrift.exe, http://thrift.apache.org/download, 這裡下載的是thrift- ...
  • Redis分散式緩存安裝(單節點) Redis官網:http://redis.io 獨立緩存伺服器:IP:xxx.xxx.xxx.xxx 安裝環境:CentOS 6.6 Redis 版本:redis-3.0 (因為 Redis3.0 在集群和性能提升方面的特性,rc 版為正式版的候選版,請在安裝時去 ...
  • 這篇文章是我在網上找到的,感覺不錯就粘過來了,感謝原作者的辛勤總結。 原文鏈接:http://database.51cto.com/art/201407/445934.html 1.對查詢進行優化,要儘量避免全表掃描,首先應考慮在 where 及 order by 涉及的列上建立索引。 2.應儘量避 ...
  • R CMD BATCH 和 Rscript 使用前都要先添加環境變數 把 C:\Program Files\R\R-3.3.0\bin; 加到"系統變數"的Path 值的最開始 可以用 R CMD BATCH *.r 也可以用 Rscript *.r args0 args1 這個可以跟一定的參數 當 ...
  • 1、 官網下載mysql5.5 下載地址: http://dev.mysql.com/downloads/mysql/5.5.html#downloads 2、 安裝mysql5.5 註意,安裝之前,請關閉殺毒軟體。 (1) 打開下載的mysql-5.5.53-winx64.msi (2) 點擊下一 ...
  • " 1、靜態數據字典 " "1.1、實用靜態數據字典" "1.2、運用靜態數據字典" " 2、動態數據字典 " "2.1、實用動態性能視圖" "2.2、運用動態性能視圖" " 3、死鎖 " "3.1、定位死鎖" "3.2、解鎖方法" "3.3、強制刪除已連接用戶" " 4、總結 " 數據字典是 Or ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...