使用DBX运行脚本

时间:2011-09-27 10:41:31

标签: unix solaris dbx

我有这样的剧本 脚本 = GF1_dd_Daemon_Sh PROCESS_NAME = RG INSTANCE = RG PART_ID = 1

在这里面有一个被调用的可执行文件。当我运行这个脚本(#!/ bin / ksh )时,它会创建一个核心转储并在分析堆栈跟踪时使用dbx,我无法获得任何信息。

有没有办法使用DBX运行脚本,并且可以跟踪可执行文件创建核心转储的位置。

我正在使用 SOLARIS。

感谢。

堆栈跟踪

  (dbx) where
    current thread: t@1
      [1] xercesc_2_6::SAXParser::SAXParser(0xffffffff70b833b8, 0xffffffff70b83480, 0x0, 0x0, 0xffffffff70b833f8, 0xffffffff7d12ccd8), at 0xffffffff7ce22fc0
    =>[2] __SLIP.INIT_D() (optimized), at 0xffffffff70a447b8 (line ~35) in "Parser.h"
      [3] __STATIC_CONSTRUCTOR() (optimized), at 0xffffffff70a46f04 (line ~35) in "Parser.h"
      [4] 0xffffffff70a74718(0xffffffff7f7361b8, 0xffffffff7f738d60, 0x11a340, 0x0, 0xffffffff7f736c60, 0x821), at 0xffffffff70a74718
      [5] call_init(0xffffffff7f736530, 0x1, 0xffffffff70a74618, 0xffdfffff, 0xffffffff7f736c60, 0xffffffffffffffff), at 0xffffffff7f618674
      [6] dlmopen_intn(0xffffffff7ffe6b0c, 0x8, 0x4a, 0x52, 0xffffffff7ffe6b0c, 0xffffffff77800a60), at 0xffffffff7f61df7c
      [7] dlmopen_check(0xffffffff7f7361b8, 0xffffffff7ffe6c18, 0x1, 0xffffffff7f400ef0, 0xffffffff7ffe6b0c, 0x118cc8), at 0xffffffff7f61e0f0
      [8] _dlopen(0xffffffff7ffe6c18, 0x1, 0x1, 0xffffffff7ea56d30, 0x11, 0xffffffff7fffc226), at 0xffffffff7f61e130
      [9] GMF_sfg_ACTIVITY(i_pgmName = ???, i_instance = ???, i_coreReplaceRegister_func_p = ???) (optimized), at 0xffffffff7e926ff0 (line ~200) in "GMF_sfg_ACTIVITY.c"
      [10] GMF_mdg_EXECinit(i_pcProcessName = ???, i_argc = ???, i_argv = ???) (optimized), at 0xffffffff7eb33394 (line ~556) in "GMF_mdg_EXECinit.c"
      [11] GMF_mdg_EXECmain(argc = ???, argv = ???) (optimized), at 0xffffffff7eb25ae8 (line ~163) in "GMF_mdg_EXECfunc.c"
      [12] main(argc = ???, argv = ???) (optimized), at 0x100001eb8 (line ~52) in "GMF_mdg_EXECproc.c"
    (dbx) down
    0xffffffff7ce22fc0: SAXParser+0x0110:   ldx      [%i2], %o3

2 个答案:

答案 0 :(得分:0)

  1. 在脚本内部检查传递的参数是什么 到可执行文件(二进制)。
  2. 使用该可执行文件启动dbx
  3. 开始后设置你在步骤1中发现的参数
  4. 停在GMF_mdg_EXECmain
  5. 然后开始检查代码流程

答案 1 :(得分:0)

一种常见的方法是在脚本中添加一个名为$ DEBUGGER

的变量
#!/bin/sh
echo "this is the script"
$DEBUGGER the_executable arg1 arg2

如果将DEBUGGER环境变量设置为“dbx”,那么当您运行脚本时, dbx将启动,它将为您提供dbx提示符。

如果您正在使用Solaris Studio IDE,则可以使用“ss_attach”而不是“dbx”,它会将调试会话附加到已在运行的IDE。

查看ss_attach的手册页。