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
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...