主頁 > 資料庫 > 通過Python收集MySQL MHA 部署及運行狀態資訊的功能實作

通過Python收集MySQL MHA 部署及運行狀態資訊的功能實作

2021-10-11 12:45:24 資料庫

一. 背景介紹 

當集團的MySQL資料庫實體數達到2000+、MHA集群規模數百個時,對MHA的及時、高效管理是DBA必須面對的一個挑戰,MHA 集群 節點資訊 和 運行狀態 是管理的基礎,本篇幅主要介紹如何通過Python實作收集MHA 集群 節點資訊 和 運行狀態的功能,這些資訊將是CMDB資訊的重要組成部分,

MHA集群數百個,MHA Manager 節點 十幾個,一個MHA Manager 節點管理著50-60個集群, 我們希望開發的程式,只在這十幾個MHA Manager 節點部署運行,就可以收集到所需的所有 MHA Server 節點資訊、VIP 資訊、運行狀態資訊及其他資訊,并且將收集到的資料保存到MySQL 資料庫中,

二.實作邏輯 

 2.1 程式呼叫的MHA工具程式或檔案

 

工具程式或檔案  功能 
 mha_appxxx.cnf 組態檔

1.從這個檔案中 提取 Server 資訊(Server IP);

2.提取 FailOver Script 和 Online Change Script的檔案,  

 appxxx_master_ip_failover 腳本檔案  提取定義的VIP,和其他處收集到的VIP,進行橫向比較,防止配置出錯,
 appxxx_master_ip_online_change 腳本檔案  提取定義的VIP,橫向比較防止配置出錯,
 masterha_check_repl 工具程式

1.檢查MySQL復制狀況;

2.決議當前主節點IP;

3.決議 slave 節點IP;

4.決議出VIP,

masterha_check_status

檢測當前MHA運行狀態(運行OK還是stop),

 為便于理解,我們貼上 mha_appxxx.cnf 的內容,

[server default]
manager_workdir=/var/log/masterha/app1.log              //設定manager的作業目錄
manager_log=/var/log/masterha/app1/manager.log          //設定manager的日志
master_binlog_dir=/data/mysql                         //設定master 保存binlog的位置,以便MHA可以找到master的日志,我這里的也就是mysql的資料目錄
master_ip_failover_script= /usr/local/bin/appxxx_master_ip_failover    //設定自動failover時候的切換腳本
master_ip_online_change_script= /usr/local/bin/appxxx_master_ip_online_change  //設定手動切換時候的切換腳本
password=用戶密碼         //設定mysql中root用戶的密碼,這個密碼是前文中創建監控用戶的那個密碼
user=root               設定監控用戶root
ping_interval=1         //設定監控主庫,發送ping包的時間間隔,默認是3秒,嘗試三次沒有回應的時候自動進行railover
remote_workdir=/tmp     //設定遠端mysql在發生切換時binlog的保存位置
repl_password=用戶密碼    //設定復制用戶的密碼
repl_user=repl          //設定復制環境中的復制用戶名
report_script=/usr/local/send_report    //設定發生切換后發送的報警的腳本          
shutdown_script=""      //設定故障發生后關閉故障主機腳本(該腳本的主要作用是關閉主機放在發生腦裂,這里沒有使用)
ssh_user=root           //設定ssh的登錄用戶名

[server1]
hostname=110.110.110.50
port=3306

[server2]
hostname=110.110.110.60
port=3306
candidate_master=1   //設定為候選master,如果設定該引數以后,發生主從切換以后將會將此從庫提升為主庫,即使這個主庫不是集群中事件最新的slave
check_repl_delay=0   //默認情況下如果一個slave落后master 100M的relay logs的話,MHA將不會選擇該slave作為一個新的master,因為對于這個slave的恢復需要花費很長時間,通過設定check_repl_delay=0,MHA觸發切換在選擇一個新的master的時候將會忽略復制延時,這個引數對于設定了candidate_master=1的主機非常有用,因為這個候選主在切換的程序中一定是新的master

[server3]
hostname=110.110.110.70
port=3306

 2.程式簡單的流程圖

 

 因是簡單流程圖,其中判斷及例外未在圖中標明,

三.主要代碼實作

3.1.創建保存收集資訊的表

表命名為mysqldb_mha_info,其create 腳本如下:

create table `mysqldb_mha_info` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
   mha_manager_ip varchar(50) NOT NULL DEFAULT '' COMMENT 'MHA管理節點所在集群的IP',
   mha_name varchar(50) NOT NULL DEFAULT '' COMMENT 'MHA的名字,類似于副本集',
   mha_file_name varchar(250) NOT NULL DEFAULT '' COMMENT 'MHA .cnf 組態檔名字',
   mha_name_path varchar(250) NOT NULL DEFAULT '' COMMENT 'MHA .cnf 組態檔路徑和名字',
  `cnf_server1_ip` varchar(50) NOT NULL DEFAULT '' COMMENT 'MHA cnf 組態檔中的節點1',
  `cnf_server2_ip` varchar(50) NOT NULL DEFAULT '' COMMENT 'MHA cnf 組態檔中的節點2',
  `cnf_server3_ip` varchar(50) NOT NULL DEFAULT '' COMMENT 'MHA cnf 組態檔中的節點3',
   failover_script varchar(250) NOT NULL DEFAULT '' COMMENT 'MHA failover scripts的檔案',
   failover_script_vip varchar(50) NOT NULL DEFAULT '' COMMENT 'MHA failover scripts 中定義的VIP',
   online_script varchar(250) NOT NULL DEFAULT '' COMMENT 'MHA online change scripts的檔案',
   online_script_vip varchar(50) NOT NULL DEFAULT '' COMMENT 'MHA online change scripts 中定義的VIP',
   script_remark varchar(1500) NOT NULL DEFAULT '' COMMENT 'MHA scripts VIP 檢查結果',
   masterha_status varchar(10) NOT NULL DEFAULT '' COMMENT 'MHA 檢查是否開啟,來自于 masterha_check_status 檢查結果',
   master_serverip varchar(50) NOT NULL DEFAULT '' COMMENT 'MHA 檢查是否開啟,來自于 masterha_check_status 檢查結果',
  `current_master_ip` varchar(50) NOT NULL DEFAULT '' COMMENT 'MHA 當前主節點,來自check_repl',
  `mha_current_vip` varchar(50) NOT NULL DEFAULT '' COMMENT 'MHA 當前VIP ,來自check_repl',
 `slave1_ip` varchar(50) NOT NULL DEFAULT '' COMMENT 'MHA 當前從節點1,來自check_repl',
  `slave2_ip` varchar(50) NOT NULL DEFAULT '' COMMENT 'MHA 當前從節點2 ,來自check_repl',
  mha_cnf_remark varchar(1500) NOT NULL DEFAULT '' COMMENT 'MHA check conf/cnf 檢查結果',
  check_repl_remark varchar(1500) NOT NULL DEFAULT '' COMMENT 'MHA check repl檢查結果',
  remark varchar(1500) NOT NULL DEFAULT '' COMMENT 'MHA 檢查結果',
  `creator` varchar(50) NOT NULL DEFAULT '',
  `create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  `operator` varchar(50) NOT NULL DEFAULT '',
  `modify_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
 PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4

2. 連接DB的模塊 

模塊命名為db_conn.py,在此模塊中,使用 mysql-connector替代了MySQLdb,安裝更加簡便,

#!/usr/bin/python3
# -*- coding: UTF-8 -*-

##import MySQLdb 安裝模塊麻煩
import mysql.connector
db = mysql.connector.connect(user='nideuid', password='nidepwd',host='nideseverip',database='DBname',port=XXXX)

 3.功能實作模塊

檔案為collect_mysqldbmha_info.py,其代碼如下:

#!/usr/bin/python
# -*- coding: UTF-8 -*-

import os
import io
import re
import ConfigParser
import socket

import db_conn
mysqldb = db_conn.db
cursor = mysqldb.cursor()

## 第1部分 獲取本機IP
try:
  s=socket.socket(socket.AF_INET,socket.SOCK_DGRAM)
  s.connect(('8.8.8.8',80))
  mha_manager_ip=s.getsockname()[0]
  print('mha manager 所在主機的IP如下:')
  print(mha_manager_ip)
finally:
  s.close()
###

##第2部分: 回圈遍歷mha cnf 所在的檔案夾,取出 cnf 進行判斷和檢查
Path='/date/funcation/python/mha_conf'
#fout=open('輸出檔案名','w')
for Name in os.listdir(Path) :
  Pathname= os.path.join(Path,Name)
 ## print(Pathname)
 ## print(Name)
  mha_name = Name.replace(".cnf", "").replace(".conf", "") ###為MHA集群啟個名字
  ##print(mha_name)
  ##注意此處為r,不能為w,否則報錯:IOError: File not open for reading
  with open(Pathname,'r') as f:
    filecontent=f.read()
    #print(filecontent)
    remark = ''
    ####調整為ConfigParser,注意python2 和 python 的模塊名字是不一樣的.ConfigParser與configparser
    config =ConfigParser.ConfigParser()
    try:
      config.read(Pathname)
      server_item = config.sections()
      ##print(server_item)
      ### start 獲取 MHA 切換時的scripts 檔案名字
      mha_failover_script = ''
      mha_online_change_script =''
      mha_cnf_remark =''
      if 'server default' in server_item:
        mha_failover_script = config.get('server default','master_ip_failover_script')
        ###
        mha_failover_script=mha_failover_script.replace(" --ssh_user=root", "")
        ##print(mha_failover_script)
      else:
        mha_cnf_remark = mha_cnf_remark + 'mha_failover_script 未配置;'
      if 'server default' in server_item:
        mha_online_change_script = config.get('server default','master_ip_online_change_script')
        ##print(mha_online_change_script)
      else:
        mha_cnf_remark = mha_cnf_remark + 'mha_online_change_script 未配置;'
      ###1.1 end  獲取結束
      ##1.2 start 獲取MHA組態檔中的節點資訊
      server1_host = ''  ##MHA cnf 組態檔中的節點1
      server2_host = ''  ##MHA cnf 組態檔中的節點2
      server3_host = ''  ##MHA cnf 組態檔中的節點3
      if 'server1' in server_item:
        server1_host = config.get('server1','hostname')
        print(server1_host)
      else:
         server1_host = ''
         mha_cnf_remark = mha_cnf_remark + 'Server1未配置;'
         print(server1_host)
      if 'server2' in server_item:
        server2_host = config.get('server2','hostname')
        print(server2_host)
      else:
        server2_host = ''
        mha_cnf_remark = mha_cnf_remark + 'Server2未配置;'
        print(server2_host)
      if 'server3' in server_item:
        server3_host = config.get('server3','hostname')
        print(server3_host)
      ##else:
        ##server3_host = ''
        ##mha_cnf_remark = mha_cnf_remark + 'Server3未配置;'
        ##print(server3_host)
      ##1.2 獲取server節點資訊結束
      print(mha_cnf_remark)
    except Exception as e:
      print(e)

    #####第3部分 start 從 mha scripts 中提取 配置的VIP
    mha_remark = ''
    mha_failover_my_vip = ''
    mha_failover_flush_vip = ''
    mha_onlinechange_my_vip = ''
    mha_onlinechange_flush_vip =''
    if len(mha_failover_script) <> 0 and len(mha_online_change_script) <> 0 :
      ##3.1 先來處置 failover_script,決議其中的VIP
      with open(mha_failover_script,'r') as f:
        failscript_lines=f.readlines()
        for failscript_line in failscript_lines:
          failscript_ip=re.findall(r"\b(?:(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\b", failscript_line)
          if failscript_ip:
            if 'my $vip =' in failscript_line:
              mha_failover_my_vip = failscript_ip[0]
              print('決議出mha_failover_my_vip:')
              print(mha_failover_my_vip)
            if  'my $ssh_flush_vip' in failscript_line:
              mha_failover_flush_vip = failscript_ip[0]
              print('決議出mha_failover_flush_vip:')
              print(mha_failover_flush_vip)

        ##檔案讀取完畢,對讀取結果進行判斷,判斷兩種情況
        ## 一種是否未定義
        if mha_failover_my_vip =='':
          mha_remark = mha_remark + 'MHA failover  未提取到VIP的設定,請檢查;'
        ## 另外一種,,定義了,但是值不相等
        if mha_failover_my_vip <> mha_failover_flush_vip:
          mha_remark = mha_remark + 'MHA failover scripts檔案中設定的兩處VIP不一致,請檢查;'

      ## 3.2 處理online change scripts ,決議提取其中的VIP資訊
      with open(mha_online_change_script,'r') as f:
        onlinescript_lines=f.readlines()
        for onlinescript_line in onlinescript_lines:
          onlinescript_ip=re.findall(r"\b(?:(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\b", onlinescript_line)
          if onlinescript_ip:
            if 'my $vip =' in onlinescript_line:
              mha_onlinechange_my_vip = onlinescript_ip[0]
              print('決議出mha_onlinechange_my_vip:')
              print(mha_onlinechange_my_vip)
            if  'my $ssh_flush_vip' in onlinescript_line:
              mha_onlinechange_flush_vip = onlinescript_ip[0]
              print('決議出mha_onlinechange_flush_vip:')
              print(mha_onlinechange_flush_vip)
        #### online change 檔案讀完了,判斷定義的VIP是否符合要求
        if mha_onlinechange_my_vip =='':
          mha_remark = mha_remark + 'MHA online change scripts未提取到VIP的設定,請檢查;'
        if mha_onlinechange_my_vip <> mha_onlinechange_flush_vip:
          mha_remark = mha_remark + 'MHA online change scripts檔案中設定的兩處VIP不一致,請檢查;'

      #### 兩個檔案都讀取了,判斷兩個檔案中定義的VIP是否一致
      if mha_onlinechange_my_vip <> mha_failover_my_vip:
        mha_remark = mha_remark + 'MHA online change script  和 failover script 中的VIP不一致,請檢查,'

    else:
      mha_remark = mha_remark + 'MHA init 的組態檔未正確定義切換的scripts,請檢查,'
      #print('MHA init 的組態檔未正確定義 切換的scripts,請檢查,')
      print(mha_remark)
    #####第2部分 end 從 mha scripts 中提取 配置的VIP

    #### 第4部分,從masterha_check_status執行結果中判斷mha行程狀態
    ## 從 執行masterha_check_status結果中決議出的  masterha_status 和 master_serverip 的資料
    masterha_status =''
    master_serverip =''
    ## 從 執行masterha_check_repl結果中決議出的 current_master 、current_slave1、current_slave2 和 mha_current_vip 的資料
    current_master = ''
    current_slave1 = ''
    current_slave2 = ''
    mha_current_vip =''
    ##判斷下檔案是否是MHA的組態檔,判斷方式就是檔案中 必須有 server default\server1的sections
    if 'server default' in server_item and 'server1' in server_item :
      ##cmd_mha_status ='/usr/local/bin/masterha_check_status --conf=/etc/mha/opszabbix.cnf'
      cmd_mha_status ='/usr/local/bin/masterha_check_status --conf='+Pathname
      try:
        mha_status=os.popen(cmd_mha_status)
        mha_status_result = mha_status.read()
        print(mha_status_result)  ##回傳樣式為 XXXX (pid:------) is running(0:PING_OK), master:XXX.XXX.XXX.XXX
        ### 判斷狀態是否為運行中
        if 'running(0:PING_OK)' in mha_status_result:
          masterha_status='Running'
          ##抓取MHA的Master 節點
          ##master_serverip = mha_status_result[mha_status_result.rfind('master:'):]
          master_serverip = mha_status_result.split('master:')[1]
          print(master_serverip)
          print('MHA啟動運行正常')
        elif 'stopped(2:NOT_RUNNING)' in mha_status_result:
          masterha_status='stopped'
          print('MHA未啟動!!!')
      finally:
         if mha_status:
            mha_status.close()
      #### 第5部分,從masterha_check_repl的執行結果中,判斷決議 主、從節點、VIP節點
      ##  判斷 副本集 的狀況
      cmd_repl_status ='/usr/local/bin/masterha_check_repl --conf='+Pathname
      try:
        ##### 添加 2> error 引數,不需要列印出除錯資訊,
        cmd_repl_status_result = cmd_repl_status + '     2> checkrepl.log'
        repl_status=os.popen(cmd_repl_status_result)
        repl_status_result = repl_status.read()
        ##print(repl_status_result)
        if 'MySQL Replication Health is OK' in repl_status_result:
          print('MHA集群的主從正常')
          ###獲取ServerIP
          #######除錯資訊是輸出到2號流中的,所以一定 添加 2>&1,否則抓取不到節點資訊,只能抓到一個VIP,
          cmd_repl_status_info = cmd_repl_status + '     2>&1'
          with os.popen(cmd_repl_status_info,'r') as repl_status_check2:
            #repl_status_lines=repl_status_check2.readlines()
            repl_status_lines=repl_status_check2.readlines()
            ##print(len(repl_status_lines))  ####列印出list的元素個數
            for repl_status_line in repl_status_lines:
              ##print('##################  start   ###########################')
              ##print(str(repl_status_line).replace("\n", "").replace("\t", ""))
              ##repl_status_line ='Current Alive Master: 10.200.58.63(10.200.58.63:55988)'
              serverip_result=re.findall(r"\b(?:(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\b", repl_status_line)
              if serverip_result:
                if 'Current Alive Master:' in repl_status_line:
                  current_master = serverip_result[0]
                  print('已決議到主節點IP')
                  print(current_master)
                elif 'Checking replication health on' in repl_status_line and current_slave1 == '':   ###有可能有2個從節點,此處為第1個從節點
                  current_slave1 = serverip_result[0]
                  print('已決議到從節點1')
                  print(current_slave1)
                elif 'Checking replication health on' in repl_status_line and current_slave1 <> '':  ###有可能有2個從節點,此處為第2個從節點
                  current_slave2 = serverip_result[0]
                  print('已決議到從節點2')
                  print(current_slave2)
                elif 'Checking replication health on' in repl_status_line and current_slave1 <> '':  ###有可能有2個從節點,此處為第2個從節點
                  print('集群有3個或更多的從節點,請確認,')
                if 'down==/sbin/ifconfig ' in repl_status_line:
                  mha_current_vip = serverip_result[0]
                  print('已決議到MHA集群的VIP')
                  print(mha_current_vip)

                ##print('包含serverip')
                ##print(serverip_result)
              #else:
                #print('不包含ServerIP')
            ##else:
              ##print(repl_status_line)
              ##print('##################  end   ###########################')
          ####獲取IP部分結束
        else:
          print('MHA集群的主從例外,請及時檢查')

      finally:
         if repl_status:
            repl_status.close()

    else:
       remark = Pathname + '...... 不是MHA的組態檔,請檢查!'
       print(remark)


    ##### 第6部分,將資料保存到表中
    sql_insert = "insert into mysqldb_mha_info(mha_manager_ip,mha_name,mha_file_name,mha_name_path,cnf_server1_ip,cnf_server2_ip,cnf_server3_ip,failover_script,failover_script_vip,online_script,online_script_vip,masterha_status,master_serverip,current_master_ip,mha_current_vip,slave1_ip,slave2_ip,mha_cnf_remark,script_remark,remark) " \
                      "values('%s','%s','%s','%s','%s','%s','%s','%s','%s','%s','%s','%s','%s','%s','%s','%s','%s','%s','%s','%s')" % \
                      (mha_manager_ip,mha_name,Name,Pathname,server1_host,server2_host,server3_host,mha_failover_script,mha_failover_my_vip,mha_online_change_script,mha_onlinechange_my_vip,masterha_status,current_master,master_serverip,mha_current_vip,current_slave1,current_slave2,mha_cnf_remark,mha_remark,remark)
    ##print(sql_insert)
    cursor.execute(sql_insert)
    mysqldb.commit()

    #####


# 關閉游標
cursor.close()
# 關閉資料庫連接
mysqldb.close()

 4.代碼運行

Python 運行環境為:Python 2.7.5

執行命令:

python /data/XXXX路徑/collect_mysqldbmha_info.py

定期收集,請根據需要設定cron.

 

轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/308478.html

標籤:MySQL

上一篇:資料采集實戰(四)-- 線性代數習題答案下載

下一篇:MySQL高性能索引策略和查詢性能優化

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • GPU虛擬機創建時間深度優化

    **?桔妹導讀:**GPU虛擬機實體創建速度慢是公有云面臨的普遍問題,由于通常情況下創建虛擬機屬于低頻操作而未引起業界的重視,實際生產中還是存在對GPU實體創建時間有苛刻要求的業務場景。本文將介紹滴滴云在解決該問題時的思路、方法、并展示最終的優化成果。 從公有云服務商那里購買過虛擬主機的資深用戶,一 ......

    uj5u.com 2020-09-10 06:09:13 more
  • 可編程網卡芯片在滴滴云網路的應用實踐

    **?桔妹導讀:**隨著云規模不斷擴大以及業務層面對延遲、帶寬的要求越來越高,采用DPDK 加速網路報文處理的方式在橫向縱向擴展都出現了局限性。可編程芯片成為業界熱點。本文主要講述了可編程網卡芯片在滴滴云網路中的應用實踐,遇到的問題、帶來的收益以及開源社區貢獻。 #1. 資料中心面臨的問題 隨著滴滴 ......

    uj5u.com 2020-09-10 06:10:21 more
  • 滴滴資料通道服務演進之路

    **?桔妹導讀:**滴滴資料通道引擎承載著全公司的資料同步,為下游實時和離線場景提供了必不可少的源資料。隨著任務量的不斷增加,資料通道的整體架構也隨之發生改變。本文介紹了滴滴資料通道的發展歷程,遇到的問題以及今后的規劃。 #1. 背景 資料,對于任何一家互聯網公司來說都是非常重要的資產,公司的大資料 ......

    uj5u.com 2020-09-10 06:11:05 more
  • 滴滴AI Labs斬獲國際機器翻譯大賽中譯英方向世界第三

    **桔妹導讀:**深耕人工智能領域,致力于探索AI讓出行更美好的滴滴AI Labs再次斬獲國際大獎,這次獲獎的專案是什么呢?一起來看看詳細報道吧! 近日,由國際計算語言學協會ACL(The Association for Computational Linguistics)舉辦的世界最具影響力的機器 ......

    uj5u.com 2020-09-10 06:11:29 more
  • MPP (Massively Parallel Processing)大規模并行處理

    1、什么是mpp? MPP (Massively Parallel Processing),即大規模并行處理,在資料庫非共享集群中,每個節點都有獨立的磁盤存盤系統和記憶體系統,業務資料根據資料庫模型和應用特點劃分到各個節點上,每臺資料節點通過專用網路或者商業通用網路互相連接,彼此協同計算,作為整體提供 ......

    uj5u.com 2020-09-10 06:11:41 more
  • 滴滴資料倉庫指標體系建設實踐

    **桔妹導讀:**指標體系是什么?如何使用OSM模型和AARRR模型搭建指標體系?如何統一流程、規范化、工具化管理指標體系?本文會對建設的方法論結合滴滴資料指標體系建設實踐進行解答分析。 #1. 什么是指標體系 ##1.1 指標體系定義 指標體系是將零散單點的具有相互聯系的指標,系統化的組織起來,通 ......

    uj5u.com 2020-09-10 06:12:52 more
  • 單表千萬行資料庫 LIKE 搜索優化手記

    我們經常在資料庫中使用 LIKE 運算子來完成對資料的模糊搜索,LIKE 運算子用于在 WHERE 子句中搜索列中的指定模式。 如果需要查找客戶表中所有姓氏是“張”的資料,可以使用下面的 SQL 陳述句: SELECT * FROM Customer WHERE Name LIKE '張%' 如果需要 ......

    uj5u.com 2020-09-10 06:13:25 more
  • 滴滴Ceph分布式存盤系統優化之鎖優化

    **桔妹導讀:**Ceph是國際知名的開源分布式存盤系統,在工業界和學術界都有著重要的影響。Ceph的架構和演算法設計發表在國際系統領域頂級會議OSDI、SOSP、SC等上。Ceph社區得到Red Hat、SUSE、Intel等大公司的大力支持。Ceph是國際云計算領域應用最廣泛的開源分布式存盤系統, ......

    uj5u.com 2020-09-10 06:14:51 more
  • es~通過ElasticsearchTemplate進行聚合~嵌套聚合

    之前寫過《es~通過ElasticsearchTemplate進行聚合操作》的文章,這一次主要寫一個嵌套的聚合,例如先對sex集合,再對desc聚合,最后再對age求和,共三層嵌套。 Aggregations的部分特性類似于SQL語言中的group by,avg,sum等函式,Aggregation ......

    uj5u.com 2020-09-10 06:14:59 more
  • 爬蟲日志監控 -- Elastc Stack(ELK)部署

    傻瓜式部署,只需替換IP與用戶 導讀: 現ELK四大組件分別為:Elasticsearch(核心)、logstash(處理)、filebeat(采集)、kibana(可視化) 下載均在https://www.elastic.co/cn/downloads/下tar包,各組件版本最好一致,配合fdm會 ......

    uj5u.com 2020-09-10 06:15:05 more
最新发布
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:33:24 more
  • MySQL中binlog備份腳本分享

    關于MySQL的二進制日志(binlog),我們都知道二進制日志(binlog)非常重要,尤其當你需要point to point災難恢復的時侯,所以我們要對其進行備份。關于二進制日志(binlog)的備份,可以基于flush logs方式先切換binlog,然后拷貝&壓縮到到遠程服務器或本地服務器 ......

    uj5u.com 2023-04-20 08:28:06 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:27:27 more
  • 快取與資料庫雙寫一致性幾種策略分析

    本文將對幾種快取與資料庫保證資料一致性的使用方式進行分析。為保證高并發性能,以下分析場景不考慮執行的原子性及加鎖等強一致性要求的場景,僅追求最終一致性。 ......

    uj5u.com 2023-04-20 08:26:48 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:26:35 more
  • 云時代,MySQL到ClickHouse資料同步產品對比推薦

    ClickHouse 在執行分析查詢時的速度優勢很好的彌補了MySQL的不足,但是對于很多開發者和DBA來說,如何將MySQL穩定、高效、簡單的同步到 ClickHouse 卻很困難。本文對比了 NineData、MaterializeMySQL(ClickHouse自帶)、Bifrost 三款產品... ......

    uj5u.com 2023-04-20 08:26:29 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:25:13 more
  • Redis 報”OutOfDirectMemoryError“(堆外記憶體溢位)

    Redis 報錯“OutOfDirectMemoryError(堆外記憶體溢位) ”問題如下: 一、報錯資訊: 使用 Redis 的業務介面 ,產生 OutOfDirectMemoryError(堆外記憶體溢位),如圖: 格式化后的報錯資訊: { "timestamp": "2023-04-17 22: ......

    uj5u.com 2023-04-20 08:24:54 more
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:24:03 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:23:11 more