之前写了一个自动收款的方法,使用的是SpringMvc定时器实现的,自动收款的方法,主要是针对现金业务的,实现对于业务员提交的收款单,自动收款的一系列操作来减轻 财务同事工作的,完成后在测试系统上测试没问题,然后上线,上线后经常有几笔会出现从重复收款的问题,我把代码看了一遍又一遍,把日志看了一遍又一遍的,特别是对于重复收款的业务的日志,日志打印中也只有一遍,这就很奇怪了。没办法,我就在业务代码那里加了一个线程锁synchronized代码块,但是还是会出现重复收款的问题。无奈找我们老大,我们老大看了看代码,又看了看日志说,这个我也没看出来有问题啊,你要不把操作人改为本机的ip试一下,看看是不是别的机器也在跑啊,我就加了个方法,然后上线,直接开跑,然后果然不出所料,出现了一笔重复的业务,操作人一栏,一笔是服务器的ip,另外一笔是之前定义的操作人,我直接打开预生产,果然,上线前夕,预生产的代码测试没问题后,没有停止预生产的服务,导致生产和预生产一块跑了自动任务。关闭预生产服务,问题解决。一下是获取本机ip的方法:
/**
* 获取本机ip地址
* @param args
*/
public static String getHostAddress(){
InetAddress ip = null;
String result=null;
try {
Enumeration allNetInterfaces = NetworkInterface.getNetworkInterfaces();
while (allNetInterfaces.hasMoreElements()){
NetworkInterface netInterface = (NetworkInterface) allNetInterfaces.nextElement();
//System.out.println(netInterface.getName());
Enumeration addresses = netInterface.getInetAddresses();
while (addresses.hasMoreElements()){
ip = (InetAddress) addresses.nextElement();
if (ip != null && ip instanceof Inet4Address && !ip.getHostAddress().equals("127.0.0.1")){
result=ip.getHostAddress();
}
}
}
} catch (Exception e) {
e.printStackTrace();
}
return result;
}