016 Redis 의 사용 처리 병행,분산 잠 금
1412 단어 SpringBoot
@Component
@Slf4j
public class RedisLLock {
@Autowired
private StringRedisTemplate redisTemplate;
/**
*
* @param key
* @param value
* @return
*/
public boolean lock(String key,String value){
if(redisTemplate.opsForValue().setIfAbsent(key, value)){
return true;
}
String currentValue =redisTemplate.opsForValue().get(key);
//
if (!StringUtils.isEmpty(currentValue)
&& Long.parseLong(currentValue)
동작:
private static final Integer TIMEOUT = 10*1000;
@Autowired
private RedisLLock redisLLock;
@Transactional
public OrderDTO buy(OrderDTO orderDTO) {
//
long time = System.currentTimeMillis()+ TIMEOUT;
if (!redisLLock.lock(orderDTO.getOrderId(),String.valueOf(time))){
throw new SellException(101," , ~~");
}
//
//
redisLLock.unlock(orderDTO.getOrderId(),String.valueOf(time));
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
【Java・SpringBoot・Thymeleaf】 에러 메세지를 구현(SpringBoot 어플리케이션 실천편 3)로그인하여 사용자 목록을 표시하는 응용 프로그램을 만들고, Spring에서의 개발에 대해 공부하겠습니다 🌟 마지막 데이터 바인딩에 계속 바인딩 실패 시 오류 메시지를 구현합니다. 마지막 기사🌟 src/main/res...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.