免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1895 | 回复: 1
打印 上一主题 下一主题

Solaris 10 Oracle 连接问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-03-26 15:48 |只看该作者 |倒序浏览
以前是solaris9 oracle11g ,我的程序没有问题。
最近solaris升级到10,程序重新编译后,oracle 无法正常创建连接池

列出部分关键代码:

int DBConnPoolInit(int iConnNum)
{
   ...
  EXEC SQL ENABLE THREADS;
  for (i=0; i<iConnNum; i++)
   {
       tcx= malloc(sizeof(sql_context));
       EXEC SQL CONTEXT ALLOCATE :*tcx;

       if (database_connect(*tcx) != RETOK)
       {
           return RETKO;
       }
   }
   ...
}

int database_connect(sql_context ctx)
{
   ...
  EXEC SQL CONTEXT USE :ctx;
   EXEC SQL CONNECT :username IDENTIFIED BY :password;
   ...
}

经测试,第一次CONNECT成功了,程序block在第二次CONNECT,长时间无任何响应。
有没牛人帮忙指点一下?谢谢了~

论坛徽章:
0
2 [报告]
发表于 2008-03-26 17:53 |只看该作者
是我自己程序的错误,但也有点收获:

oracle10g以后CONNECT会通过子进程(线程)进行数据库链接。

如果程序里面对SIG_CHLD进行处理,回调函数会多次被调用。

我的程序就是回调函数里面有漏洞导致死锁,其实程序不是停在CONNECT上,是停在SIG_CHLD的回调函数上
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP