added Snmp client thread (untested)

This commit is contained in:
Lucas Pleß 2014-10-27 22:04:11 +01:00
parent 805330fa27
commit 1c2b262680
5 changed files with 48 additions and 9 deletions

View file

@ -1,5 +1,3 @@
<component name="CopyrightManager">
<settings default="">
<module2copyright />
</settings>
<settings default="" />
</component>

View file

@ -10,7 +10,7 @@
</list>
</option>
</component>
<component name="ProjectRootManager" version="2" languageLevel="JDK_1_6" assert-keyword="true" jdk-15="true" project-jdk-name="1.7" project-jdk-type="JavaSDK">
<component name="ProjectRootManager" version="2" languageLevel="JDK_1_7" assert-keyword="true" jdk-15="true" project-jdk-name="1.7" project-jdk-type="JavaSDK">
<output url="file://$PROJECT_DIR$/out" />
</component>
</project>

View file

@ -41,6 +41,7 @@ public class Main {
@Override
public void windowClosing(WindowEvent e) {
chaOSCclient.stopReceiver();
snmp.stopRunning();
super.windowClosing(e);
}
});

View file

@ -63,6 +63,7 @@ public class MainForm {
}
});
snmpTimer.setRepeats(true);
snmpStatClient.start();
if(showErrors) {
@ -76,6 +77,8 @@ public class MainForm {
pulse3.hide();
statDisplay.hide();
}
}
@ -146,4 +149,5 @@ public class MainForm {
}

View file

@ -21,19 +21,22 @@ import java.util.List;
* @author: lucas
* @date: 18.04.14 12:10
*/
public class SnmpStatClient {
public class SnmpStatClient extends Thread {
private final int napTime = 5000;
public static final String OID_COUNTER = "1.3.6.1.2.1.2.2.1.10";
private HashMap<Integer, Long> lastPorts = new HashMap<>();
private HashMap<Integer, Long> sumPorts = new HashMap<>();
private Snmp snmp;
private CommunityTarget communityTarget;
private long currentTrafficSum = 0;
private Boolean doRun = true;
private CommunityTarget getCommunityTarget(String host) {
CommunityTarget communityTarget = new CommunityTarget();
communityTarget.setCommunity(new OctetString("public"));
communityTarget.setVersion(SnmpConstants.version2c);
communityTarget.setAddress(new UdpAddress(host));
communityTarget.setTimeout(100);
communityTarget.setTimeout(300);
return communityTarget;
}
@ -46,15 +49,44 @@ public class SnmpStatClient {
this.snmp = new Snmp(transportMapping);
} catch (IOException e) {
e.printStackTrace();
System.out.println("error: cannot get traffic from snmp target");
}
}
public long getTrafficSum() {
public void stopRunning() {
doRun = false;
}
@Override
public void run() {
if (snmp == null || this.communityTarget == null) {
System.out.println("snmp error");
return 0;
doRun = false;
}
while (doRun && !Thread.interrupted()) {
long sleepTill = System.currentTimeMillis() + napTime;
getSNMPValues();
try {
long remainingTime = sleepTill - System.currentTimeMillis();
if (remainingTime > 0)
Thread.sleep(remainingTime);
} catch (InterruptedException e) {
return;
}
}
}
private void getSNMPValues() {
if (snmp == null || this.communityTarget == null) {
System.out.println("snmp error");
doRun = false;
return;
}
long sum = 0;
@ -87,7 +119,11 @@ public class SnmpStatClient {
sum += port;
}
return sum;
currentTrafficSum = sum;
}
public long getTrafficSum() {
return currentTrafficSum;
}
}