MySQL中間件之ProxySQL(3):Admin管理介面

来源:https://www.cnblogs.com/f-ck-need-u/archive/2018/07/08/9281199.html
-Advertisement-
Play Games

1.ProxySQL的Admin管理介面 當ProxySQL啟動後,將監聽兩個埠: (1).admin管理介面,預設埠為6032。該埠用於查看、配置ProxySQL。 (2).接收SQL語句的介面,預設埠為6033,這個介面類似於MySQL的3306埠。 ProxySQL的admin管理接 ...


1.ProxySQL的Admin管理介面

當ProxySQL啟動後,將監聽兩個埠:

  • (1).admin管理介面,預設埠為6032。該埠用於查看、配置ProxySQL。
  • (2).接收SQL語句的介面,預設埠為6033,這個介面類似於MySQL的3306埠。

ProxySQL的admin管理介面是一個使用MySQL協議的介面,所以,可以直接使用mysql客戶端、navicat等工具去連接這個管理介面。

例如,使用mysql客戶端去連接ProxySQL的管理介面。下麵使用的是管理介面的預設用戶名和密碼admin:admin

mysql -uadmin -padmin -h127.0.0.1 -P6032 --prompt 'admin> '
mysql: [Warning] Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 30
Server version: 5.5.30 (ProxySQL Admin Module)

Copyright (c) 2000, 2018, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

admin> 

由於ProxySQL的配置全部保存在幾個自帶的庫中,所以通過管理介面,可以非常方便地通過發送一些SQL命令去修改ProxySQL的配置。ProxySQL會解析通過該介面發送的某些對ProxySQL有效的特定命令,並將其合理轉換後發送給內嵌的SQLite3資料庫引擎去運行。

例如,查看庫、庫中的表。

admin> show databases;
+-----+---------------+-------------------------------------+
| seq | name          | file                                |
+-----+---------------+-------------------------------------+
| 0   | main          |                                     |
| 2   | disk          | /var/lib/proxysql/proxysql.db       |
| 3   | stats         |                                     |
| 4   | monitor       |                                     |
| 5   | stats_history | /var/lib/proxysql/proxysql_stats.db |
+-----+---------------+-------------------------------------+

admin> show tables from disk;
+------------------------------------+
| tables                             |
+------------------------------------+
| global_variables                   |
| mysql_collations                   |
| mysql_group_replication_hostgroups |
| mysql_query_rules                  |
| mysql_query_rules_fast_routing     |
| mysql_replication_hostgroups       |
| mysql_servers                      |
| mysql_users                        |
| proxysql_servers                   |
| scheduler                          |
+------------------------------------+

請註意,SQLite3和MySQL使用的SQL語法有所不同,因此能在MySQL上正常運行的命令不一定能在SQLite3上運行。例如,儘管admin管理介面接收USE命令,但不會切換預設的schema,因為SQLite3不支持USE功能。
ProxySQL會儘量將MySQL語法自動調整為對應的SQLite3的語法,例如show databases;會轉換為SQLite3上等價的語句。

ProxySQL的配置幾乎都是通過管理介面來操作的,通過Admin管理介面,可以線上修改幾乎所有的配置並使其生效。只有兩個變數的配置是必須重啟ProxySQL才能生效的,它們是:mysql-threadsmysql-stacksize

2.和admin管理介面相關的變數

一般來說,admin介面基本不需要額外的配置,最有可能配置的是admin介面的管理員用戶名、密碼。

2.1 admin-admin_credentials

該變數控制的是admin管理介面的管理員賬戶。預設的管理員賬戶和密碼為admin:admin,但是這個預設的用戶只能在本地使用。如果想要遠程連接到ProxySQL,例如用windows上的navicat連接Linux上的ProxySQL管理介面,必須自定義一個管理員賬戶。

例如,添加一個myuser:myuser的用戶密碼對。

admin> select @@admin-admin_credentials;    # 當前用戶名和密碼
+---------------------------+
| @@admin-admin_credentials |
+---------------------------+
| admin:admin               |
+---------------------------+

admin> set admin-admin_credentials='admin:admin;myuser:myuser';

admin> select @@admin-admin_credentials;
+---------------------------+
| @@admin-admin_credentials |
+---------------------------+
| admin:admin;myuser:myuser |
+---------------------------+

admin> load admin variables to runtime;  # 使修改立即生效
admin> save admin variables to disk;     # 使修改永久保存到磁碟

修改後,就可以使用該用戶名和密碼連接管理介面。

mysql -umyuser -pmyuser -P6032 -h127.0.0.1 --prompt 'admin> '

所有的配置操作都是在修改main庫中對應的表。

select * from global_variables 
 where variable_name='admin-admin_credentials';
+-------------------------+---------------------------+
| variable_name           | variable_value            |
+-------------------------+---------------------------+
| admin-admin_credentials | admin:admin;myuser:myuser |
+-------------------------+---------------------------+

所以,前面的set語句和下麵的update語句是等價的:

update global_variables set variable_value='admin:admin;myuser:myuser'
 where variable_name='admin-admin_credentials';

必須要區分admin管理介面的用戶名和mysql_users中的用戶名。

  • admin管理介面的用戶是連接到管理介面(預設埠6032)上用來管理、配置ProxySQL的。
  • mysql_users表中的用戶名是應用程式連接ProxySQL(預設埠6033),以及ProxySQL連接後端MySQL Servers使用的用戶。它的作用是發送、路由SQL語句,類似於MySQL Server的3306埠。所以,這個表中的用戶必須已經在後端MySQL Server上存在且授權了。

目前ProxySQL的mysql_users中的用戶既負責ProxySQL前端,又負責ProxySQL後端的連接,(作者說)未來版本中可能會將這兩段連接的用戶系統分開,讓ProxySQL更加安全。

admin管理介面的用戶必須不能存在於mysql_users中,這是出於安全的考慮,防止通過admin管理介面用戶猜出mysql_users中的用戶。

2.2 admin-stats_credentials

該變數控制admin管理介面的普通用戶,這個變數中的用戶沒有超級管理員許可權,只能查看monitor庫和main庫中關於統計的數據,其它庫都是不可見的,且沒有任何寫許可權。

預設的普通用戶名和密碼為stats:stats

mysql> select @@admin-stats_credentials;
+---------------------------+
| @@admin-stats_credentials |
+---------------------------+
| stats:stats               |
+---------------------------+

mysql> set admin-stats_credentials='stats:stats;mystats:mystats';
[root@s1 ~]#  mysql -ustats -pstats -P6032 -h127.0.0.1 

mysql> show databases;
+-----+---------------+-------------------------------------+
| seq | name          | file                                |
+-----+---------------+-------------------------------------+
| 0   | main          |                                     |
| 2   | monitor       |                                     |
| 3   | stats_history | /var/lib/proxysql/proxysql_stats.db |
+-----+---------------+-------------------------------------+

mysql> show tables from main;
+--------------------------------------+
| tables                               |
+--------------------------------------+
| global_variables                     |
| stats_memory_metrics                 |
| stats_mysql_commands_counters        |
| stats_mysql_connection_pool          |
| stats_mysql_connection_pool_reset    |
| stats_mysql_global                   |
| stats_mysql_prepared_statements_info |
| stats_mysql_processlist              |
| stats_mysql_query_digest             |
| stats_mysql_query_digest_reset       |
| stats_mysql_query_rules              |
| stats_mysql_users                    |
| stats_proxysql_servers_checksums     |
| stats_proxysql_servers_metrics       |
| stats_proxysql_servers_status        |
+--------------------------------------+

同樣,這個變數中的用戶必須不能存在於mysql_users表中。

2.3 admin-mysql_ifaces

該變數指定admin介面的監聽地址,格式為分號分隔的hostname:port列表。預設監聽在0.0.0.0:6032

註意,允許使用UNIX的domain socket進行監聽,這樣本主機內的應用程式就可以直接被處理。

例如:

SET admin-mysql_ifaces='127.0.0.1:6032;/tmp/proxysql_admin.sock'

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

-Advertisement-
Play Games
更多相關文章
  • 網路上所有資料都說epoll是高併發、單線程、IO重疊服用的首選架構,比select和poll性能都要好,特別是在有大量不活躍連接的情況下。具體原理就不闡述了,下麵說說使用。 具有有三個函數: #include <sys/epoll.h> 1、int epoll_create ( int size ...
  • 配置過程最終結果是生成.config文件,我們想要對配置的目的有很清楚的瞭解,必須先對.config文件進行分析。通過cd命令切換到linux-2.6.22.6內核目錄,輸入vi .config 可以看到如下圖所示內容(截圖僅部分內容): 分析.config文件被什麼文件使用,為了簡便化我們以網卡D ...
  • 1.ProxySQL的線程 ProxySQL由多個模塊組成,是一個多線程的daemon類程式。每個模塊都有一個或多個線程去執行任務。 例如,以下是剛啟動ProxySQL時的進程情況,一個main進程,一個主線程,21個線程。 下麵是正常運行時使用的線程列表: 1.1 Main thread 這其實是 ...
  • 一、概述 在前面的文章中介紹過了redis的主從和哨兵兩種集群方案,redis從3.0版本開始引入了redis-cluster(集群)。可以說從主從-哨兵-集群可以看到redis的不斷完善;主從複製是最簡單的節點同步方案無法主從自動故障轉移。哨兵可以同時管理多個主從同步方案同時也可以處理主從自動故障 ...
  • 主要: DDL: Data Definition Language 數據定義語言 資料庫操作語句 創建庫 創建資料庫: create database dbname [charset 字元編碼] [collate 排序規則]; 如: 查詢庫 1) 查看所有可用的字元編碼: show charset; ...
  • 占座 ...
  • 1. 官網下載安裝 MongoDB https://www.mongodb.com/ 2. 環境變數設置 把 mongod.exe 所在路徑加入到環境變數的PATH, 我這裡安裝的路徑是 D:\db\MongoDB\Server\3.4\bin 3.註冊為windows服務 在cmd命令視窗下執行 ...
  • 今天使用ide連接線下MySQL報錯Can not connect to MySQL server. Too many connections,報錯很明確,與MySQL的連接數滿了。想想也是,每起一個服務都會創建MySQL連接池,占用不少的長連接。用ide查看了一下,原來最大連接數才151,看來有必 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...