springboot多线程安全demo

下面例子是线程安不安全实例

复制代码
import com.vip.vman.client.zk.ZkLock;
import com.vip.vman.result.BasicResult;
import com.vip.vman.service.job.ZKJob;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;

import java.util.concurrent.TimeUnit;

@Slf4j
@RestController
@RequestMapping(value = "/vman/sys2")
public class System2Controller {

    @Autowired
    ZKJob zkJob;
    private volatile  Integer value = 0;

    //这个是线程不安全的,即使变量设置了volatile
    @RequestMapping(value = "/cacheClean3", method = RequestMethod.GET)
    public  BasicResult expireRedis3(){
        BasicResult<Integer> basicResult = new BasicResult<>();
        value++;
        basicResult.setSingleResult(value);
        return basicResult;
    }

    //因为加了synchronized,所以线程安全。这个只能针对单实例安全,但是多实例并也不安全
    @RequestMapping(value = "/cacheClean4", method = RequestMethod.GET)
    public synchronized BasicResult expireRedis4(){
        BasicResult<Integer> basicResult = new BasicResult<>();
        //证
        value++;
        basicResult.setSingleResult(value);
        return basicResult;
    }

    @RequestMapping(value = "/cacheClean5", method = RequestMethod.GET)
    public  BasicResult expireRedis5() throws Exception {
        BasicResult<Integer> basicResult = new BasicResult<>();
        ZkLock lock = new ZkLock(zkJob.getZK(), "/vman/analyse_task_delete/lock2");
        try {
            if( lock.acquire(20, TimeUnit.SECONDS) ) {
                value++;
            }
        }catch (Exception e) {
            log.info("exception:{}",e);
        }finally {
            lock.release();
        }
        basicResult.setSingleResult(value);
        return basicResult;
    }
}
相关推荐
你的人类朋友2 小时前
“签名”这个概念是非对称加密独有的吗?
前端·后端·安全
南尘NCA86662 小时前
企业微信防封防投诉拦截系统:从痛点解决到技术实现
java·网络·企业微信
怪兽20143 小时前
SQL优化手段有哪些
java·数据库·面试
ss2733 小时前
手写MyBatis第107弹:@MapperScan原理与SqlSessionTemplate线程安全机制
java·开发语言·后端·mybatis
携欢3 小时前
PortSwigger靶场之CSRF where token validation depends on request method通关秘籍
安全·web安全·csrf
周杰伦_Jay4 小时前
【计算机网络表格图表解析】网络体系结构、数据链路层、网络层、传输层、应用层、网络安全、故障排查
计算机网络·安全·web安全
Deschen4 小时前
设计模式-原型模式
java·设计模式·原型模式
麦麦鸡腿堡4 小时前
Java的动态绑定机制(重要)
java·开发语言·算法
それども4 小时前
SpringBootTest运行线程池被拒绝
java
介一安全4 小时前
【Frida Android】基础篇6:Java层Hook基础——创建类实例、方法重载、搜索运行时实例
android·java·网络安全·逆向·安全性测试·frida