目录
前言
在RHEL7上安装单节点的Vertica数据库
现在,我们在RHEL7操作系统上快速安装一个单节点的Vertica数据库。基本步骤是:
- 安装CE(社区免费)版本的RPM包 vertica-11.0.1-2.x86_64.RHEL6.rpm
- 用install_vertica脚本配置Vertica数据库集群
- 根据提示信息排错并重新配置集群
- 在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=>
创建连接用户并授权
dbadmin=> CREATE USER Qwz IDENTIFIED BY 'oracle';
dbadmin=> GRANT USAGE ON SCHEMA PUBLIC TO Qwz;
将Oracle数据库的DB Time查询导入Vertica数据库
- 将Oracle数据库的DB Time的两个SQL查询分别保存为CSV文件
- 将两个CSV文件上传到服务器/home/dbadmin目录下
- 用DBeaver 21.3.1客户端工具连接到Vertica数据库
- 在DBeaver 21.3.1上创建两张表awr_dbtime和awr_dbtime_2
- 将两个CSV文件分别导入刚创建的两张表中
将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小时,按每分钟间隔)
- 用Tableau可视化表awr_dbtime(最近31天,按每小时间隔)
- 用Tableau可视化表awr_dbtime(最近31天,按每天间隔)
用Tableau连接Vertica数据库
用Tableau可视化表awr_dbtime_2(最近1小时,按每分钟间隔)
在连接成功Vertica数据库以后,首先选择架构(这里翻译得可能有误,应该叫schema)public,然后将表awr_dbtime_2拖动到指定的位置,单击底部的“工作表1”,顺次见如下两图:
接着,我们按照简单的五个步骤来进行可视化表awr_dbtime_2,这个表里包含按每分钟间隔的最近1小时的DB Time取值。每个步骤的屏幕截图依次如下所示:
最后,我们用鼠标移动到一个对应的标签上面,它会显示具体的快照时间和DB Time取值,效果如下图:
至此,最近1小时的DB Time(按每分钟间隔)的折线图已经制作完成。另外,Tableau可以将其导出并保存为PDF或PowerPoint格式的文件。
用Tableau可视化表awr_dbtime(最近31天,按每小时间隔)
和前面的可视化表awr_dbtime_2的方法相同,在此省略一些设置步骤,直接附上最终的折线图。
用Tableau可视化表awr_dbtime(最近31天,按每天间隔)
同样的思路和方法,最终的效果图如下所示:
以上就是这篇博客文章的全部内容,欢迎朋友们在评论区提出您的宝贵意见或建议,我将认真阅您的反馈信息,并尽快逐一回复,谢谢!
参考内容
- 什么是Vertica数据库?
- Quickstart Guide from the official documentation of Vertica 11.0.x
- HINT (S0305)
- WARN (N0010)
- WARN (S0112)
- FAIL (S0312)
- DBeaver Community Edition 21.3.1
- Using This Guide from the official documentation of Vertica 11.0.x
- Tableau Desktop 2021.4.1
- Oracle导入csv文本文件到Vertica
- Visual output in Vertica
- Tableau生成折线图
更新于 2021年12月18日 晚上:
您也可以在我的GitHub上找到如何查询Oracle数据库最近31天的DB Time(按每小时间隔)和最近1小时的DB Time(按每分钟间隔)。