返回首页

gbase数据、南大通用产品文档:GBase8a

更新日期:2024年09月11日

GBA-01BR-0063
错误码
错误标识
错误显示信息
GBA-01BR-0063

read DC data file Error
错误出现原因
读取数据文件错误
分析与建议
检查数据文件的权限及状态

配置文件

GBase 8a MPP Cluster 产品手册
4 管理员指南
文档版本953(2022-09-15)
南大通用数据技术股份有限公司
158
在$GCWARE_BASE/config/gcware_monit.conf 配置文件中,可以查看和修改
gcware_monit 的基本配置。
配置文件格式说明
[TagName]
fail2ok_trigger_cmd=
prog_name=
ok2fail_trigger_cmd=""
[common]
log_flag=
retry_times=
interval=
log_file=""
表4- 9 参数说明
参数名称


TagName
要监控的服务程序名称。
fail2ok_trigger_cmd
监测程序由stopped 到running 状态后需要执行的命令行方法。
可选设置项,用户可以依照需求来进行设置。如果发现设置
存在异常(如重复设置,设置值有误等),gcware_monit 程
序将报错退出。
prog_name
指定了服务程序对应的具体进程名称,必须在配置文件中指
定。如果没有指定,gcware_monit 程序将报错退出。
ok2fail_trigger_cmd
被监测程序由running 到stopped 状态后,
或者是在retry_times
内的stopped 到stopped,需要执行的命令行方法。可选设置
项,用户可以依照需求来进行设置。如果发现设置存在异常
(如重复设置,设置值有误等),gcware_monit 程序将报错
退出。
common
通用设置节点标签,此标签下的配置为gcware_monit 程序配
置。
log_flag
gcware_monit 程序启动过程中是否生成log 文件。
1 表示生成
log 信息;0 表示不生成log 信息。默认值为1。
retry_times
gcware_monit 启动被监测程序的连续失败次数,设置内容为
非负整数。最小值为0,代表无限重试;最大值为64。
interval
gcware_monit 的检测服务程序的时间间隔,设置内容为正整
数。单位为秒。最小值为1,最大值为3600。
log_file
gcware_monit 日志文件的绝对路径,如果没有指定,程序将
报错退出。
示例
gcware_monit 的配置文件$GCWARE_BASE/config/gcware_monit.conf 内容参考如
下:

GBase 8a MPP Cluster 产品手册
4 管理员指南
文档版本953(2022-09-15)
南大通用数据技术股份有限公司
159
$ cat $GCWARE_BASE/config/gcware_monit.conf
[gcware]
fail2ok_trigger_cmd=""
prog_name=gcware
ok2fail_trigger_cmd="/opt/192.168.146.22/gcware/sbin/gcware start"
[common]
log_flag=1
retry_times=10
interval=5
log_file="/opt/192.168.146.22/gcware/log/gcware_monit.log"
[gcware_mmonit]
fail2ok_trigger_cmd=""
prog_name=gcware_mmonit
ok2fail_trigger_cmd="/opt/192.168.146.22/gcware/sbin/gcware_mmonit --start"

当您使用由程序逻辑补充的游标时,您可解决普通的 SQL 不可解决的问题。这些问题之
一就是部件爆炸问题,有时称为材料单处理。此问题的核心是对象之间的递归关系;一个
对象包含其他对象,其又包含其他对象。
通常以制造库存为例来说明该问题。例如,公司制造各种部件。有些部件是分立的,但有
些是其他部件的组合。
在可能称为 contains 的单个表中说明这些关系。列 contains.parent 持有系组合的部件的部件
编号。列 contains.child 具有为父部件的组件的部件的部件编号。如果部件编号 123400 是
九个部件的组合,则存在九行,123400 在第一列中,其他部件编号在第二列中。下图展示
描述部件编号 123400 的多行中的一行。
图: 部件爆炸问题


部件爆炸问题在于:给定一个部件编号,产生为那个部件的组件的所有部件的列表。下列
示例是一种解决方案的概要,如以 GBase 8s ESQL/C 实现的那样:
int part_list[200];

boom(top_part)
int top_part;
{
long this_part, child_part;
int next_to_do = 0, next_free = 1;
part_list[next_to_do] = top_part;

EXEC SQL DECLARE part_scan CURSOR FOR
SELECT child INTO child_part FROM contains

GBase 8s SQL 指南:教程
南大通用数据技术股份有限公司
- 222 -
WHERE parent = this_part;
while(next_to_do < next_free)
{
this_part = part_list[next_to_do];
EXEC SQL OPEN part_scan;
while(SQLCODE == 0)
{
EXEC SQL FETCH part_scan;
if(SQLCODE == 0)
{
part_list[next_free] = child_part;
next_free += 1;
}
}
EXEC SQL CLOSE part_scan;
next_to_do += 1;
}
return (next_free - 1);
}
从技术上讲,contains 表的每一行都是有向无环图,或树,的头结点。该函数执行对该树的
宽度优先搜索,树根是作为它的参数传递的部件编号。该函数使用名为 part_scan 的游标返
回在 parent 列中带有特定的值的所有行。最内层的 while 循环打开 part_scan 游标,在选择
集中访存每一行,并当已检索了每一组件的部件编号时,关闭该游标。
此函数解决部件爆炸问题的核心,但该函数不是完整的解决方案。例如,它不允许组件在
树中出现多个级别。此外,实际的 contains 表还会有列count,给出在每一 parent 中使用
的 child 部件的计数。返回每一组件部件的总计数的程序要复杂得多。
之前描述的迭代方法不是解决部件爆炸问题的唯一方法。如果代的数目有固定的限制,则
您可使用嵌套的外部自连接,以单个 SELECT 语句解决该问题。
如果在一个最高级别部件内,可包含最多四代部件,则下列 SELECT 语句返回所有部件:

SELECT a.parent, a.child, b.child, c.child, d.child
FROM contains a
OUTER (contains b,
OUTER (contains c, outer contains d) )
WHERE a.parent = top_part_number
AND a.child = b.parent
AND b.child = c.parent

GBase 8s SQL 指南:教程
南大通用数据技术股份有限公司
- 223 -
AND c.child = d.parent
此 SELECT 语句为来源于指定为 top_part_number 的祖先的每一行返回一行。对于不存在
的级别,返回 Null 值。
(请使用指示符变量来检测它们。)要将此解决方案扩展到更多级
别,请选择 contains 表的附加的嵌套外部连接。您还可修订此解决方案来返回每一级别上
部件的数目的计数。