add:acs申请任务添加控制:相同设备只能申请一次
This commit is contained in:
@@ -0,0 +1,64 @@
|
|||||||
|
package org.nl.common;
|
||||||
|
|
||||||
|
import org.nl.common.exception.BadRequestException;
|
||||||
|
|
||||||
|
import java.util.Random;
|
||||||
|
import java.util.concurrent.ConcurrentHashMap;
|
||||||
|
import java.util.concurrent.TimeUnit;
|
||||||
|
import java.util.concurrent.locks.ReentrantLock;
|
||||||
|
import java.util.function.Supplier;
|
||||||
|
|
||||||
|
public class LockUtils {
|
||||||
|
private static ConcurrentHashMap<String, ReentrantLock> locks = new ConcurrentHashMap<>();
|
||||||
|
public static <T> T lock(String key, Supplier<T> supplier,Integer second) {
|
||||||
|
ReentrantLock lock;
|
||||||
|
synchronized (key.intern()){
|
||||||
|
lock = locks.get(key);
|
||||||
|
if (lock==null){
|
||||||
|
lock = new ReentrantLock();
|
||||||
|
locks.put(key, lock) ;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
boolean isLock = false;
|
||||||
|
if (second !=null){
|
||||||
|
try {
|
||||||
|
isLock = lock.tryLock(second, TimeUnit.SECONDS);
|
||||||
|
}catch (Exception ex){
|
||||||
|
isLock = false;
|
||||||
|
}
|
||||||
|
}else {
|
||||||
|
isLock = lock.tryLock();
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
if (isLock){
|
||||||
|
return supplier.get();
|
||||||
|
}else {
|
||||||
|
throw new BadRequestException(Thread.currentThread().getName()+"当前业务"+key+"正在执行");
|
||||||
|
}
|
||||||
|
}catch (Exception ex){
|
||||||
|
throw new BadRequestException(Thread.currentThread().getName()+"当前业务"+key+"正在执行");
|
||||||
|
}finally {
|
||||||
|
if (lock.isLocked() && lock.isHeldByCurrentThread()){
|
||||||
|
lock.unlock();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
for (int i = 0; i < 100; i++) {
|
||||||
|
new Thread(()->{
|
||||||
|
String key = String.valueOf(new Random().nextInt(5));
|
||||||
|
String result = LockUtils.lock(key, () -> {
|
||||||
|
try {
|
||||||
|
System.out.println(Thread.currentThread().getName() + "正在执行");
|
||||||
|
Thread.sleep(2000);
|
||||||
|
} catch (Exception ex) {
|
||||||
|
}
|
||||||
|
return key;
|
||||||
|
}, null);
|
||||||
|
System.out.println("执行结果"+result);
|
||||||
|
}).start();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@@ -5,8 +5,10 @@ import com.alibaba.fastjson.JSONObject;
|
|||||||
import io.swagger.annotations.Api;
|
import io.swagger.annotations.Api;
|
||||||
import io.swagger.annotations.ApiOperation;
|
import io.swagger.annotations.ApiOperation;
|
||||||
import lombok.extern.slf4j.Slf4j;
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.nl.common.LockUtils;
|
||||||
import org.nl.common.logging.annotation.Log;
|
import org.nl.common.logging.annotation.Log;
|
||||||
import org.nl.wms.ext.acs.service.AcsToWmsService;
|
import org.nl.wms.ext.acs.service.AcsToWmsService;
|
||||||
|
import org.nl.wms.ext.acs.service.dto.to.BaseResponse;
|
||||||
import org.nl.wms.sch.point.service.ISchBasePointService;
|
import org.nl.wms.sch.point.service.ISchBasePointService;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.http.HttpStatus;
|
import org.springframework.http.HttpStatus;
|
||||||
@@ -16,6 +18,8 @@ import org.springframework.web.bind.annotation.RequestBody;
|
|||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
import org.springframework.web.bind.annotation.RequestMapping;
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
|
|
||||||
|
import java.util.concurrent.locks.ReentrantLock;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @Author: lyd
|
* @Author: lyd
|
||||||
* @Description: acs请求lms接口
|
* @Description: acs请求lms接口
|
||||||
@@ -30,6 +34,8 @@ public class AcsToWmsController {
|
|||||||
|
|
||||||
@Autowired
|
@Autowired
|
||||||
private ISchBasePointService schBasePointService;
|
private ISchBasePointService schBasePointService;
|
||||||
|
private static ReentrantLock lock = new ReentrantLock();
|
||||||
|
|
||||||
|
|
||||||
@Autowired
|
@Autowired
|
||||||
private AcsToWmsService acsToWmsService;
|
private AcsToWmsService acsToWmsService;
|
||||||
@@ -40,7 +46,12 @@ public class AcsToWmsController {
|
|||||||
//@SaCheckPermission("@el.check('schBaseTask:add')")
|
//@SaCheckPermission("@el.check('schBaseTask:add')")
|
||||||
@SaIgnore
|
@SaIgnore
|
||||||
public ResponseEntity<Object> apply(@RequestBody JSONObject param) {
|
public ResponseEntity<Object> apply(@RequestBody JSONObject param) {
|
||||||
return new ResponseEntity<>(acsToWmsService.acsApply(param), HttpStatus.OK);
|
|
||||||
|
String device_code = param.getString("device_code");
|
||||||
|
BaseResponse response = LockUtils.lock(
|
||||||
|
device_code,
|
||||||
|
() -> acsToWmsService.acsApply(param), 2);
|
||||||
|
return new ResponseEntity<>(response, HttpStatus.OK);
|
||||||
}
|
}
|
||||||
|
|
||||||
@PostMapping("/status")
|
@PostMapping("/status")
|
||||||
|
|||||||
Reference in New Issue
Block a user