国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

云服務器|WEB服務器|FTP服務器|郵件服務器|虛擬主機|服務器安全|DNS服務器|服務器知識|Nginx|IIS|Tomcat|

服務器之家 - 服務器技術 - 服務器知識 - 在Ubuntu上使用Grafana監控Docker的方法

在Ubuntu上使用Grafana監控Docker的方法

2020-12-30 17:37服務器技術網 服務器知識

如今越來越多的公司開始使用Docker,一談起Docker總是會跟著讓人聯想到輕量這個詞,甚至會有一種通過Docker啟動一個服務會節省很多資源的錯覺。然而Docker的「輕」也只是相對于傳統虛擬機而已。Docker如何監控呢?本文就給大家介

前言

grafana 是一個有著豐富指標的開源控制面板。在可視化大規模測量數據的時候是非常有用的。根據不同的指標數據,它提供了一個強大、優雅的來創建、分享和瀏覽數據的方式。

它提供了豐富多樣、靈活的圖形選項。此外,針對數據源(data source),它支持許多不同的存儲后端。每個數據源都有針對特定數據源的特性和功能所定制的查詢編輯器。grafana 提供了對下述數據源的正式支持:graphite、influxdb、opentsdb、 prometheus、elasticsearch 和 cloudwatch。

每個數據源的查詢語言和能力顯然是不同的,你可以將來自多個數據源的數據混合到一個單一的儀表盤上,但每個面板(panel)被綁定到屬于一個特定組織(organization)的特定數據源上。它支持驗證登錄和基于角色的訪問控制方案。它是作為一個獨立軟件部署,使用 go 和 javascript 編寫的。

在這篇文章,我將講解如何在 ubuntu 16.04 上安裝 grafana 并使用這個軟件配置 docker 監控。

先決條件

安裝好 docker 的服務器

安裝 grafana

我們可以在 docker 中構建我們的 grafana。 有一個官方提供的 grafana docker 鏡像。

請運行下述命令來構建grafana 容器。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
root@ubuntu:~# docker run -i -p 3000:3000 grafana/grafana
 
unable to find image 'grafana/grafana:latest' locally
 
latest: pulling from grafana/grafana
 
5c90d4a2d1a8: pull complete
 
b1a9a0b6158e: pull complete
 
acb23b0d58de: pull complete
 
digest: sha256:34ca2f9c7986cb2d115eea373083f7150a2b9b753210546d14477e2276074ae1
 
status: downloaded newer image for grafana/grafana:latest
 
t=2016-07-27t15:20:19+0000 lvl=info msg="starting grafana"
 
logger=main version=3.1.0 commit=v3.1.0 compiled=2016-07-12t06:42:28+0000
 
t=2016-07-27t15:20:19+0000 lvl=info msg="config loaded from"
 
logger=settings file=/usr/share/grafana/conf/defaults.ini
 
t=2016-07-27t15:20:19+0000 lvl=info msg="config loaded from"
 
logger=settings file=/etc/grafana/grafana.ini
 
t=2016-07-27t15:20:19+0000 lvl=info msg="config overriden from
 
command line" logger=settings arg="default.paths.data=/var/lib/grafana"
 
t=2016-07-27t15:20:19+0000 lvl=info msg="config overriden from command
 
line" logger=settings arg="default.paths.logs=/var/log/grafana"
 
t=2016-07-27t15:20:19+0000 lvl=info msg="config overriden from command
 
line" logger=settings arg="default.paths.plugins=/var/lib/grafana/plugins"
 
t=2016-07-27t15:20:19+0000 lvl=info msg="path home" logger=settings
 
path=/usr/share/grafana
 
t=2016-07-27t15:20:19+0000 lvl=info msg="path data" logger=settings
 
path=/var/lib/grafana
 
t=2016-07-27t15:20:19+0000 lvl=info msg="path logs" logger=settings
 
path=/var/log/grafana
 
t=2016-07-27t15:20:19+0000 lvl=info msg="path plugins" logger=settings
 
path=/var/lib/grafana/plugins
 
t=2016-07-27t15:20:19+0000 lvl=info msg="initializing db" logger=sqlstore
 
dbtype=sqlite3
 
t=2016-07-27t15:20:20+0000 lvl=info msg="executing migration" logger=migrator
 
id="create playlist table v2"
 
t=2016-07-27t15:20:20+0000 lvl=info msg="executing migration" logger=migrator
 
id="create playlist item table v2"
 
t=2016-07-27t15:20:20+0000 lvl=info msg="executing migration" logger=migrator
 
id="drop preferences table v2"
 
t=2016-07-27t15:20:20+0000 lvl=info msg="executing migration" logger=migrator
 
id="drop preferences table v3"
 
t=2016-07-27t15:20:20+0000 lvl=info msg="executing migration" logger=migrator
 
id="create preferences table v3"
 
t=2016-07-27t15:20:20+0000 lvl=info msg="created default admin user: [admin]"
 
t=2016-07-27t15:20:20+0000 lvl=info msg="starting plugin search" logger=plugins
 
t=2016-07-27t15:20:20+0000 lvl=info msg="server listening" logger=server
 
address=0.0.0.0:3000 protocol=http suburl=

我們可以通過運行此命令確認 grafana 容器的工作狀態 docker ps -a 或通過這個url訪問 http://docker ip:3000。

所有的 grafana 配置設置都使用環境變量定義,在使用容器技術時這個是非常有用的。grafana 配置文件路徑為 /etc/grafana/grafana.ini。

理解配置項

grafana 可以在它的 ini 配置文件中指定幾個配置選項,或可以使用前面提到的環境變量來指定。

配置文件位置

通常配置文件路徑:

默認配置文件路徑 : $working_dir/conf/defaults.ini

自定義配置文件路徑 : $working_dir/conf/custom.ini

ps:當你使用 deb、rpm 或 docker 鏡像安裝 grafana 時,你的配置文件在 /etc/grafana/grafana.ini。

理解配置變量

現在我們看一些配置文件中的變量:

instance_name:這是 grafana 服務器實例的名字。默認值從 ${hostname} 獲取,其值是環境變量hostname,如果該變量為空或不存在,grafana 將會嘗試使用系統調用來獲取機器名。

[paths]:這些路徑通常都是在 init.d 腳本或 systemd service 文件中通過命令行指定。

data:這個是 grafana 存儲 sqlite3 數據庫(如果使用)、基于文件的會話(如果使用),和其他數據的路徑。

logs:這個是 grafana 存儲日志的路徑。

[server]

http_addr:應用監聽的 ip 地址,如果為空,則監聽所有的接口。

http_port:應用監聽的端口,默認是 3000,你可以使用下面的命令將你的 80 端口重定向到 3000 端口:$iptables -t nat -a prerouting -p tcp --dport 80 -j redirect --to-port 3000

root_url : 這個 url 用于從瀏覽器訪問 grafana 。

cert_file : 證書文件的路徑(如果協議是 https)。

cert_key : 證書密鑰文件的路徑(如果協議是 https)。

[database]:grafana 使用數據庫來存儲用戶和儀表盤以及其他信息,默認配置為使用內嵌在 grafana 主二進制文件中的 sqlite3。

type:你可以根據你的需求選擇 mysql、postgres、sqlite3。

path:僅用于選擇 sqlite3 數據庫時,這個是數據庫所存儲的路徑。

host:僅適用 mysql 或者 postgres。它包括 ip 地址或主機名以及端口。例如,grafana 和 mysql 運行在同一臺主機上設置如: host = 127.0.0.1:3306 。

name:grafana 數據庫的名稱,把它設置為 grafana 或其它名稱。

user:數據庫用戶(不適用于 sqlite3)。

password:數據庫用戶密碼(不適用于 sqlite3)。

ssl_mode:對于 postgres,使用 disable,require,或 verify-full 等值。對于 mysql,使用 true,false,或 skip-verify。

ca_cert_path:(只適用于 mysql)ca 證書文件路徑,在多數 linux 系統中,證書可以在 /etc/ssl/certs 找到。

client_key_path:(只適用于 mysql)客戶端密鑰的路徑,只在服務端需要用戶端驗證時使用。

client_cert_path:(只適用于 mysql)客戶端證書的路徑,只在服務端需要用戶端驗證時使用。

server_cert_name:(只適用于 mysql)mysql 服務端使用的證書的通用名稱字段。如果 ssl_mode 設置為 skip-verify 時可以不設置。

[security]

admin_user:這個是 grafana 默認的管理員用戶的用戶名,默認設置為 admin。

admin_password:這個是 grafana 默認的管理員用戶的密碼,在第一次運行時設置,默認為 admin。

login_remember_days:保持登錄/記住我的持續天數。

secret_key:用于保持登錄/記住我的 cookies 的簽名。

設置監控的重要組件

我們可以使用下面的組件來創建我們的 docker 監控系統。

cadvisor:它被稱為 container advisor。它給用戶提供了一個資源利用和性能特征的解讀。它會收集、聚合、處理、導出運行中的容器的信息。你可以通過這個文檔了解更多。

influxdb:這是一個包含了時間序列、度量和分析數據庫。我們使用這個數據源來設置我們的監控。cadvisor 只展示實時信息,并不保存這些度量信息。influx db 幫助保存 cadvisor 提供的監控數據,以展示非某一時段的數據。

grafana dashboard:它可以幫助我們在視覺上整合所有的信息。這個強大的儀表盤使我們能夠針對 influxdb 數據存儲進行查詢并將他們放在一個布局合理好看的圖表中。

docker 監控的安裝

我們需要一步一步的在我們的 docker 系統中安裝以下每一個組件:

安裝 influxdb

我們可以使用這個命令來拉取 influxdb 鏡像,并部署了 influxdb 容器。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
root@ubuntu:~# docker run -d -p 8083:8083 -p 8086:8086 --expose
 
8090 --expose 8099 -e pre_create_db=cadvisor --name influxsrv tutum/influxdb:0.8.8
 
unable to find image 'tutum/influxdb:0.8.8' locally
 
0.8.8: pulling from tutum/influxdb
 
a3ed95caeb02: already exists
 
23efb549476f: already exists
 
aa2f8df21433: already exists
 
ef072d3c9b41: already exists
 
c9f371853f28: already exists
 
a248b0871c3c: already exists
 
749db6d368d0: already exists
 
7d7c7d923e63: pull complete
 
e47cc7808961: pull complete
 
1743b6eeb23f: pull complete
 
digest: sha256:8494b31289b4dbc1d5b444e344ab1dda3e18b07f80517c3f9aae7d18133c0c42
 
status: downloaded newer image for tutum/influxdb:0.8.8
 
d3b6f7789e0d1d01fa4e0aacdb636c221421107d1df96808ecbe8e241ceb1823
 
-p 8083:8083 : user interface, log in with username-admin, pass-admin
 
-p 8086:8086 : interaction with other application
 
--name influxsrv : container have name influxsrv, use to cadvisor link it.

你可以測試 influxdb 是否安裝好,通過訪問這個 url http://你的 ip 地址:8083,用戶名和密碼都是 ”root“。

在Ubuntu上使用Grafana監控Docker的方法

influxdb administration 2016-08-01 14-10-08

我們可以在這個界面上創建我們所需的數據庫。

在Ubuntu上使用Grafana監控Docker的方法

createdb influx

安裝 cadvisor

我們的下一個步驟是安裝 cadvisor 容器,并將其鏈接到 influxdb 容器。你可以使用此命令來創建它。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
root@ubuntu:~# docker run --volume=/:/rootfs:ro --volume
 
=/var/run:/var/run:rw --volume=/sys:/sys:ro --volume=
 
/var/lib/docker/:/var/lib/docker:ro --publish=8080:8080
 
--detach=true --link influxsrv:influxsrv --name=cadvisor
 
google/cadvisor:latest -storage_driver_db=cadvisor
 
-storage_driver_host=influxsrv:8086
 
unable to find image 'google/cadvisor:latest' locally
 
latest: pulling from google/cadvisor
 
09d0220f4043: pull complete
 
151807d34af9: pull complete
 
14cd28dce332: pull complete
 
digest: sha256:8364c7ab7f56a087b757a304f9376c3527c8c60c848f82b66dd728980222bd2f
 
status: downloaded newer image for google/cadvisor:latest
 
3bfdf7fdc83872485acb06666a686719983a1172ac49895cd2a260deb1cdde29
 
root@ubuntu:~#
 
--publish=8080:8080 : user interface
 
--link=influxsrv:influxsrv: link to container influxsrv
 
-storage_driver=influxdb: set the storage driver as influxdb
 
specify what influxdb instance to push data to:
 
-storage_driver_host=influxsrv:8086: the ip:port of the
 
database. default is ‘localhost:8086'
 
-storage_driver_db=cadvisor: database name. uses db
 
‘cadvisor' by default

你可以通過訪問這個地址來測試安裝 cadvisor 是否正常 http://你的 ip 地址:8080。 這將為你的 docker 主機和容器提供統計信息。

在Ubuntu上使用Grafana監控Docker的方法

cadvisor - docker containers 2016-08-01 14-24-18

安裝 grafana 控制面板

最后,我們需要安裝 grafana 儀表板并連接到 influxdb,你可以執行下面的命令來設置它。

?
1
2
3
4
5
6
7
8
9
root@ubuntu:~# docker run -d -p 3000:3000 -e influxdb_host=localhost
 
-e influxdb_port=8086 -e influxdb_name=cadvisor -e influxdb_user=
 
root -e influxdb_pass=root --link influxsrv:influxsrv --name
 
grafana grafana/grafana
 
f3b7598529202b110e4e6b998dca6b6e60e8608d75dcfe0d2b09ae408f43684a

現在我們可以登錄 grafana 來配置數據源. 訪問 http://你的 ip 地址:3000 或 http://你的 ip 地址(如果你在前面做了端口映射的話):

用戶名 - admin

密碼 - admin

一旦我們安裝好了 grafana,我們可以連接 influxdb。登錄到儀表盤并且點擊面板左上方角落的 grafana 圖標(那個火球)。點擊數據源(data sources)來配置。

在Ubuntu上使用Grafana監控Docker的方法

addingdatabsource

現在你可以添加新的圖形(graph)到我們默認的數據源 influxdb。

在Ubuntu上使用Grafana監控Docker的方法

panelgraph

我們可以通過在測量(metric)頁面編輯和調整我們的查詢以調整我們的圖形。

在Ubuntu上使用Grafana監控Docker的方法

grafana - grafana dashboard 2016-08-01 14-53-40

在Ubuntu上使用Grafana監控Docker的方法

grafana - grafana dashboard

總結

關于 docker 監控,你可用從此了解更多信息。 以上就是這篇文章的全部內容了,如果大家有什么疑問或問題留意留言交流,希望可以留下有價值的建議和評論。謝謝對服務器之家的支持。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 欧美在线高清 | 久久精品中文字幕 | 天天干天天射天天操 | 狠狠操狠狠干 | 成人国产综合 | 久久韩国| av手机在线播放 | 午夜黄色| 国产成人精品亚洲日本在线观看 | 中文字幕视频在线 | 国产精品极品美女在线观看免费 | 久久久亚洲精品一区二区三区 | 国产伦精品一区二区三区四区视频 | 国产色黄视频 | 亚洲免费观看视频网站 | 久久久婷| 七七婷婷婷婷精品国产 | 日本中文字幕久久 | 日韩在线视频播放 | 欧美成人区| 国产精品久久久久国产a级 最新国产视频 | 在线欧美日韩 | 日韩在线观看一区 | 一级电影毛片 | 国产免费久久 | 免费一级毛片免费播放 | 一区二区三区精品 | av看片网| 久久成人精品视频 | 亚洲精品久久久久久下一站 | 久久三区 | 欧美日韩综合视频 | 免费h | 亚洲一区久久 | 日韩av中文在线 | 国产成人精品一区二区三区四区 | 欧美一级特黄aaaaaa | 免费视频久久久 | 久久精品综合 | 久久中文字幕一区二区 | 日本一区二区免费在线观看 |