记一次DM8 Manager管理工具启动异常问题

环境:CentOS7.3 64位 + DM8数据库

首先按照官网要求安装完数据库,一开始还可以正常打开管理工具,过了一段时间后发现用dmdba登录manager管理工具异常,具体如下截图:

null

 具体报错内容如下:

[dmdba@localhost tool]$ ./manager



(Manager:3952): GLib-GObject-WARNING **: invalid (NULL) pointer instance



(Manager:3952): GLib-GObject-CRITICAL **: g_signal_connect_data: assertion 'G_TYPE_CHECK_INSTANCE (instance)' failed



(Manager:3952): Gtk-CRITICAL **: IA__gtk_settings_get_for_screen: assertion 'GDK_IS_SCREEN (screen)' failed



(Manager:3952): Gtk-WARNING **: Screen for GtkWindow not set; you must always set

a screen for a GtkWindow before using the window



(Manager:3952): Gtk-WARNING **: Screen for GtkWindow not set; you must always set

a screen for a GtkWindow before using the window



(Manager:3952): Gdk-CRITICAL **: IA__gdk_screen_get_display: assertion 'GDK_IS_SCREEN (screen)' failed



(Manager:3952): Gdk-CRITICAL **: IA__gdk_display_get_pointer: assertion 'GDK_IS_DISPLAY (display)' failed



(Manager:3952): Gdk-CRITICAL **: IA__gdk_screen_get_monitor_at_point: assertion 'GDK_IS_SCREEN (screen)' failed



(Manager:3952): Gtk-WARNING **: Screen for GtkWindow not set; you must always set

a screen for a GtkWindow before using the window



(Manager:3952): Gdk-CRITICAL **: IA__gdk_screen_get_n_monitors: assertion 'GDK_IS_SCREEN (screen)' failed



(Manager:3952): Gtk-WARNING **: Screen for GtkWindow not set; you must always set

a screen for a GtkWindow before using the window



(Manager:3952): Gdk-CRITICAL **: IA__gdk_screen_get_monitor_geometry: assertion 'GDK_IS_SCREEN (screen)' failed



(Manager:3952): Gdk-CRITICAL **: IA__gdk_screen_get_default_colormap: assertion 'GDK_IS_SCREEN (screen)' failed



(Manager:3952): Gdk-CRITICAL **: IA__gdk_colormap_get_visual: assertion 'GDK_IS_COLORMAP (colormap)' failed



(Manager:3952): Gdk-CRITICAL **: IA__gdk_screen_get_default_colormap: assertion 'GDK_IS_SCREEN (screen)' failed



(Manager:3952): Gdk-CRITICAL **: IA__gdk_screen_get_root_window: assertion 'GDK_IS_SCREEN (screen)' failed



(Manager:3952): Gdk-CRITICAL **: IA__gdk_screen_get_root_window: assertion 'GDK_IS_SCREEN (screen)' failed



(Manager:3952): Gdk-CRITICAL **: IA__gdk_window_new: assertion 'GDK_IS_WINDOW (parent)' failed

#

# A fatal error has been detected by the Java Runtime Environment:

#

#  SIGSEGV (0xb) at pc=0x00007f3127ed02b7, pid=3952, tid=139849844127488

#

# JRE version: OpenJDK Runtime Environment (8.0_20-b26) (build 1.8.0_20-b26)

# Java VM: OpenJDK 64-Bit Server VM (25.20-b23 mixed mode linux-amd64 compressed oops)

# Problematic frame:

# C  [libgdk-x11-2.0.so.0+0x7b2b7]  gdk_window_enable_synchronized_configure+0x7

#

# Failed to write core dump. Core dumps have been disabled. To enable core dumping, try "ulimit -c unlimited" before starting Java again

#

# An error report file with more information is saved as:

# /dm8/tool/hs_err_pid3952.log

#

# If you would like to submit a bug report, please visit:

#   http://bugreport.sun.com/bugreport/crash.jsp

# The crash happened outside the Java Virtual Machine in native code.

# See problematic frame for where to report the bug.

#

./manager: line 20:  3952 Aborted                 (core dumped) "$JAVA_HOME/bin/java" -Xms256m -Xmx2048m -XX:+PerfDisableSharedMem -DDM_HOME="$DM_HOME" -Djava.library.path="$DM_HOME/bin" -Ddameng.log.file="$TOOL_HOME/log4j.xml" -DeclipseHome="$TOOL_HOME" -Dosgi.nl="$INSTALL_LANGUAGE" -Ddameng.dts.explorer.root="$TOOL_HOME/workspace/local/dts" -Ddameng.isql.explorer.root="$TOOL_HOME/workspace/local/isql" -Duse_bak2=true -Dapp.name=manager -jar "$TOOL_HOME/plugins/org.eclipse.equinox.launcher_1.1.1.R36x_v20101122_1400.jar" -os linux -ws gtk -arch x86_64 -showsplash "$TOOL_HOME/manager.bmp" -data "$TOOL_HOME/workspace/manager" -product com.dameng.manager.product -name Manager

[dmdba@localhost tool]$ 

首先确认DM8数据库服务正常,可以通过disql登录;

null

其次根据上述报错“Screen for GtkWindow not set; you must always seta screen for a GtkWindow before using the window”提示的是图形化界面窗口设置异常,即问题属于图形化界面调用异常;

在Linux/Unix类操作系统上的GUI应用程序使用X Window系统(X Window System),它旨在允许多个用户使用窗口化的应用程序通过网络访问计算机。 DISPLAY环境变量用来设置将图形显示到何处。

然后我们确认当前环境设置的环境变量DISPLAY:

null

根据上面截图可以看出,root用户下DISPLAY变量是:0,而dmdba下查询发现变量为空,即不生效了,这里需要设置dmdba变量和root的一致,才能在dmdba用户下,启动manager时调用图形化界面;

xhost + 这个命令,是允许别的用户启动的图形程序将图形显示在当前屏幕上;

接下来我们发现,启动manager程序再次报错,这次则是提示“/dm8/tool/configuration/org.eclipse.osgi/.manager/.fileTableLock (Permission denied)”

首先我们先查看一下这个文件:

null

虽然暂时不知道这个文件是干什么的,但是发现configuration子目录下,好几个文件属主属组都已经变成root了;

正常情况下,我们创建达梦数据库的安装目录,下面所有的文件,属主属组都应该是dmdba:dinstall,而报错提示的也是fileTablelock文件锁相关的问题,这里推测是文件属性问题导致,修改属主属组测试:

null

chown -R dmdba:dinstall /dm8

后续启动发现再次报错DISPLAY的问题,查看发现DISPLAY变量再次被还原为空了,再次设置一遍

export DISPLAY=:0

xhost +

echo $DISPLAY

然后再次启动manager管理程序,问题解决;

null

针对DISPLAY变量失效问题,需要设置永久生效: 

vim .bashrc

把export DISPLAY=:0写入文件最下面,然后执行命令重新加载:

source .bashrc

null

 

关于/dm8下面的部分文件,属主属组发生改变,这个问题产生的原因还不太清楚,可能是实验中途切换成root执行过启动程序命令,导致生成root为属主属组的文件?原因待进一步探讨。

 

 

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值