Meta佛薩奇矩陣模式/MetaForce/系統開發/原始碼搭建方案/魔豹聯盟開發技術講解
工作使用場景
工作中需要透過CPU、記憶體生成資源利用率報表,可以透過Prometheus的API寫一個Python指令碼。
可透過API獲取資料,然後再進行資料排序、過濾、運算、聚合,最後寫入Mysql資料庫。
CPU峰值計算
取最近一週CPU數值,再排序取最高的值。
def get_cpu_average(self): """ CPU忙時平均值:取最近一週CPU資料,每一天的TOP20除以20得到忙時平均值; 再將一週得到的忙時平均值相加,再除以7,得到時間範圍內一週的忙時平均值。 :return: """ cpu_average = {} for t in range(len(self.time_list)): if t + 1 < len(self.time_list): start_time = self.time_list[t] end_time = self. time_list[t + 1] # print(start_time, end_time) # 拼接URL pre_url = server_ip + '/api/v1/query_range?query=' expr = '100 - (avg by(instance) (irate(node_cpu_seconds_total{mode="idle"}[5m])) * 100) ' \ '&start=%s&end=%s&step=300' % (start_time, end_time - 1) url = pre_url + expr # print(url) # 請求介面資料 data = json.loads(requests.post(url=url, headers=self.headers).content.decode('utf8', 'ignore')) for da in data.get('data').get('result'): # 迴圈拿到result資料 values = da.get('values') cpu_load = [float(v[1]) for v in values] # 迴圈拿到values裡面的所有值 ip = da.get('metric').get('instance') # 拿到instance裡面的ip ip = ip[:ip.index(':')] if ':' in ip else ip # 去除個別後面帶的埠號 # avg_cup_load = sum(sorted(cpu_load, reverse=True)[:20]) / 20 # 取top20% 再除以20%,得出top20%的平均值 # avg_cup_load = round(sum(sorted(cpu_load, reverse=True)[:round(len(cpu_load) * 0.2)]) / round(len(cpu_load) * 0.2), 2) # 倒序後取前面20%除以個數,得到前20%的平均值 avg_cup_load = sum(sorted(cpu_load, reverse=True)[:round(len(cpu_load) * 0.2)]) / round(len(cpu_load) * 0.2) # print(avg_cup_load) # 將計算後的資料以ip為key寫入字典 if cpu_average.get(ip): cpu_average[ip].append(avg_cup_load) else: cpu_average[ip] = [avg_cup_load] # 每日top20的平均值累加,共7天的再除以7 for k, v in cpu_average.items(): # cpu_average[k] = round(sum(v) / 7, 2) cpu_average[k] = sum(v) # print(cpu_average) return cpu_average cpu_average[ip] = [avg_cup_load] # 每日top20的平均值累加,共7天的再除以7 for k, v in cpu_average.items(): # cpu_average[k] = round(sum(v) / 7, 2) cpu_average[k] = sum(v) # print(cpu_average) return cpu_average cpu_average[ip] = [avg_cup_load] # 每日top20的平均值累加,共7天的再除以7 for k, v in cpu_average.items(): # cpu_average[k] = round(sum(v) / 7, 2) cpu_average[k] = sum(v) # print(cpu_average) return cpu_average
記憶體峰值計算
取7天記憶體數值,排序後取最高峰值
def get_mem_average(self): """ 記憶體忙時平均值:先取出7天的日期,根據多條連結迴圈取出每天資料,排序value取top20除以20,最終7天資料再除以7 :return: """ avg_mem_util = {} for t in range(len(self.time_list)): if t + 1 < len(self.time_list): start_time = self.time_list[t] end_time = self.time_list[t + 1] # 根據多條連結迴圈取出每天資料 pre_url = self.server_ip + '/api/v1/query_range?query=' # expr = '(node_memory_MemTotal_bytes - (node_memory_MemFree_bytes+node_memory_Buffers_bytes+node_memory_Cached_bytes )) / node_memory_MemTotal_bytes * 100&start=%s&end=%s&step=300' % (start_time, end_time) expr_MenTotal = 'node_memory_MemTotal_bytes&start=%s&end=%s&step=600' % (start_time, end_time - 1) expr_MemFree = 'node_memory_MemFree_bytes&start=%s&end=%s&step=600' % (start_time, end_time - 1) expr_Buffers = 'node_memory_Buffers_bytes&start=%s&end=%s&step=600' % (start_time, end_time - 1) expr_Cached = 'node_memory_Cached_bytes&start=%s&end=%s&step=600' % (start_time, end_time - 1) result = {} # 迴圈取出四個欄位 for ur in expr_MenTotal, expr_MemFree, expr_Buffers, expr_Cached: url = pre_url + ur data = json.loads(requests.post(url=url, headers=self.headers).content.decode('utf8', 'ignore')) ip_dict = {} # 迴圈單個欄位所有值 for da in data.get('data').get('result'): ip = da.get('metric').get('instance') ip = ip[:ip.index(':')] if ':' in ip else ip if ip_dict.get(ip): # print("重複ip:%s" % (ip)) continue values = da.get('values') # 將列表裡的值轉為字典方便計算 values_dict = {} for v in values: values_dict[str(v[0])] = v[1] # 標記ip存在 ip_dict[ip] = True # 建立列表追加字典 if result.get(ip): result[ip].append(values_dict) else: result[ip] = [values_dict] # print(result) for ip, values in result.items(): values_list = [] for k, v in values[0].items(): try: values_MenTotal = float(v) values_MemFree = float(values[1].get(k, 0)) if values[1] else 0 values_Buffers = float(values[2].get(k, 0)) if values[2] else 0 values_Cached = float(values[3].get(k, 0)) if values[3] else 0 if values_MemFree == 0.0 or values_Buffers == 0.0 or values_Cached == 0.0: continue value_calc = (values_MenTotal - (values_MemFree + values_Buffers + values_Cached)) / values_MenTotal * 100 if value_calc != float(0): values_list.append(value_calc) except Exception as e: print(values[0]) # logging.exception(e) continue # 排序value取top20除以20 # avg_mem = round(sum(sorted(values_list, reverse=True)[:round(len(values_list) * 0.2)]) / round(len(values_list) * 0.2), 2) try: avg_mem = sum(sorted(values_list, reverse=True)[:round(len(values_list) * 0.2)]) / round(len(values_list) * 0.2) except Exception as e: avg_mem = 0 logging.exception(e) if avg_mem_util.get(ip): avg_mem_util[ip].append(avg_mem) else: avg_mem_util[ip] = [avg_mem] # 最終7天資料再除以7 for k, v in avg_mem_util.items(): # avg_mem_util[k] = round(sum(v) / 7, 2) avg_mem_util[k] = sum(v) return avg_mem_util
匯出excel
將採集到的資料匯出excel
<pre class="hljs python" "="" style="overflow: auto; font-family: Menlo, Monaco, Consolas, "Courier New", monospace; font-size: 13px; padding: 0.5em; margin-top: 0px; margin-bottom: 10px; line-height: 1.42857; color: rgb(68, 68, 68); word-break: break-all; overflow-wrap: normal; background: rgb(240, 240, 240); border: 1px solid rgb(204, 204, 204); border-radius: 4px; max-width: ;">def export_excel(self, export): """ 將採集到的資料匯出excel :param export: 資料集合 :return: """ try: # 將字典列表轉換為DataFrame pf = pd.DataFrame(list(export)) # 指定欄位順序 order = ['ip', 'cpu_peak', 'cpu_average', 'mem_peak', 'mem_average', 'collector'] pf = pf[order] # 將列名替換為中文 columns_map = { 'ip': 'ip', 'cpu_peak': 'CPU峰值利用率', 'cpu_average': 'CPU忙時平均峰值利用率', 'mem_peak': '記憶體峰值利用率', 'mem_average': '記憶體忙時平均峰值利用率', 'collector': '來源地址' } pf.rename(columns=columns_map, inplace=True) # 指定生成的Excel表格名稱 writer_name = self.Host + '.xlsx' writer_name.replace(':18600', '') # print(writer_name) file_path = pd.ExcelWriter(writer_name.replace(':18600', '')) # 替換空單元格 pf.fillna(' ', inplace=True) # 輸出 pf.to_excel(file_path, encoding='utf-8', index=False) # 儲存表格 file_path.save() except Exception as e: print(e) logging.exception(e)
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/70016646/viewspace-2942109/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 魔豹聯盟Meta系統開發方案丨佛薩奇2.0系統開發技術講解
- Meta佛薩奇2.0開發原始碼搭建丨Meta魔豹聯盟系統開發原始碼技術開發原始碼
- about魔豹聯盟佛薩奇系統開發技術方案(原始碼)原始碼
- MetaForce魔豹聯盟佛薩奇2.0矩陣公排系統開發(開發方案及功能)矩陣
- 魔豹聯盟元宇宙佛薩奇系統開發技術原始碼搭建元宇宙原始碼
- Forsage/MetaForce/魔豹聯盟/Matic馬蹄鏈/佛薩奇2.0系統開發技術方案
- 佛薩奇開發2.0元宇宙魔豹聯盟系統開發技術講解方案元宇宙
- Forsage佛薩奇2.0魔豹聯盟系統技術開發分析(佛薩奇2.0原始碼版)原始碼
- meta魔豹聯盟2.0佛薩奇開發(Demo)案例
- 魔豹聯盟2.0Metaforce佛薩奇模式系統開發搭建(Solidity環境)詳解模式Solid
- 魔豹聯盟佛薩奇2.0矩陣公排系統開發方案及邏輯矩陣
- MetaForce/Forsage/魔豹聯盟馬蹄鏈佛薩奇2.0系統開發
- 闡述MetaForce原力元宇宙佛薩奇系統開發丨魔豹聯盟原始碼解析方案技術元宇宙原始碼
- Metaforce/Forsage/魔豹聯盟佛薩奇2.0公排矩陣系統開發詳細邏輯丨原始碼功能矩陣原始碼
- 魔豹聯盟佛薩奇2.0矩陣公排NFT系統開發原始碼(智慧合約)矩陣原始碼
- 魔豹聯盟Forsage佛薩奇2.0系統開發詳情(技術分析)
- 佛薩奇metaforce原始碼系統開發搭建原始碼
- 佛薩奇2.0(Meta force)矩陣系統開發原始碼矩陣原始碼
- 佛薩奇原始碼/互助矩陣/佛薩奇2.0聊天/系統開發技術原始碼矩陣
- Forsage/魔豹聯盟/MetaForce/Polygon馬蹄鏈Matic佛薩奇2.0系統開發方案設計丨原始碼案例Go原始碼
- Polygon馬蹄鏈Matic/Forsage/魔豹聯盟/Metaforce佛薩奇2.0系統開發案例丨技術分析Go
- 佛薩奇2.0聊天交友/系統開發技術/佛薩奇原始碼/互助矩陣原始碼矩陣
- 魔豹聯盟佛薩奇2.0開發邏輯demo
- MetaForce/Forsage/魔豹聯盟/Matic馬蹄鏈/佛薩奇2.0系統開發案例詳細丨成熟技術
- 佛薩奇Forsage運營版2.0系統開發技術丨佛薩奇2.0魔豹聯盟程式碼程式設計程式設計
- 魔豹聯盟/Forsage/MetaForce/Polygon馬蹄鏈Matic佛薩奇2.0系統開發詳細功能丨原始碼Go原始碼
- MetaForce佛薩奇系統開發合約技術搭建
- 佛薩奇原始碼|佛薩奇2.0合約|佛薩奇矩陣公排模式開發系統原始碼矩陣模式
- 佛薩奇合約/系統技術開發/佛薩奇分紅矩陣模式開發技術詳情矩陣模式
- MetaForce佛薩奇系統開發技術流程(成熟程式碼)佛薩奇2.0原始碼部署教程原始碼
- DAPP佛薩奇合約系統技術開發/原始碼/佛薩奇分紅矩陣開發詳情APP原始碼矩陣
- MetaForce佛薩奇系統原始碼開發搭建馬蹄鏈原始碼
- 佛薩奇系統開發(原始碼部署)丨META FORCE佛薩奇2.0系統開發技術詳細版本原始碼
- MetaForce佛薩奇系統2.0開發技術分析
- MetaForce佛薩奇系統開發馬蹄鏈方案搭建
- 佛薩奇3.0矩陣NFT模式系統開發方案分析矩陣模式
- Metaforce佛薩奇2.0開發詳細版丨Metaforce佛薩奇2.0系統開發(開發功能及原始碼)原始碼
- DeFi佛薩奇2.0互助矩陣系統技術開發流程方案矩陣