-
Notifications
You must be signed in to change notification settings - Fork 360
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
how to set apache mina sshd io thread count? #518
Comments
well,I have discovered another issue: there is a memory leak when reconnecting the client. Here is an example: I register a listener for each session to monitor if the session disconnects. Once it disconnects, I attempt to reconnect proactively. this.session.addSessionListener(new SessionListener() {
@Override
public void sessionClosed(Session session) {
synchronized (BaseSshSessionSender.this){
if(BaseSshSessionSender.this.status != SenderStatus.DISCONNECT && BaseSshSessionSender.this.status != SenderStatus.DEATH){
BaseSshSessionSender.this.status = SenderStatus.DISCONNECT;
BaseSshSessionSender.this.reConnect(true);
}
}
}
}); protected void reConnect(boolean immediately){
this.scheduledExecutorService.schedule(this::connect, immediately?0L:metaData.getReconnectInterval().getSeconds(), TimeUnit.SECONDS);
}
public void connect() {
try {
if(this.status != SenderStatus.DEATH){
this.doConnect();
}
} catch (Exception e) {
this.status = SenderStatus.DISCONNECT;
this.reConnect(false);
}
} Assuming each client currently uses I tested this with Jprofiler, and found that at service startup, there were around 1200 sshd threads, but after about 5 minutes, there were nearly 2000 threads (because I intentionally connected some clients to unreachable networks, triggering reconnections). This situation clearly leads to a memory leak. How can this be resolved? Thank you for your assistance. |
SshClient.setUpDefaultClient() will bulid new client, then every time call doConnect it is new client. But as example should stop old client. maybe you can move client init (setUpDefaultClient) to BaseSshSessionSender instance init, but you should also call stop.
|
Version
sshd-core 2.12.0
Bug description
Hello,
I am using sshd-core to interact with some hardware devices. My code is structured as follows:
For each device, I create a
BaseSshSessionSender
object to communicate, maintaining a long connection with the device. However, I've noticed that creating such a device connection spawnscpu*2
threads. For instance, with 100 devices on an 8-core CPU, maintaining these connections requires 1600 threads, which is a substantial overhead. Given that my communication with these devices is infrequent, I do not need so many threads.I am looking for a way to specify the number of I/O threads during connection setup, similar to how one might use bootstrap.group(new NioEventLoopGroup(1)) in Netty. Does sshd-core support this configuration? If so, how can I set it up?
Thank you for your assistance.
Actual behavior
each device connection spawns
cpu*2
threadsExpected behavior
specify the number of I/O threads during connection setup
Relevant log output
No response
Other information
No response
The text was updated successfully, but these errors were encountered: