[分享]虚拟机下使用oprofile报错Failed to open profile device: Operation not permitted的解决 _MySQL, Oracle及数据库讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  MySQL, Oracle及数据库讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 2088 | 回复: 0   主题: [分享]虚拟机下使用oprofile报错Failed to open profile device: Operation not permitted的解决         下一篇 
malu
注册用户
等级:列兵
经验:90
发帖:5
精华:0
注册:2014-4-29
状态:离线
发送短消息息给malu 加好友    发送短消息息给malu 发消息
发表于: IP:您无权察看 2014-11-13 14:33:52 | [全部帖] [楼主帖] 楼主

这是帮其他团队的同学解决的一个问题.这里做个记录.

问题描述:

    Nginx作为前端HttpServer
    使用HttpProxy与JBoss进行连接
    在上传比较大的文件时,JBoss已经返回结果,但是Nginx不立即将结果返回给浏览器,直到Nginx的HttpProxy与JBoss因为超时而断开后才返回结果给浏览器
    这样导致的结果就是用户觉得上传文件需要很长时间.

问题原因分析:

    Nginx HttpProxy转发的请求是Http 1.0的,就是说是不支持Keep-Alive的,那么也就是说只有当JBoss主动断开与HttpProxy的连接,或是超时被动断开,Nginx才认为这个请求已经完结了.
    在看一下业务代码,因为在上传处理逻辑中会先进行一些前置判断,一旦判断失败,会不读取上传的文件然后直接返回一个Failed的Response回去,而这个时候就会出现上述的问题.
    用Wireshark抓包分析HttpProxy与JBoss之间的通信发现,当JBoss一返回Response之后Nginx就会立马停止向JBoss Post数据,但是JBoss这个时候却不会断开与Nginx的连接.
    再分析一下JBoss(即Tomcat)的对于endRequest的源码:
        在当Tomcat处理完servlet后在org.apache.coyote.http11.Http11AprProcessor#endRequest的过程当中org.apache.coyote.http11.filters.IdentityInputFilter#end 会去读完所有的Content-Length这个长度的请求后才会Close连接,但是这个时候Nginx已经停止Post了,那么org.apache.coyote.http11.filters.IdentityInputFilter#end 取不到要取的数据就只有等待soTimeout(即配置的connectionTimeout)之后才超时断开连接,这个时候Nginx才会返回response给真正的Client
    原因就是因为Nginx的处理和JBoss的处理不兼容引起的
        Nginx认为JBoss已经返回Response了,就没有必要再需要继续Post数据了
        JBoss比较死板,就算你在Servlet中没有全读完整个Request,也会在Servlet之后的org.apache.coyote.http11.Http11AprProcessor#endRequest里读完整个Content-Length长度的请求

问题解决:

    需要在Servlet里面读完整个Request,或用一个Filter来读完也可以

--转自 北京联动北方科技有限公司




赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论