免费注册 查看新帖 |

Chinaunix

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

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

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-03-26 15:48 |只看该作者 |倒序浏览
以前是solaris9 oracle11g ,我的程序没有问题。\r\n最近solaris升级到10,程序重新编译后,oracle 无法正常创建连接池\r\n\r\n列出部分关键代码:\r\n\r\nint DBConnPoolInit(int iConnNum)\r\n{\r\n   ...\r\n  EXEC SQL ENABLE THREADS;\r\n  for (i=0; i<iConnNum; i++)\r\n   {\r\n       tcx= malloc(sizeof(sql_context));\r\n       EXEC SQL CONTEXT ALLOCATE :*tcx;\r\n\r\n       if (database_connect(*tcx) != RETOK)\r\n       {\r\n           return RETKO;\r\n       }\r\n   }\r\n   ...\r\n}\r\n\r\nint database_connect(sql_context ctx)\r\n{\r\n   ...\r\n  EXEC SQL CONTEXT USE :ctx;\r\n   EXEC SQL CONNECT :username IDENTIFIED BY :password;\r\n   ...\r\n}\r\n\r\n经测试,第一次CONNECT成功了,程序block在第二次CONNECT,长时间无任何响应。\r\n有没牛人帮忙指点一下?谢谢了~

论坛徽章:
0
2 [报告]
发表于 2008-03-26 17:53 |只看该作者
是我自己程序的错误,但也有点收获:\r\n\r\noracle10g以后CONNECT会通过子进程(线程)进行数据库链接。\r\n\r\n如果程序里面对SIG_CHLD进行处理,回调函数会多次被调用。\r\n\r\n我的程序就是回调函数里面有漏洞导致死锁,其实程序不是停在CONNECT上,是停在SIG_CHLD的回调函数上
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP