Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
O
Openfire
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Administrator
Openfire
Commits
b1dfb9c1
Commit
b1dfb9c1
authored
Aug 07, 2014
by
Dele Olajide
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #61 from jackrabbit128/master
Fix for OF-835
parents
fad60d88
18fffdac
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
56 additions
and
29 deletions
+56
-29
NIOConnection.java
src/java/org/jivesoftware/openfire/nio/NIOConnection.java
+4
-3
ConnectionManagerImpl.java
.../org/jivesoftware/openfire/spi/ConnectionManagerImpl.java
+52
-26
No files found.
src/java/org/jivesoftware/openfire/nio/NIOConnection.java
View file @
b1dfb9c1
...
...
@@ -372,9 +372,10 @@ public class NIOConnection implements Connection {
filter
.
setWantClientAuth
(
true
);
}
// TODO Temporary workaround (placing SSLFilter before ExecutorFilter) to avoid deadlock. Waiting for
// MINA devs feedback
ioSession
.
getFilterChain
().
addBefore
(
"org.apache.mina.common.ExecutorThreadModel"
,
"tls"
,
filter
);
//ioSession.getFilterChain().addAfter("org.apache.mina.common.ExecutorThreadModel", "tls", filter);
// MINA devs feedback. Note that ExecutorFilter is flanked by ReadThrottleFilterBuilder and we must not
// get in between them.
ioSession
.
getFilterChain
().
addBefore
(
"org.apache.mina.filter.ReadThrottleFilterBuilder.add"
,
"tls"
,
filter
);
//ioSession.getFilterChain().addAfter("org.apache.mina.filter.ReadThrottleFilterBuilder.release", "tls", filter);
ioSession
.
setAttribute
(
SSLFilter
.
DISABLE_ENCRYPTION_ONCE
,
Boolean
.
TRUE
);
if
(!
clientMode
)
{
// Indicate the client that the server is ready to negotiate TLS
...
...
src/java/org/jivesoftware/openfire/spi/ConnectionManagerImpl.java
View file @
b1dfb9c1
...
...
@@ -47,15 +47,8 @@ import javax.net.ssl.KeyManagerFactory;
import
javax.net.ssl.SSLContext
;
import
javax.net.ssl.TrustManagerFactory
;
import
org.apache.mina.common.ByteBuffer
;
import
org.apache.mina.common.ExecutorThreadModel
;
import
org.apache.mina.common.IoHandler
;
import
org.apache.mina.common.IoService
;
import
org.apache.mina.common.IoServiceConfig
;
import
org.apache.mina.common.IoServiceListener
;
import
org.apache.mina.common.IoSession
;
import
org.apache.mina.common.SimpleByteBufferAllocator
;
import
org.apache.mina.common.ThreadModel
;
import
org.apache.mina.common.*
;
import
org.apache.mina.filter.ReadThrottleFilterBuilder
;
import
org.apache.mina.filter.SSLFilter
;
import
org.apache.mina.filter.codec.ProtocolCodecFilter
;
import
org.apache.mina.filter.executor.ExecutorFilter
;
...
...
@@ -98,6 +91,7 @@ import org.slf4j.LoggerFactory;
public
class
ConnectionManagerImpl
extends
BasicModule
implements
ConnectionManager
,
CertificateEventListener
{
private
static
final
Logger
Log
=
LoggerFactory
.
getLogger
(
ConnectionManagerImpl
.
class
);
private
static
final
int
MB
=
1024
*
1024
;
private
SocketAcceptor
socketAcceptor
;
private
SocketAcceptor
sslSocketAcceptor
;
...
...
@@ -360,19 +354,39 @@ public class ConnectionManagerImpl extends BasicModule implements ConnectionMana
// Create SocketAcceptor with correct number of processors
socketAcceptor
=
buildSocketAcceptor
(
"client"
);
// Customize Executor that will be used by processors to process incoming stanzas
ExecutorThreadModel
threadModel
=
ExecutorThreadModel
.
getInstance
(
"client"
);
int
eventThreads
=
JiveGlobals
.
getIntProperty
(
"xmpp.client.processing.threads"
,
16
);
ThreadPoolExecutor
eventExecutor
=
(
ThreadPoolExecutor
)
threadModel
.
getExecutor
();
ExecutorFilter
executorFilter
=
new
ExecutorFilter
();
ThreadPoolExecutor
eventExecutor
=
(
ThreadPoolExecutor
)
executorFilter
.
getExecutor
();
ThreadFactory
threadFactory
=
eventExecutor
.
getThreadFactory
();
threadFactory
=
new
DelegatingThreadFactory
(
"Old executor thread - "
,
threadFactory
);
eventExecutor
.
setThreadFactory
(
threadFactory
);
eventExecutor
.
setCorePoolSize
(
eventThreads
+
1
);
eventExecutor
.
setMaximumPoolSize
(
eventThreads
+
1
);
eventExecutor
.
setKeepAliveTime
(
60
,
TimeUnit
.
SECONDS
);
socketAcceptor
.
getDefaultConfig
().
setThreadModel
(
threadModel
);
socketAcceptor
.
getDefaultConfig
().
setThreadModel
(
ThreadModel
.
MANUAL
);
// Add the XMPP codec filter
socketAcceptor
.
getFilterChain
().
addFirst
(
"xmpp"
,
new
ProtocolCodecFilter
(
new
XMPPCodecFactory
()));
socketAcceptor
.
getFilterChain
().
addFirst
(
"threadModel"
,
executorFilter
);
// Kill sessions whose outgoing queues keep growing and fail to send traffic
socketAcceptor
.
getFilterChain
().
addAfter
(
"xmpp"
,
"outCap"
,
new
StalledSessionsFilter
());
// Throttle sessions who send data too fast
int
maxBufferSize
=
JiveGlobals
.
getIntProperty
(
"xmpp.client.maxReadBufferSize"
,
10
*
MB
);
installReadThrottle
(
socketAcceptor
,
maxBufferSize
);
}
}
private
static
void
installReadThrottle
(
IoAcceptor
socketAcceptor
,
int
maxBufferSize
)
{
if
(
maxBufferSize
<=
0
)
{
return
;
}
// Install filter that throttles the incoming data
Log
.
debug
(
"Throttling read buffer for connections from socketAcceptor={} to max={} bytes"
,
socketAcceptor
,
maxBufferSize
);
ReadThrottleFilterBuilder
readThrottle
=
new
ReadThrottleFilterBuilder
();
readThrottle
.
setMaximumConnectionBufferSize
(
maxBufferSize
);
readThrottle
.
attach
(
socketAcceptor
.
getFilterChain
());
}
private
void
startClientListeners
(
String
localIPAddress
)
{
...
...
@@ -431,20 +445,9 @@ public class ConnectionManagerImpl extends BasicModule implements ConnectionMana
int
eventThreads
=
JiveGlobals
.
getIntProperty
(
"xmpp.client_ssl.processing.threads"
,
16
);
ExecutorFilter
executorFilter
=
new
ExecutorFilter
();
ThreadPoolExecutor
eventExecutor
=
(
ThreadPoolExecutor
)
executorFilter
.
getExecutor
();
final
ThreadFactory
originalThreadFactory
=
eventExecutor
.
getThreadFactory
();
ThreadFactory
newThreadFactory
=
new
ThreadFactory
()
{
private
final
AtomicInteger
threadId
=
new
AtomicInteger
(
0
);
public
Thread
newThread
(
Runnable
runnable
)
{
Thread
t
=
originalThreadFactory
.
newThread
(
runnable
);
t
.
setName
(
"Old SSL executor thread - "
+
threadId
.
incrementAndGet
()
);
t
.
setDaemon
(
true
);
return
t
;
}
};
eventExecutor
.
setThreadFactory
(
newThreadFactory
);
ThreadFactory
threadFactory
=
eventExecutor
.
getThreadFactory
();
threadFactory
=
new
DelegatingThreadFactory
(
"Old SSL executor thread - "
,
threadFactory
);
eventExecutor
.
setThreadFactory
(
threadFactory
);
eventExecutor
.
setCorePoolSize
(
eventThreads
+
1
);
eventExecutor
.
setMaximumPoolSize
(
eventThreads
+
1
);
eventExecutor
.
setKeepAliveTime
(
60
,
TimeUnit
.
SECONDS
);
...
...
@@ -455,6 +458,9 @@ public class ConnectionManagerImpl extends BasicModule implements ConnectionMana
sslSocketAcceptor
.
getFilterChain
().
addFirst
(
"threadModel"
,
executorFilter
);
// Kill sessions whose outgoing queues keep growing and fail to send traffic
sslSocketAcceptor
.
getFilterChain
().
addAfter
(
"xmpp"
,
"outCap"
,
new
StalledSessionsFilter
());
// Throttle sessions who send data too fast
int
maxBufferSize
=
JiveGlobals
.
getIntProperty
(
"xmpp.client_ssl.maxReadBufferSize"
,
10
*
MB
);
installReadThrottle
(
sslSocketAcceptor
,
maxBufferSize
);
// Add the SSL filter now since sockets are "borned" encrypted in the old ssl method
SSLContext
sslContext
=
SSLContext
.
getInstance
(
algorithm
);
...
...
@@ -929,4 +935,24 @@ public class ConnectionManagerImpl extends BasicModule implements ConnectionMana
CertificateManager
.
removeListener
(
this
);
serverName
=
null
;
}
private
static
class
DelegatingThreadFactory
implements
ThreadFactory
{
private
final
AtomicInteger
threadId
;
private
final
ThreadFactory
originalThreadFactory
;
private
String
threadNamePrefix
;
public
DelegatingThreadFactory
(
String
threadNamePrefix
,
ThreadFactory
originalThreadFactory
)
{
this
.
originalThreadFactory
=
originalThreadFactory
;
threadId
=
new
AtomicInteger
(
0
);
this
.
threadNamePrefix
=
threadNamePrefix
;
}
public
Thread
newThread
(
Runnable
runnable
)
{
Thread
t
=
originalThreadFactory
.
newThread
(
runnable
);
t
.
setName
(
threadNamePrefix
+
threadId
.
incrementAndGet
());
t
.
setDaemon
(
true
);
return
t
;
}
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment