- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
你们中有人了解 weblogic.socket.Muxer 在 WebLogic 8.1 中的用途吗?
我经常在线程转储中看到与此类似的堆栈跟踪:
"ExecuteThread: '0' for queue: 'weblogic.socket.Muxer'" id=20 idx=0x68 tid=26709 prio=5 alive, in native, blocked, daemon
-- Blocked trying to get lock: java/lang/String@0x2b673d373c50[fat lock]
at jrockit/vm/Threads.waitForUnblockSignal()V(Native Method)
at jrockit/vm/Locks.fatLockBlockOrSpin(Locks.java:1675)[optimized]
at jrockit/vm/Locks.lockFat(Locks.java:1776)[optimized]
at jrockit/vm/Locks.monitorEnterSecondStageHard(Locks.java:1312)[optimized]
at jrockit/vm/Locks.monitorEnterSecondStage(Locks.java:1259)[optimized]
at jrockit/vm/Locks.monitorEnter(Locks.java:2439)[optimized]
at weblogic/socket/EPollSocketMuxer.processSockets(EPollSocketMuxer.java:153)
at weblogic/socket/SocketReaderRequest.run(SocketReaderRequest.java:29)
at weblogic/socket/SocketReaderRequest.execute(SocketReaderRequest.java:42)
at weblogic/kernel/ExecuteThread.execute(ExecuteThread.java:145)
at weblogic/kernel/ExecuteThread.run(ExecuteThread.java:117)
at jrockit/vm/RNI.c2java(JJJJJ)V(Native Method)
-- end of trace
这并不是我有任何问题,只是想了解一下:
1) 它在做什么?
2) 它会影响任何性能吗?
最佳答案
来自文档(http://download.oracle.com/docs/cd/E13222_01/wls/docs100/perform/WLSTuning.html#wp1152246):
WebLogic Server uses software modules called muxers to read incoming requests on the server and incoming responses on the client. These muxers are of two primary types: the Java muxer or native muxer.
A Java muxer has the following characteristics:
- Uses pure Java to read data from sockets.
- It is also the only muxer available for RMI clients.
- Blocks on reads until there is data to be read from a socket. This behavior does not scale well when there are a large number of sockets and/or when data arrives infrequently at sockets. This is typically not an issue for clients, but it can create a huge bottleneck for a server.
Native muxers use platform-specific native binaries to read data from sockets. The majority of all platforms provide some mechanism to poll a socket for data. For example, Unix systems use the poll system and the Windows architecture uses completion ports. Native provide superior scalability because they implement a non-blocking thread model. When a native muxer is used, the server creates a fixed number of threads dedicated to reading incoming requests. BEA recommends using the default setting of selected for the
Enable Native IO
parameter which allows the server automatically selects the appropriate muxer for the server to use.If the
Enable Native IO
parameter is not selected, the server instance exclusively uses the Java muxer. This maybe acceptable if there are a small number of clients and the rate at which requests arrive at the server is fairly high. Under these conditions, the Java muxer performs as well as a native muxer and eliminate Java Native Interface (JNI) overhead. Unlike native muxers, the number of threads used to read requests is not fixed and is tunable for Java muxers by configuring thePercent Socket Readers
parameter setting in the Administration Console. See Changing the Number of Available Socket Readers. Ideally, you should configure this parameter so the number of threads roughly equals the number of remote concurrently connected clients up to 50% of the total thread pool size. Each thread waits for a fixed amount of time for data to become available at a socket. If no data arrives, the thread moves to the next socket.
那么,出于这些原因,使用 native 混合器显然更好。
在这里,看起来您使用的是默认的 native 多路复用器 (weblogic.socket.EPollSocketMuxer
),而不是 Java 多路复用器 (weblogic.socket.SocketMuxer)
。
关于java - 什么是 weblogic.socket.Muxer?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1623692/
我正在尝试在 weblogic (10.3.2.0) 中创建和加载动态类。这是我部署到 weblogic 服务器的 ADF 应用程序。 当我打印时 ((GenericClassLoader)this.
我正在尝试使用 weblogic 部署计划将 init-param 值添加到供应商提供的 .war 文件的 web.xml。 虽然我意识到我可以打开 .war 文件并只在其中编辑文件,但我更喜欢使用部
当我尝试从本地计算机启动 weblogic 服务器(在另一台服务器上运行)时,出现以下错误。我可以毫无问题地停止这个 weblogic 服务器,但我无法启动。 boot.properties 文件中有
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
如果我想在网页中显示图像,并且其 src 是上下文根之外的文件。在 IDE 中,图像显示为已加载。 但是当我测试网页时,没有任何显示。如何配置 weblogic 服务器以允许显示图像。如果没有,无论如
我知道我们用于 WebLogic 的 4 个配置文件: web.xml weblogic.xml weblogic-application.xml 应用程序.xml 使用这些文件的目的是什么? 最佳答
我需要一个自定义属性来为 Weblogic 中的每个服务器 JVM 设置。什么是更好的方法呢? 我知道我们可以指定如下参数: 在域结构 Pane 中,展开服务器节点。 单击要配置的服务器的名称。 在右
我需要使用哪些 URL、端口和 weblogic 服务器端设置? 最佳答案 这取决于您是否要连接到 WebLogic MBean 服务器(域、运行时、编辑)或平台 (JDK) MBean 服务器(请参
当我使用已部署的应用程序启动 Weblogic 实例时,部署有时处于准备状态,而不是事件状态。我必须转到 Weblogic 控制台并手动启动部署,这是相当缓慢且烦人的重复工作。由于这是在开发计算机上完
我想在我的 Web 应用程序中访问在 Weblogic 的自定义 keystore 配置中配置的身份 keystore (JKS)。如何让 weblogic 在不依赖以下环境属性的情况下公开此内容:-
我在我的 mac 机器上运行 Weblogic 10.3 的托管实例。有一天,我尝试启动它,但收到此错误消息 * **
我需要为 Weblogic 中的每个服务器 JVM 设置一个自定义属性。更好的方法是什么? 我知道我们可以指定如下参数: 在“域结构” Pane 中,展开“服务器”节点。 单击要配置的服务器的名称。
当我运行 WLST 脚本 .sh 脚本来设置环境时,为什么在回显时看不到更新的路径? [linbox2 bin]$ ./setWLSEnv.sh CLASSPATH=/directory/ols_wl
我有一个 WebLogic 集群,在该集群上部署了许多主题和使用它们的应用程序。我的应用程序统一显示为警告状态。查看部署中的监控,我看到 MDB 应用程序连接到服务器 #1,但在服务器 #2 上显示如
我想切换到 CentOS 来运行当前部署在 RHEL 下的 WebLogic 11g。人们在 CentOS 上运行 WebLogic 11g 时是否遇到过任何我应该注意的问题? 最佳答案 大约三年前,
我一直在尝试将我们的 Activiti 实现重构为使用 CDI,但遇到了许多问题。我已经花了太多时间试图解决这个问题,但我就是不能放手......我想我现在已经解决了这个问题,在不涉及 Activit
我正在编写代码以在 weblogc 上启动、停止、取消部署和部署我的应用程序。 我的组件需要部署在少数托管服务器上。 当我手动进行新部署时,我可以通过勾选多个框并从下拉菜单中选择启动和停止来并行启动和
我无法从 jdevloper 创建 weblogic 域! 我正在使用 Jdevloper 12.1.2(12c),当我尝试在默认集成 weblogic 服务器 上创建域时,会出现这样的错误 - wl
使用 Weblogic 11g 并希望能够向 weblogic 提供的所有文件添加 header 。 weblogic 前面没有单独的 Web 服务器。找不到配置 weblogic 向 HTTP 响应
我正在尝试将 Jprofiler7 连接到远程 weblogic10.3 托管服务器。我能够在 JProfiler 中连接并查看管理控制台线程和内存使用情况,但不能查看部署在托管服务器上的应用程序。
我是一名优秀的程序员,十分优秀!