发布于: Oct 14, 2022
要连接您的集群:
- 使用 Amazon Redshift 控制台上的左侧导航窗格导航至查询编辑器。
- 在集群下拉列表中的凭证对话框中,选择集群名称 (demo-cluster)。为此集群选择数据库和数据库用户。
- 如果您使用服务提供的默认值创建了集群,请将 dev 选为您的数据库选择,并在数据库用户框中输入:
awsuser
4.为集群输入密码。通常情况下,Amazon Redshift 数据库用户通过提供数据库用户名和密码进行登录。作为替代方法,如果您忘记了密码,您可以通过选择创建临时密码以加密格式检索密码,如下面的示例所示。有关更多信息,请参阅使用 IAM 身份验证生成数据库用户凭证。
如果您拥有 Amazon Web Services 账户的查询编辑器相关权限,这将会连接到集群。有关更多信息,请参见前一部分中将查询编辑器相关权限添加到 Amazon Web Services 账户的步骤。
要使用示例数据集准备集群:
- 在查询编辑器中运行以下 SQL。这将会在 Amazon Redshift 集群 demo-cluster 中创建架构 myinternalschema。
/* 创建架构 */CREATE SCHEMA myinternalschema
2.在查询编辑器中运行以下 SQL 语句,以为架构 myinternalschema 创建表。
/* 创建表 */CREATE TABLE myinternalschema.event( eventid integer not null distkey, venueid smallint not null, catid smallint not null, dateid smallint not null sortkey, eventname varchar(200), starttime timestamp);
3. 使用 COPY 命令运行以下 SQL 语句,以在 us-east-1 区域中将示例数据集从 Amazon S3 复制到您的 Amazon Redshift 集群 demo-cluster 中。示例数据集的 Amazon S3 路径为
s3://aws-redshift-spectrum-sample-data-us-east-1/spectrum/event/allevents_pipe.txt。
选择运行查询之前,记得把示例中的占位符替换为与此 Amazon Web Services 账户相关的 IAM 角色的 ARN。如果您的集群在另一个 Amazon Web Services 区域中,请替换区域参数中的 Region 和 Amazon S3 路径,如下面的 SQL 命令所示:
/* 加载数据 */ COPY myinternalschema.event FROM 's3://aws-redshift-spectrum-sample-data-us-east-1/spectrum/event/allevents_pipe.txt' iam_role ‘REPLACE THIS PLACEHOLDER WITH THE IAM ROLE ARN' delimiter '|' timeformat 'YYYY-MM-DD HH:MI:SS' region 'us-east-1';
- 要确保可以访问 Amazon S3 中的公共数据集,请确保此 Amazon Web Services 账户具有能访问 Amazon S3、Amazon Glue 和 Athena 的正确权限。有关更多信息,请参阅此博文前面所述的在示例数据集(Amazon S3 和 Amazon Glue/Amazon Athena 数据目录权限)中加载和运行查询的步骤。
- 要在查询编辑器中验证以前创建的表中的数据,请浏览左侧架构查看器中的表。选择表名称旁的预览图标,以查看事件表中前 10 个记录。选择此选项将运行表格预览的以下查询,从而显示表中的 10 行内容:
/* 在 myinternalschema 中查看相同数据集的一个片段 */ SELECT * FROM myinternalschema.eventLIMIT 10;
您也可以输入自己的 SQL 语句。使用 Ctrl + Space 在查询编辑器中自动完成查询,以验证您创建的表中的数据。
您已准备好尝试 Amazon Redshift 了! 在日常集群管理和监控中,您可以在查询编辑器中运行以下 SQL 查询。这些常用查询可让您查找并管理长期运行的查询、发现死锁状况并检查您的 Amazon Redshift 集群上的可用磁盘空间。通过在控制台的左侧导航窗格中选择保存的查询来保存这些查询并方便地访问它们,如下面的示例所示:
消除集群上的故障或长期运行的查询
如果存在必须要关闭的故障查询,通常要经过多步骤过程才能找到查询。在查询编辑器中运行以下 SQL 以查找使用 SQL 语句在 Amazon Redshift 集群中运行的所有查询:
/* 目前正在进行查询 */ SELECT userid , query , pid , starttime , left(text, 50) as textFROM pg_catalog.stv_inflight
从查询结果集中找到故障查询后,使用取消 <pid> <msg> 命令来消除查询。务必使用过程 ID(在以前的 SQL 中为 pid)而非查询 ID。您可以提供一个可选消息,该消息将返回至查询发布者并被记录。
监测集群上使用的磁盘空间
最常用的控制台功能之一是监测集群所用磁盘空间的百分比。如果集群中用于创建查询运行时使用的临时表的空间有限,查询将会失败。如果集群中没有可用空间在集群恢复过程中存储中间数据,Vacuum 也可能会失败。监测此指标对于在集群满载之前进行计划很重要,且您必须调整集群大小或添加更多集群。
如果您怀疑您的 Amazon Redshift 磁盘使用量过高或已满,请在查询编辑器中运行以下 SQL,以查找可用磁盘空间并查看集群上的各个表大小:
/* 您的 Redshift 集群上的可用磁盘空间 */SELECT SUM(used)::float / SUM(capacity) as pct_fullFROM pg_catalog.stv_partitions /* 查找各个表大小 */SELECT t.name, COUNT(tbl) / 1000.0 as gbFROM (SELECT DISTINCT id, name FROM stv_tbl_perm) tJOIN stv_blocklist ON tbl=t.idGROUP BY t.name ORDER BY gb DESC
您可以从这里删除不必要的表,或者调整集群的大小以获得更大的容量。有关更多信息,请参阅调整 Amazon Redshift 中的集群大小。
观察集群上可疑的长时间运行更新有无发生死锁状况
如果集群发生可疑的长时间运行更新,它可能处于死锁事务中。stv_locks 表中显示了已锁定的任何事务,以及相关会话的过程 ID。此 pid 可以传递到 pg_terminate_backend(pid) 中,以消除有问题的会话。
在查询编辑器中运行 SQL 语句,以检查锁定情况:
\/* 查找已锁定且具有相关会话过程 ID 的所有事务 */ select table_id, last_update, last_commit, lock_owner_pid, lock_status FROM pg_catalog.stv_locks ORDER BY last_update asc
要关闭会话,请使用 stl_locks 中的值运行 select pg_terminate_backend(lock_owner_pid)。
查看受集群最新 Vacuum 影响的行
通过在集群中的表上运行 Vacuum 命令,可以回收由于删除和更新操作而产生的任何可用空间。同时,表中的数据将被排序。结果将产生紧凑型排序表,从而提高集群性能。
运行以下 SQL 语句以查看从 svv_vacuum_summary 表的最新 Vacuum 中删除或存储的行的计数:
/* 从最近的 Vacuum 中删除或恢复的行 */* 从 svv_vacuum_summary 中选择 其中 table_name = 'events'
调试 Amazon Redshift 集群的连接问题
加入 stv_sessions 和 stl_connection_log 表会返回所有会话的列表(集群上的所有连接、身份验证和断开连接)及各自的远程主机和端口信息。
要列出所有连接,请在查询编辑器中运行以下 SQL 语句:
/* 列出连接以及远程主机信息 */ SELECT DISTINCT starttime, process, user_name, '169.254.21.1' remotehost, remoteportFROM stv_sessionsLEFT JOIN stl_connection_log ON pid = process AND starttime > recordtime - interval '1 second'ORDER BY starttime DESC
使用保存的查询功能将这些常用的 SQL 语句保存在您的账户中,并在查询编辑器中单击一下运行它们。
使用 Amazon Redshift Spectrum,您可以在 Amazon S3 中查询数据,无需首先将其加载到 Amazon Redshift 中。Amazon Redshift Spectrum 查询采用大量并行处理 S3 中的大型数据集,无需将该数据提取到 Amazon Redshift 中。大部分处理发生在 Amazon Redshift Spectrum 层。多个集群可以同时查询 Amazon S3 中的同一个数据集,无需对每个集群的数据进行复制。
要使用 Amazon Redshift Spectrum 进行设置,请在查询编辑器中为 demo-cluster 运行以下 SQL 语句。如果您的集群在另一个 Amazon Web
Services 区域中,务必替换区域参数中的 Region 和以下 SQL 语句中的 Amazon S3 路径。
要从数据目录中创建新架构以与 Amazon Redshift Spectrum 结合使用:
/* 创建外部 (Amazon S3) 架构 */CREATE EXTERNAL SCHEMA myexternalschemafrom data catalogdatabase 'myexternaldatabase' region 'us-east-1' iam_role 'REPLACE THIS PLACEHOLDER WITH THE IAM ROLE ARN' create external database if not exists;
要为 Amazon Redshift Spectrum S3 示例数据集创建表:
/* 创建外部表 */CREATE EXTERNAL TABLE myexternalschema.sales( salesid integer, listid integer, sellerid integer, buyerid integer, eventid integer, dateid smallint, qtysold smallint, pricepaid decimal(8,1), commission decimal(8,1), saletime timestamp)row format delimitedfields terminated by '\t' stored as textfile 位置 's3://aws-redshift-spectrum-sample-data-us-east-1/spectrum/sales/' 表属性 ('numRows'='171000');
此部分提供开始从外部 (Amazon S3) 销售表和内部 (Amazon Redshift) 事件表中查询数据的示例场景。在此场景下加入查询将查找销售价格已支付 > 50(从 Amazon S3 中的 Amazon Redshift Spectrum 数据集中,
s3://aws-redshift-spectrum-sample-data-us-east-1/spectrum/sales/
)的所有事件(从 demo-cluster 上加载的销售数据集中)。
/* 将样本数据集中的表加入 Spectrum 表中 *//* 加入外部 (Amazon S3) 和内部 (Amazon Redshift) 表 */SELECT myexternalschema.sales.eventid, sum(myexternalschema.sales.pricepaid) from myexternalschema.sales, myinternalschema.event where myexternalschema.sales.eventid = myinternalschema.event.eventid and myexternalschema.sales.pricepaid > 50 group by myexternalschema.sales.eventid order by 1 desc;
在查询结果部分中,选择查看执行以查看详细的执行计划。查询计划可用于在计算节点上执行的所有查询。
注:未参考用户表的查询,如只使用目录表的管理查询,没有可用的查询计划。
或者,可以将查询结果下载到您的本地磁盘中供离线使用。查询在查询编辑器中最多运行三分钟。查询完成后,查询编辑器将提供两分钟来获取结果。如果您达到了两分钟的阈值,请返回查询并重试。
通过使用以下 SQL 语句从 Amazon Redshift 示例数据集中加载其他表格,然后创造性地进行查询。在查询编辑器中选择运行查询之前,请记住在以下 SQL 语句的占位符中添加与此 Amazon Web Services 账户相关的 IAM 角色的 ARN。如果您的集群处于另一个 Amazon Web Services 区域中,请替换区域参数中的 Region 和以下 SQL 语句中的 Amazon S3 路径。
从 's3://awssampledbuswest2/tickit/allusers_pipe.txt' 中复制用户 凭证 'aws_iam_role=REPLACE THIS PLACEHOLDER WITH THE IAM ROLE ARN' delimiter '|' region 'us-west-2'; 从 's3://awssampledbuswest2/tickit/venue_pipe.txt' 中复制会场 凭证 'aws_iam_role=REPLACE THIS PLACEHOLDER WITH THE IAM ROLE ARN' delimiter '|' region 'us-west-2'; 从 's3://awssampledbuswest2/tickit/category_pipe.txt' 中复制类别 凭证 'aws_iam_role=REPLACE THIS PLACEHOLDER WITH THE IAM ROLE ARN' delimiter '|' region 'us-west-2'; 从 's3://awssampledbuswest2/tickit/date2008_pipe.txt' 中复制日期 凭证 'aws_iam_role= REPLACE THIS PLACEHOLDER WITH THE IAM ROLE ARN' delimiter '|' region 'us-west-2'; 从 's3://awssampledbuswest2/tickit/listings_pipe.txt' 中复制列表 凭证 'aws_iam_role= REPLACE THIS PLACEHOLDER WITH THE IAM ROLE ARN' delimiter '|' region 'us-west-2'; 从 's3://awssampledbuswest2/tickit/sales_tab.txt' 中复制销售 凭证 'aws_iam_role= REPLACE THIS PLACEHOLDER WITH THE IAM ROLE ARN'delimiter '\t' timeformat 'MM/DD/YYYY HH:MI:SS' region 'us-west-2';
在此博文中,我们介绍了查询编辑器,它是一个浏览器内界面,用于在 Amazon Redshift 集群上运行 SQL 查询。我们向您展示了如何使用它运行 SQL 查询以将数据加载到集群中及直接从控制台中监控集群性能。要详细了解 Amazon Redshift 并开始使用查询编辑器,请访问 Amazon Redshift 网页。
如果您喜欢此功能,如下所示通过使用控制台上的发送反馈链接分享您的反馈。
相关文章