暂无图片
暂无图片
3
暂无图片
暂无图片
暂无图片

用Tableau可视化Vertica数据库之“DB Time”篇

原创 Quanwen Zhao 2021-12-17
8783

目录

前言

在我的上一篇墨天轮博客文章中描述了什么是Vertica数据库,相信朋友们已经对Vertica数据库有了一定的了解。那么,今天我将给大家带来快速安装Vertica数据库和结合具体的业务场景来用Tableau可视化Vertica数据库中的“DB Time”表。说到这里,也许您可能会问,什么是DB Time?因为我是一名Oracle DBA工程师,需要时刻关注Oracle的性能情况,而DB Time是衡量Oracle性能的一个非常重要的指标。为了能够快速了解到Oracle数据库最近一段时间内的DB Time,我们可以通过相关的性能查询SQL语句来得到一段时间内的DB Time取值。但是在Oracle数据库当中DB Time的保留时间是由AWR报告的保留策略决定的,根据实际的业务诉求,我们通常只保留一个月的AWR报告,所以DB Time的数据也只能保留一个月。为了能够尽可能地将DB Time的数据保留的时间长一些,我们可以把DB Time的SQL查询导出到CSV(各个值用逗号分开)文件,然后将这个CSV文件导入到Vertica数据库(Vertica数据库是一种列式存储,支持大规模并行处理,非常适合海量数据的分析处理)然后用Tableau这个数据库可视化工具连接到Vertica数据库就能将DB Time表进行可视化,生成直观形象的折线图,让我们能够快速地了解什么时间段的DB Time值高,什么时间段的DB Time值会相对低一些,进而快速了解业务高峰期是什么时候和数据库的总体运行情况。

[返回到顶部目录]

在RHEL7上安装单节点的Vertica数据库

现在,我们在RHEL7操作系统上快速安装一个单节点的Vertica数据库。基本步骤是:

安装CE(社区免费)版本的RPM包 vertica-11.0.1-2.x86_64.RHEL6.rpm

将RPM包上传到服务器并用命令进行安装,如下所示:

[root@test ~]# ls -lrht vertica-11.0.1-2.x86_64.RHEL6.rpm 
-rw-r--r-- 1 root root 514M Dec  6 16:07 vertica-11.0.1-2.x86_64.RHEL6.rpm
[root@test ~]# rpm -ivh --nodeps vertica-11.0.1-2.x86_64.RHEL6.rpm 
warning: vertica-11.0.1-2.x86_64.RHEL6.rpm: Header V3 RSA/SHA256 Signature, key ID f54b82a0: NOKEY
Preparing...                          ################################# [100%]
Updating / installing...
   1:vertica-11.0.1-2                 ################################# [100%]

Vertica Analytic Database v11.0.1-2 successfully installed on host test

To complete your NEW installation and configure the cluster, run: 
 /opt/vertica/sbin/install_vertica

To complete your Vertica UPGRADE, run:
 /opt/vertica/sbin/update_vertica

---------------------------------------------------------------------------------- 
Important
---------------------------------------------------------------------------------- 
Before upgrading Vertica, you must backup your database.  After you restart your   
database after upgrading, you cannot revert to a previous Vertica software version.
---------------------------------------------------------------------------------- 

View the latest Vertica documentation at https://www.vertica.com/documentation/vertica/

此时,可以看到/opt目录下生成了vertica目录,其大小为1.9G

[root@test opt]# cd vertica/

[root@test vertica]# ls -lrht
total 3.5M
drwxrwxr-x  2 root root    6 Nov 20 08:04 log
-rw-r--r--  1 root root 3.4M Nov 20 08:11 LICENSES
drwxr-xr-x  2 root root   22 Dec 15 08:53 agent
drwxr-xr-x  2 root root 4.0K Dec 15 08:53 bin
drwxr-xr-x  4 root root  101 Dec 15 08:53 config
drwxr-xr-x  3 root root   26 Dec 15 08:53 examples
drwxr-xr-x  2 root root   57 Dec 15 08:53 en-US
drwxr-xr-x  2 root root   45 Dec 15 08:53 include
drwxr-xr-x  3 root root  101 Dec 15 08:53 java
drwxr-xr-x  2 root root 4.0K Dec 15 08:53 lib
drwxr-xr-x  2 root root   31 Dec 15 08:53 lib64
drwxrwxr-x  4 root root   36 Dec 15 08:53 oss
drwxr-xr-x 19 root root 4.0K Dec 15 08:54 packages
drwxr-xr-x  2 root root 4.0K Dec 15 08:54 sbin
drwxr-xr-x  2 root root 4.0K Dec 15 08:54 scripts
drwxrwxr-x  5 root root   91 Dec 15 08:54 sdk
drwxr-xr-x  9 root root  132 Dec 15 08:54 share
drwxrwxr-x  8 root root   80 Dec 15 08:54 spread
[root@test vertica]# du -sh .
1.9G    .

[返回到父目录] [返回到顶部目录]

用install_vertica脚本配置Vertica数据库集群

接下来,我们用install_vertica脚本配置Vertica集群。详见如下操作:

[root@test ~]# /opt/vertica/sbin/install_vertica --hosts 127.0.0.1 --rpm ~/vertica-11.0.1-2.x86_64.RHEL6.rpm --dba-user dbadmin
Vertica Analytic Database 11.0.1-2 Installation Tool


>> Validating options...


Mapping hostnames in --hosts (-s) to addresses...

>> Starting installation tasks.
>> Getting system information for cluster (this may take a while)...

Default shell on nodes:
127.0.0.1 /bin/bash

>> Validating software versions (rpm or deb)...

warning: /root/vertica-11.0.1-2.x86_64.RHEL6.rpm: Header V3 RSA/SHA256 Signature, key ID f54b82a0: NOKEY

>> Beginning new cluster creation...

successfully backed up admintools.conf on 127.0.0.1

>> Creating or validating DB Admin user/group...

Password for new dbadmin user (empty = disabled)  <<== 输入 密码 回车 (注意: 不回显)
Successful on hosts (1): 127.0.0.1
    Provided DB Admin account details: user = dbadmin, group = verticadba, home = /home/dbadmin
    Creating group... Adding group
    Validating group... Okay
    Creating user... Adding user, Setting credentials
    Validating user... Okay


>> Validating node and cluster prerequisites...

Prerequisites not fully met during local (OS) configuration for
verify-127.0.0.1.xml:
    HINT (S0305): https://www.vertica.com/docs/11.0.x/HTML/index.htm#cshid=S0305
        HINT(eS0305): TZ is unset for dbadmin. Consider updating .profile or
        .bashrc
    WARN (N0010): https://www.vertica.com/docs/11.0.x/HTML/index.htm#cshid=N0010
        WARN(eN0010): Linux iptables (firewall) has some non-trivial rules in
        tables: filter, mangle
    WARN (S0112): https://www.vertica.com/docs/11.0.x/HTML/index.htm#cshid=S0112
        WARN(eS0112): vm.swappiness is higher than recommended: your 30 > 1
    FAIL (S0312): https://www.vertica.com/docs/11.0.x/HTML/index.htm#cshid=S0312
        FAIL(eS0312): Transparent hugepages is set to 'never'. Must be 'always'.

System prerequisites failed.  Threshold = WARN
        Hint: Fix above failures or use --failure-threshold

Installation FAILED with errors.

****
AdminTools and your existing Vertica databases may be unavailable.
Investigate the above warnings/errors and re-run installation.
****

[返回到父目录] [返回到顶部目录]

根据提示信息排错并重新配置集群

从上面的安装中,我们可以看到有个重要的消息提示,它们依次为:HINT (S0305)WARN (N0010)WARN (S0112)FAIL (S0312),顺便还告知了网址和采取的解决办法。我们接着进行如下操作:

-- https://www.vertica.com/docs/11.0.x/HTML/Content/Authoring/InstallationGuide/BeforeYouInstall/TZenvironmentVar.htm?cshid=S0305

[root@test ~]# echo 'export TZ="Asia/Shanghai"' >> /home/dbadmin/.bash_profile

-- https://www.vertica.com/docs/11.0.x/HTML/Content/Authoring/InstallationGuide/BeforeYouInstall/CheckforSwappiness.htm?cshid=S0112

[root@test ~]# echo 0 > /proc/sys/vm/swappiness

[root@test ~]# echo 'vm.swappiness = 0' >> /etc/sysctl.conf

-- https://www.vertica.com/docs/11.0.x/HTML/Content/Authoring/InstallationGuide/BeforeYouInstall/transparenthugepages.htm?cshid=S0312

[root@test ~]# echo always > /sys/kernel/mm/transparent_hugepage/enabled

[root@test ~]# vi /etc/rc.local 
......
if test -f /sys/kernel/mm/transparent_hugepage/enabled; then
   echo always > /sys/kernel/mm/transparent_hugepage/enabled
fi
......
"/etc/rc.local" 34L, 1357C written

[root@test ~]# chmod +x /etc/rc.d/rc.local

经过上述操作以后,我们接着用install_vertica脚本进行配置,注意:最后加上参数和值--failure-threshold FAIL”。因为WARN (N0010)的警告非常奇怪,而且我们已经关闭防火墙,Vertica官网上说,只能加这个参数来回避这个问题。

[root@test ~]# /opt/vertica/sbin/install_vertica --hosts 127.0.0.1 --rpm ~/vertica-11.0.1-2.x86_64.RHEL6.rpm --dba-user dbadmin --failure-threshold FAIL
Vertica Analytic Database 11.0.1-2 Installation Tool


>> Validating options...


Mapping hostnames in --hosts (-s) to addresses...

>> Starting installation tasks.
>> Getting system information for cluster (this may take a while)...

Default shell on nodes:
127.0.0.1 /bin/bash

>> Validating software versions (rpm or deb)...

warning: /root/vertica-11.0.1-2.x86_64.RHEL6.rpm: Header V3 RSA/SHA256 Signature, key ID f54b82a0: NOKEY

>> Beginning new cluster creation...

successfully backed up admintools.conf on 127.0.0.1 

>> Creating or validating DB Admin user/group...

Successful on hosts (1): 127.0.0.1
    Provided DB Admin account details: user = dbadmin, group = verticadba, home = /home/dbadmin
    Creating group... Group already exists
    Validating group... Okay
    Creating user... User already exists
    Validating user... Okay


>> Validating node and cluster prerequisites...

Prerequisites not fully met during local (OS) configuration for
verify-127.0.0.1.xml:
    WARN (N0010): https://www.vertica.com/docs/11.0.x/HTML/index.htm#cshid=N0010
        WARN(eN0010): Linux iptables (firewall) has some non-trivial rules in
        tables: filter, mangle

System prerequisites passed.  Threshold = FAIL


>> Establishing DB Admin SSH connectivity...

Installing/Repairing SSH keys for dbadmin


>> Setting up each node and modifying cluster...

Creating Vertica Data Directory...

Updating agent...
Creating node node0001 definition for host 127.0.0.1
... Done

>> Sending new cluster configuration to all nodes...

Starting or restarting agent...

>> Completing installation...

Running upgrade logic
Installation complete.

Please evaluate your hardware using Vertica's validation tools:
    https://www.vertica.com/docs/11.0.x/HTML/index.htm#cshid=VALSCRIPT

To create a database:
  1. Logout and login as dbadmin. (see note below)
  2. Run /opt/vertica/bin/adminTools as dbadmin
  3. Select Create Database from the Configuration Menu

  Note: Installation may have made configuration changes to dbadmin
  that do not take effect until the next session (logout and login).

To add or remove hosts, select Cluster Management from the Advanced Menu.

[返回到父目录] [返回到顶部目录]

在Vertica集群上创建一个新的数据库

Vertica官网上的11.0.x帮助文档中的Creating a Database and Users来创建一个新的数据库vdb_oracle_perf。具体操作如下所示:

1. 用su命令将从操作系统的root用户切换到dbadmin用户,查看集群状态,它应该返回空值注:因为返回行很冗长,所以在此省略了屏幕上提示的17条条款内容。

[root@test ~]# su - dbadmin
[dbadmin@test ~]$ 
[dbadmin@test ~]$ /opt/vertica/bin/admintools -t view_cluster
Micro Focus End User License Agreement - Enterprise Version

......


5200-0949 v1.0, 2017
? Copyright 2015-2017 EntIT Software LLC



Enter ACCEPT to accept license terms & conditions, or REJECT to not accept the license and quit: ACCEPT  <<== 输入 ACCEPT
 DB | Host | State 
----+------+-------

2. 创建数据库“vdb_oracle_perf”,并设置密码为“oracle_perf”

[dbadmin@test ~]$ /opt/vertica/bin/admintools -t create_db --data_path=/home/dbadmin --catalog_path=/home/dbadmin --database=vdb_oracle_perf --password=oracle_perf --hosts=localhost

3. 用vsql命令登录到客户端,密码为前面设置的密码,最终出现提示符dbadmin=> ”

[dbadmin@test ~]$ /opt/vertica/bin/vsql
Password:  <<== 输入密码(不回显)
Welcome to vsql, the Vertica Analytic Database interactive terminal.

Type:  \h or \? for help with vsql commands
       \g or terminate with semicolon to execute query
       \q to quit

dbadmin=> 

[返回到父目录] [返回到顶部目录]

创建连接用户并授权

创建数据库的连接用户为“Qwz”并设置密码,然后授予公共schema给该用户。其具体的操作命令,如下所示:
dbadmin=> CREATE USER Qwz IDENTIFIED BY 'oracle';

dbadmin=> GRANT USAGE ON SCHEMA PUBLIC TO Qwz;

[返回到父目录] [返回到顶部目录]

将Oracle数据库的DB Time查询导入Vertica数据库

将Oracle数据库的DB Time的两个SQL查询分别保存为CSV文件

Oracle SQL Developer将下面的两个DB Time的SQL查询以脚本方式运行并保存为CSV文件,详见具体的SQL代码和对应的屏幕截图。

SET FEEDBACK  off;
SET SQLFORMAT csv;

-- DB time in Last 31 Days (interval by each hour).

SET LINESIZE 200
SET PAGESIZE 200

COLUMN snap_date_time FORMAT a19
COLUMN stat_name      FORMAT a10
COLUMN dbtime         FORMAT 999,999.99

ALTER SESSION SET nls_date_format = 'yyyy-mm-dd hh24:mi:ss';

WITH st AS
(
  SELECT snap_id
       , dbid
       , instance_number
       , end_interval_time
  FROM dba_hist_snapshot
),
stm AS
(
  SELECT snap_id
       , dbid
       , instance_number
       , stat_name
       , value
  FROM dba_hist_sys_time_model
  WHERE stat_name = 'DB time'
),
dbtime_per_hour AS
(
  SELECT CAST(st.end_interval_time AS DATE) snap_date_time
       , stm.stat_name
       , ROUND((stm.value - LAG(stm.value, 1, 0) OVER (PARTITION BY stm.dbid, stm.instance_number ORDER BY stm.snap_id))/1e6/6e1, 2) dbtime
  FROM st
     , stm
  WHERE st.snap_id = stm.snap_id
  AND   st.instance_number = stm.instance_number
  AND   st.dbid = stm.dbid
  AND   CAST(st.end_interval_time AS DATE) >= SYSDATE - 31
  ORDER BY snap_date_time
)
SELECT snap_date_time  -- the group column
     , stat_name       -- the series column
     , dbtime          -- the value column
FROM dbtime_per_hour
WHERE dbtime NOT IN (SELECT MAX(dbtime) FROM dbtime_per_hour)
;


SET FEEDBACK  off;
SET SQLFORMAT csv;

-- DB time in Last 1 Hour (interval by each minute).

SET LINESIZE 200
SET PAGESIZE 200

COLUMN snap_date_time FORMAT a19
COLUMN stat_name      FORMAT a10
COLUMN dbtime         FORMAT 999,999.99

SELECT end_time    snap_date_time
     , DECODE(metric_name, 'Average Active Sessions', 'AAS') stat_name
     , ROUND(value, 2)*60 dbtime
-- FROM dba_hist_sysmetric_history
FROM v$sysmetric_history
WHERE metric_name = 'Average Active Sessions'
AND   group_id = 2
AND   end_time >= SYSDATE - INTERVAL '60' MINUTE
ORDER BY snap_date_time
;


[返回到父目录] [返回到顶部目录]

将两个CSV文件上传到服务器/home/dbadmin目录下

[dbadmin@test ~]$ ls -lrht
total 40K
drwxr-xr-x 5 dbadmin verticadba  134 Dec 15 14:06 vdb_oracle_perf
-rw-r--r-- 1 dbadmin verticadba  27K Dec 16 18:37 oracle_dbtime.csv    <<==
-rw-r--r-- 1 dbadmin verticadba 1.9K Dec 16 18:37 oracle_dbtime_2.csv  <<==

[返回到父目录] [返回到顶部目录]

用DBeaver 21.3.1客户端工具连接到Vertica数据库


[返回到父目录] [返回到顶部目录]

在DBeaver 21.3.1上创建两张表awr_dbtime和awr_dbtime_2

创建步骤分别详见如下图:



[返回到父目录] [返回到顶部目录]

将两个CSV文件分别导入刚创建的两张表中

相应的屏幕截图如下所示:



[返回到父目录] [返回到顶部目录]

用Tableau可视化Vertica数据库的表

用Tableau连接Vertica数据库


[返回到父目录] [返回到顶部目录]

用Tableau可视化表awr_dbtime_2(最近1小时,按每分钟间隔)

在连接成功Vertica数据库以后,首先选择架构(这里翻译得可能有误,应该叫schemapublic,然后将表awr_dbtime_2拖动到指定的位置,单击底部的“工作表1”,顺次见如下两图:



接着,我们按照简单的五个步骤来进行可视化表awr_dbtime_2,这个表里包含按每分钟间隔最近1小时DB Time取值。每个步骤的屏幕截图依次如下所示:






最后,我们用鼠标移动到一个对应的标签上面,它会显示具体的快照时间和DB Time取值,效果如下图:


至此,最近1小时的DB Time(按每分钟间隔)的折线图已经制作完成。另外,Tableau可以将其导出并保存为PDFPowerPoint格式的文件。

[返回到父目录] [返回到顶部目录]

用Tableau可视化表awr_dbtime(最近31天,按每小时间隔)

和前面的可视化表awr_dbtime_2的方法相同,在此省略一些设置步骤,直接附上最终的折线图。


[返回到父目录] [返回到顶部目录]

用Tableau可视化表awr_dbtime(最近31天,按每天间隔)

同样的思路和方法,最终的效果图如下所示:


以上就是这篇博客文章的全部内容,欢迎朋友们在评论区提出您的宝贵意见或建议,我将认真阅您的反馈信息,并尽快逐一回复,谢谢!

[返回到父目录] [返回到顶部目录]

参考内容

更新于 2021年12月18日 晚上:

您也可以在我的GitHub上找到如何查询Oracle数据库最近31天的DB Time(按每小时间隔)最近1小时的DB Time(按每分钟间隔)

最后修改时间:2022-01-11 15:51:40
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
1人已赞赏
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论