使用 Python 用戶端管理儀表板
使用 Python 用戶端以程式化方式管理儀表板。
若要瞭解如何使用 Python 用戶端,請參閱 使用 Python 用戶端。
若要使用特定團隊中的資源,您必須使用「監視 (sysdig)」記號。
下表列出可用來管理儀表板的部分 Python 函數:
| 動作 | 功能 |
|---|---|
| 建立儀表板 | sdclient.create_dashboard(dashboard_name) |
| 從文件建立儀表板 | sdclient.create_dashboard_from_file('dashboard_name', 'dashboard_name.json', scope_filter, shared=False, public=True) |
| 複製儀表板 | sdclient.create_dashboard_from_dashboard(dashboard_name, existing_dashboard_name, scope_filter, shared=False, public=True) |
| 下載儀表板 | sdclient.get_dashboards() |
| 更新儀表板 | sdclient.update_dashboard(dashboard_name) |
| 刪除儀表板 | sdclient.delete_dashboard(dashboard_name) |
| 尋找儀表板 | sdclient.find_dashboard_by(dashboard_name) |
| 新增時間序列 | sdclient.add_dashboard_panel(dashboard_name, panel_name, panel_type, metrics, scope=scope) |
| 新增儀表板畫面 | sdclient.add_dashboard_panel(dashboard_name, panel_name, panel_type, metrics, sort_direction=sort_direction, limit=limit, layout=layout) |
| 移除畫面 | sdclient.remove_dashboard_panel(dashboard_name, 'CPU Over Time') |
| 將儀表板儲存至檔案 | sdclient.save_dashboard_to_file('dashboard_name', 'dashboard_name.json') |
列出每個團隊的儀表板
您可以使用 Python 來列出可供團隊使用的儀表板。
列出預設團隊中可用的儀表板
下列程式碼顯示 Python Script 的結構,以列出預設團隊中可用的儀表板。
#!/usr/bin/env python3
import os
import sys
sys.path.insert(0, os.path.join(os.path.dirname(os.path.realpath(sys.argv[0])), '..'))
from sdcclient import IbmAuthHelper, SdMonitorClient
# Parse arguments.
def usage():
print('usage: %s <endpoint-url> <apikey> <instance-guid>' % sys.argv[0])
print('endpoint-url: The endpoint URL that should point to IBM Cloud')
print('apikey: IBM Cloud IAM apikey that will be used to retrieve an access token')
print('instance-guid: GUID of an IBM Cloud Monitoring with monitoring instance')
sys.exit(1)
if len(sys.argv) != 4:
usage()
URL = sys.argv[1]
APIKEY = sys.argv[2]
GUID = sys.argv[3]
# Instantiate the client
ibm_headers = IbmAuthHelper.get_headers(URL, APIKEY, GUID)
sdclient = SdMonitorClient(sdc_url=URL, custom_headers=ibm_headers)
# Show the list of dashboards
ok, res = sdclient.get_dashboards()
if not ok:
print(res)
sys.exit(1)
for db in res['dashboards']:
print("%s [Team ID: %s] Name: %s, # Charts: %d" % ( db['id'], db['teamId'], db['name'], len(db['widgets'] if 'widgets' in db else [])))
列出團隊中可用的儀表板
下列程式碼顯示 Python Script 的結構,以列出可供特定團隊使用的儀表板。
#!/usr/bin/env python3
import os
import sys
sys.path.insert(0, os.path.join(os.path.dirname(os.path.realpath(sys.argv[0])), '..'))
from sdcclient import SdMonitorClient
# Parse arguments.
def usage():
print('usage: %s <endpoint-url> <sysdig_token>' % sys.argv[0])
print('endpoint-url: The endpoint URL that should point to IBM Cloud')
print('sysdig_token: Sysdig token for the team')
sys.exit(1)
if len(sys.argv) != 3:
usage()
URL = sys.argv[1]
# Set to the Sysdig token of the team
SYSDIG_TOKEN = sys.argv[2]
sdclient = SdMonitorClient(token=SYSDIG_TOKEN,sdc_url=URL)
# Show the list of dashboards
ok, res = sdclient.get_dashboards()
if not ok:
print(res)
sys.exit(1)
for db in res['dashboards']:
print("%s [Team ID: %s] Name: %s, # Charts: %d" % ( db['id'], db['teamId'], db['name'], len(db['widgets'] if 'widgets' in db else [])))
建立儀表板
您可以使用 Python 來建立儀表板。
在預設團隊中建立儀表板
下列程式碼顯示 Python Script 的結構,以建立預設團隊的新儀表板。
下列程式碼顯示 Python Script 的結構:
#!/usr/bin/env python3
import os
import sys
sys.path.insert(0, os.path.join(os.path.dirname(os.path.realpath(sys.argv[0])), '..'))
from sdcclient import IbmAuthHelper, SdMonitorClient
# Parse arguments.
def usage():
print('usage: %s <endpoint-url> <apikey> <instance-guid>' % sys.argv[0])
print('endpoint-url: The endpoint URL that should point to IBM Cloud')
print('apikey: IBM Cloud IAM apikey that will be used to retrieve an access token')
print('instance-guid: GUID of an IBM Cloud Monitoring with monitoring instance')
sys.exit(1)
if len(sys.argv) != 4:
usage()
URL = sys.argv[1]
APIKEY = sys.argv[2]
GUID = sys.argv[3]
DASHBOARD_NAME = 'My New Dashboard from Python'
PANEL_NAME = 'CPU Over Time'
# Instantiate the client
ibm_headers = IbmAuthHelper.get_headers(URL, APIKEY, GUID)
sdclient = SdMonitorClient(sdc_url=URL, custom_headers=ibm_headers)
# Create an empty dashboard
ok, res = sdclient.create_dashboard(DASHBOARD_NAME)
# Check the result
dashboard_name = None
if ok:
print('Dashboard %d created successfully' % res['dashboard']['id'])
dashboard_name = res['dashboard']
else:
print(res)
sys.exit(1)
# Add a time series panel
panel_type = 'timeSeries'
metrics = [
{'id': 'proc.name'},
{'id': 'cpu.used.percent', 'aggregations': {'time': 'avg', 'group': 'avg'}}
]
ok, res = sdclient.add_dashboard_panel(
dashboard_name, PANEL_NAME, panel_type, metrics)
# Check the result
if ok:
print('Panel added successfully')
dashboard_name = res['dashboard']
else:
print(res)
sys.exit(1)
在團隊中建立儀表板
下列程式碼顯示 Python Script 的結構,以建立特定團隊的儀表板。
#!/usr/bin/env python3
import os
import sys
sys.path.insert(0, os.path.join(os.path.dirname(os.path.realpath(sys.argv[0])), '..'))
from sdcclient import SdMonitorClient
# Parse arguments.
def usage():
print('usage: %s <endpoint-url> <sysdig_token>' % sys.argv[0])
print('endpoint-url: The endpoint URL that should point to IBM Cloud')
print('sysdig_token: Sysdig token for the team')
sys.exit(1)
if len(sys.argv) != 3:
usage()
URL = sys.argv[1]
# Set to the Sysdig token of the team
SYSDIG_TOKEN = sys.argv[2]
DASHBOARD_NAME = 'My New Dashboard from Python'
PANEL_NAME = 'CPU Over Time'
sdclient = SdMonitorClient(token=SYSDIG_TOKEN,sdc_url=URL)
# Create an empty dashboard
ok, res = sdclient.create_dashboard(DASHBOARD_NAME)
# Check the result
dashboard_name = None
if ok:
print('Dashboard %d created successfully' % res['dashboard']['id'])
dashboard_name = res['dashboard']
else:
print(res)
sys.exit(1)
# Add a time series panel
panel_type = 'timeSeries'
metrics = [
{'id': 'proc.name'},
{'id': 'cpu.used.percent', 'aggregations': {'time': 'avg', 'group': 'avg'}}
]
ok, res = sdclient.add_dashboard_panel(
dashboard_name, PANEL_NAME, panel_type, metrics)
# Check the result
if ok:
print('Panel added successfully')
dashboard_name = res['dashboard']
else:
print(res)
sys.exit(1)
複製儀表板
您可以使用 Python 來複製儀表板。
複製預設團隊中的自訂儀表板
下列程式碼顯示 Python Script 的結構,以將自訂儀表板複製到預設團隊。
#!/usr/bin/env python3
import os
import sys
sys.path.insert(0, os.path.join(os.path.dirname(os.path.realpath(sys.argv[0])), '..'))
from sdcclient import IbmAuthHelper, SdMonitorClient
# Parse arguments.
def usage():
print('usage: %s <endpoint-url> <apikey> <instance-guid>' % sys.argv[0])
print('endpoint-url: The endpoint URL that should point to IBM Cloud')
print('apikey: IBM Cloud IAM apikey that will be used to retrieve an access token')
print('instance-guid: GUID of an IBM Cloud Monitoring with monitoring instance')
sys.exit(1)
if len(sys.argv) != 4:
usage()
URL = sys.argv[1]
APIKEY = sys.argv[2]
GUID = sys.argv[3]
# Name for the dashboard to create
dashboard_name = "My new CPU dashboard"
# Existing dashboard to copy
existing_dashboard_name = "My Existing Dashboard"
# New filter to apply
scope_filter = 'host.hostName = "virtualserver02"'
# Instantiate the client
ibm_headers = IbmAuthHelper.get_headers(URL, APIKEY, GUID)
sdclient = SdMonitorClient(sdc_url=URL, custom_headers=ibm_headers)
# Copy a dashboard
ok, res = sdclient.create_dashboard_from_dashboard(dashboard_name, existing_dashboard_name, scope_filter, shared=False, public=True)
# Check the result
#
if ok:
print('Dashboard created successfully')
else:
print(res)
sys.exit(1)
複製預設團隊中預先定義的儀表板
下列程式碼顯示 Python Script 的結構,以將預先定義的儀表板複製到預設團隊。
#!/usr/bin/env python3
import os
import sys
sys.path.insert(0, os.path.join(os.path.dirname(os.path.realpath(sys.argv[0])), '..'))
from sdcclient import IbmAuthHelper, SdMonitorClient
# Parse arguments.
def usage():
print('usage: %s <endpoint-url> <apikey> <instance-guid>' % sys.argv[0])
print('endpoint-url: The endpoint URL that should point to IBM Cloud')
print('apikey: IBM Cloud IAM apikey that will be used to retrieve an access token')
print('instance-guid: GUID of an IBM Cloud Monitoring with monitoring instance')
sys.exit(1)
if len(sys.argv) != 4:
usage()
URL = sys.argv[1]
APIKEY = sys.argv[2]
GUID = sys.argv[3]
# Name for the dashboard to create
dashboard_name = "My Overview by Process"
# Existing dashboard to copy
default_dashboard_name = "Overview by Process"
# New filter to apply
scope_filter = 'host.hostName = "virtualserver02"'
# Instantiate the client
ibm_headers = IbmAuthHelper.get_headers(URL, APIKEY, GUID)
sdclient = SdMonitorClient(sdc_url=URL, custom_headers=ibm_headers)
# Copy a dashboard
ok, res = sdclient.create_dashboard_from_view(dashboard_name, default_dashboard_name, scope_filter, shared=False, public=True)
# Check the result
#
if ok:
print('Dashboard created successfully')
else:
print(res)
sys.exit(1)
複製團隊中的儀表板
下列程式碼顯示 Python Script 的結構,以將儀表板複製到團隊。
#!/usr/bin/env python3
import os
import sys
sys.path.insert(0, os.path.join(os.path.dirname(os.path.realpath(sys.argv[0])), '..'))
from sdcclient import SdMonitorClient
# Parse arguments.
def usage():
print('usage: %s <endpoint-url> <sysdig_token>' % sys.argv[0])
print('endpoint-url: The endpoint URL that should point to IBM Cloud')
print('sysdig_token: Sysdig token for the team')
sys.exit(1)
if len(sys.argv) != 3:
usage()
URL = sys.argv[1]
# Set to the Sysdig token of the team
SYSDIG_TOKEN = sys.argv[2]
# Name for the dashboard to create
dashboard_name = "My new CPU dashboard"
# Existing dashboard to copy
existing_dashboard_name = "My Existing Dashboard"
# New filter to apply
scope_filter = 'host.hostName = "virtualserver02"'
sdclient = SdMonitorClient(token=SYSDIG_TOKEN,sdc_url=URL)
# Copy a dashboard
ok, res = sdclient.create_dashboard_from_dashboard(dashboard_name, existing_dashboard_name, scope_filter, shared=False, public=True)
# Check the result
#
if ok:
print('Dashboard created successfully')
else:
print(res)
sys.exit(1)
刪除儀表板
您可以使用 Python 來刪除儀表板。
您必須知道儀表板的 ID 才能刪除它。
從預設團隊中刪除儀表板
下列程式碼顯示 Python Script 的結構,以從預設團隊中刪除儀表板。
#!/usr/bin/env python3
import os
import sys
sys.path.insert(0, os.path.join(os.path.dirname(os.path.realpath(sys.argv[0])), '..'))
from sdcclient import IbmAuthHelper, SdMonitorClient
# Parse arguments.
def usage():
print('usage: %s <endpoint-url> <apikey> <instance-guid>' % sys.argv[0])
print('endpoint-url: The endpoint URL that should point to IBM Cloud')
print('apikey: IBM Cloud IAM apikey that will be used to retrieve an access token')
print('instance-guid: GUID of an IBM Cloud Monitoring with monitoring instance')
sys.exit(1)
if len(sys.argv) != 4:
usage()
URL = sys.argv[1]
APIKEY = sys.argv[2]
GUID = sys.argv[3]
# Name of the dashboard that you want to delete
DASHBOARD_NAME = "Nginx production"
# Instantiate the client
ibm_headers = IbmAuthHelper.get_headers(URL, APIKEY, GUID)
sdclient = SdMonitorClient(sdc_url=URL, custom_headers=ibm_headers)
# Show the list of dashboards
ok, res = sdclient.get_dashboards()
# Loop through all fetched dashboards
for dashboard in res[1]['dashboards']:
# Delete dashboard if it matches the pattern (one or many)
if DASHBOARD_NAME in dashboard['name']:
print("Deleting " + dashboard['name'])
res = sdclient.delete_dashboard(dashboard)
從團隊中刪除儀表板
下列程式碼顯示 Python Script 的結構,以從特定團隊中刪除儀表板。
#!/usr/bin/env python3
import os
import sys
sys.path.insert(0, os.path.join(os.path.dirname(os.path.realpath(sys.argv[0])), '..'))
from sdcclient import SdMonitorClient
# Parse arguments.
def usage():
print('usage: %s <endpoint-url> <sysdig_token>' % sys.argv[0])
print('endpoint-url: The endpoint URL that should point to IBM Cloud')
print('sysdig_token: Sysdig token for the team')
sys.exit(1)
if len(sys.argv) != 3:
usage()
URL = sys.argv[1]
# Set to the Sysdig token of the team
SYSDIG_TOKEN = sys.argv[2]
sdclient = SdMonitorClient(token=SYSDIG_TOKEN,sdc_url=URL)
# Show the list of dashboards
ok, res = sdclient.get_dashboards()
# Loop through all fetched dashboards
for dashboard in res[1]['dashboards']:
# Delete dashboard if it matches the pattern (one or many)
if DASHBOARD_NAME in dashboard['name']:
print("Deleting " + dashboard['name'])
res = sdclient.delete_dashboard(dashboard)
下載自訂儀表板
您可以使用 Python 來下載自訂儀表板。
當您下載儀表板時,只會下載自訂儀表板。
下載預設團隊中的自訂儀表板
下列程式碼顯示 Python Script 的結構,以從預設團隊下載自訂儀表板。
#!/usr/bin/env python3
import os
import sys
sys.path.insert(0, os.path.join(os.path.dirname(os.path.realpath(sys.argv[0])), '..'))
from sdcclient import IbmAuthHelper, SdMonitorClient
# Parse arguments.
def usage():
print('usage: %s <endpoint-url> <apikey> <instance-guid>' % sys.argv[0])
print('endpoint-url: The endpoint URL that should point to IBM Cloud')
print('apikey: IBM Cloud IAM apikey that will be used to retrieve an access token')
print('instance-guid: GUID of an IBM Cloud Monitoring with monitoring instance')
sys.exit(1)
if len(sys.argv) != 4:
usage()
def zipdir(path, ziph):
# ziph is zipfile handle
for root, dirs, files in os.walk(path):
for file in files:
ziph.write(os.path.join(root, file))
def cleanup_dir(path):
if os.path.exists(path) == False:
return
if os.path.isdir(path) == False:
print('Provided path is not a directory')
sys.exit(-1)
for file in os.listdir(path):
file_path = os.path.join(path, file)
try:
if os.path.isfile(file_path):
os.unlink(file_path)
else:
print('Cannot clean the provided directory due to delete failure on %s' % file_path)
except Exception as e:
print(e)
os.rmdir(path)
sysdig_dashboard_dir = 'sysdig-dashboard-dir'
URL = sys.argv[1]
APIKEY = sys.argv[2]
GUID = sys.argv[3]
# Instantiate the client
ibm_headers = IbmAuthHelper.get_headers(URL, APIKEY, GUID)
sdclient = SdMonitorClient(sdc_url=URL, custom_headers=ibm_headers)
ok, res = sdclient.get_dashboards()
if not ok:
print(res)
sys.exit(1)
# Creating sysdig dashboard directory to store dashboards
if not os.path.exists(sysdig_dashboard_dir):
os.makedirs(sysdig_dashboard_dir)
for db in res['dashboards']:
sdclient.save_dashboard_to_file(db, os.path.join(sysdig_dashboard_dir, str(db['id'])))
print("Name: %s, # Charts: %d" % (db['name'], len(db['widgets'])))
下載團隊中的自訂儀表板
下列程式碼顯示 Python Script 的結構,以從特定團隊下載自訂儀表板。
#!/usr/bin/env python3
import os
import sys
sys.path.insert(0, os.path.join(os.path.dirname(os.path.realpath(sys.argv[0])), '..'))
from sdcclient import SdMonitorClient
# Parse arguments.
def usage():
print('usage: %s <endpoint-url> <sysdig_token>' % sys.argv[0])
print('endpoint-url: The endpoint URL that should point to IBM Cloud')
print('sysdig_token: Sysdig token for the team')
sys.exit(1)
if len(sys.argv) != 3:
usage()
URL = sys.argv[1]
# Set to the Sysdig token of the team
SYSDIG_TOKEN = sys.argv[2]
def zipdir(path, ziph):
# ziph is zipfile handle
for root, dirs, files in os.walk(path):
for file in files:
ziph.write(os.path.join(root, file))
def cleanup_dir(path):
if os.path.exists(path) == False:
return
if os.path.isdir(path) == False:
print('Provided path is not a directory')
sys.exit(-1)
for file in os.listdir(path):
file_path = os.path.join(path, file)
try:
if os.path.isfile(file_path):
os.unlink(file_path)
else:
print('Cannot clean the provided directory due to delete failure on %s' % file_path)
except Exception as e:
print(e)
os.rmdir(path)
sysdig_dashboard_dir = 'sysdig-dashboard-dir'
sdclient = SdMonitorClient(token=SYSDIG_TOKEN,sdc_url=URL)
ok, res = sdclient.get_dashboards()
if not ok:
print(res)
sys.exit(1)
# Creating sysdig dashboard directory to store dashboards
if not os.path.exists(sysdig_dashboard_dir):
os.makedirs(sysdig_dashboard_dir)
for db in res['dashboards']:
sdclient.save_dashboard_to_file(db, os.path.join(sysdig_dashboard_dir, str(db['id'])))
print("Name: %s, # Charts: %d" % (db['name'], len(db['widgets'])))