当前位置: 首页 > news >正文

公司网站建设模板有高并发 高访问量网站开发

公司网站建设模板,有高并发 高访问量网站开发,wordpress添加api,房地产开发资质需要什么条件一、Lock4j 分布式锁工具 你是不是在使用分布式锁的时候#xff0c;还在自己用 AOP 封装框架#xff1f;那么 Lock4j 你可以考虑一下。 Lock4j 是一个分布式锁组件#xff0c;其提供了多种不同的支持以满足不同性能和环境的需求。 立志打造一个简单但富有内涵的分布式锁组…一、Lock4j 分布式锁工具 你是不是在使用分布式锁的时候还在自己用 AOP 封装框架那么 Lock4j 你可以考虑一下。 Lock4j 是一个分布式锁组件其提供了多种不同的支持以满足不同性能和环境的需求。 立志打造一个简单但富有内涵的分布式锁组件。 并且支持redission,redisTemplate,zookeeper。可混用支持扩展。 Giee地址https://gitee.com/baomidou/lock4j 二、使用方式 这里我以 redisson 作为分布式锁的底层。 添加依赖 dependencygroupIdcom.baomidou/groupIdartifactIdlock4j-redisson-spring-boot-starter/artifactIdversion2.2.5/version /dependency然后再配置中增加 redis 的配置 spring:redis:timeout: 6000password:cluster:max-redirects:nodes:- 192.168.40.120:6379- 192.168.40.121:6379- 192.168.40.122:6379声明 RedissonClient Configuration public class RedissonConfig {Beanpublic RedissonClient getRedisson(RedisProperties redisProperties) {Config config new Config();String[] nodes redisProperties.getCluster().getNodes().stream().filter(StringUtils::isNotBlank).map(node - redis:// node).collect(Collectors.toList()).toArray(new String[]{});ClusterServersConfig clusterServersConfig config.useClusterServers().addNodeAddress(nodes);if (StringUtils.isNotBlank(redisProperties.getPassword())) {clusterServersConfig.setPassword(redisProperties.getPassword());}clusterServersConfig.setConnectTimeout((int) (redisProperties.getTimeout().getSeconds() * 1000));clusterServersConfig.setScanInterval(2000);return Redisson.create(config);} }然后只需在需要分布式锁的地方加 Lock4j 即可 RestController RequestMapping(/lock) public class Lock4jController {//不指定,默认获取锁超时3秒30秒锁过期Lock4jGetMapping(/test)public String test() {return success;}Lock4j(keys {#id, #name}, expire 60000, acquireTimeout 10000)GetMapping(/test1)public String test1(Long id, String name) {Thread.sleep(5000);return success;}}如果同时两次访问 /test1可以感觉出第二次没有获得锁的请求等待的时间更长因为要等待锁的释放 获取锁超时时间和锁过期时间可以通过配置在配置文件中全局生效 lock4j:acquire-timeout: 3000 #默认值3s可不设置expire: 30000 #默认值30s可不设置primary-executor: com.baomidou.lock.executor.RedisTemplateLockExecutor #默认redissonredisTemplatezookeeper可不设置lock-key-prefix: lock4j #锁key前缀, 默认值lock4j可不设置acquire-timeout 等待锁的时长超过这个时间会默认抛出 com.baomidou.lock.exception.LockFailureException 异常。 也可以自定义异常捕获需要实现 LockFailureStrategy 接口 Slf4j Component public class MyLockFailureStrategy implements LockFailureStrategy {Overridepublic void onLockFailure(String key, Method method, Object[] arguments) {log.error(key: {} , method: {} ,arguments: {} , key, method.getName(), Arrays.asList(arguments).toString());} }如果获取锁超时则可以看到打印的日志 锁的获取逻辑也可以自定义如果是 Redisson 依赖下可以继承 AbstractLockExecutorRLock 抽象类例如 Slf4j Component public class MyLockExecutor extends AbstractLockExecutorRLock {ResourceRedissonClient redissonClient;/*** 尝试获取锁*/Overridepublic RLock acquire(String lockKey, String lockValue, long expire, long acquireTimeout) {log.info(key: {} 尝试获取锁, lockKey);try {RLock lockInstance this.redissonClient.getLock(lockKey);boolean locked lockInstance.tryLock(acquireTimeout, expire, TimeUnit.MILLISECONDS);return (RLock)this.obtainLockInstance(locked, lockInstance);} catch (InterruptedException var9) {return null;}}/*** 释放锁*/Overridepublic boolean releaseLock(String key, String value, RLock lockInstance) {log.info(key: {} 释放锁, key);if (lockInstance.isHeldByCurrentThread()) {try {return (Boolean)lockInstance.forceUnlockAsync().get();} catch (InterruptedException | ExecutionException var5) {return false;}} else {return false;}} }然后在使用时指定执行器 Lock4j(keys {#id, #name}, expire 60000, acquireTimeout 1000, executor MyLockExecutor.class) GetMapping(/test2) public String test2(Long id, String name) throws InterruptedException {Thread.sleep(5000);return success; }请求 test2 接口可以看到打印的日志 Key 的生成也可以自定义只需继承 DefaultLockKeyBuilder 抽象类例如 Slf4j Component public class MyLockKeyBuilder extends DefaultLockKeyBuilder {public MyLockKeyBuilder(BeanFactory beanFactory) {super(beanFactory);}Overridepublic String buildKey(MethodInvocation invocation, String[] definitionKeys) {String key super.buildKey(invocation, definitionKeys);log.info(生成的key{} , key);return key;} }运行后可以观察日志 上面都是通过注解的方式同样也可以手动控制锁的获取和释放只需要引入 LockTemplate 例如 RestController RequestMapping(/lock) public class Lock4j2Controller {Resourceprivate LockTemplate lockTemplate;GetMapping(/test3)public String test1(Long id, String name) {// 获取锁final LockInfo lockInfo lockTemplate.lock(id name, 30000L, 5000L, RedissonLockExecutor.class);try {Thread.sleep(5000);return success;} catch (InterruptedException e) {throw new RuntimeException(e);} finally {//释放锁lockTemplate.releaseLock(lockInfo);}} }三、通过锁实现限流 在注解中 autoRelease 控制着是否自动在方法执行结束后释放锁如果为 false 则是在 expire 时间到的时候移除锁实际是通过 Redis 的过期机制通过这个机制可以限制某个 key 的访问频次例如 Lock4j(keys {#id, #name}, expire 3000, acquireTimeout 10000, autoRelease false) GetMapping(/test4) public String test4(Long id, String name) throws InterruptedException {return success; }当同一个 id 和 name 第一次访问的时候速度会很快 如果频繁访问则会被限流
http://www.dnsts.com.cn/news/273025.html

相关文章:

  • 宁波自助建站网站搜索引擎优化的定义是什么
  • 做的比较好的美食网站建网站如何添加会员模式
  • 微信网站搭建哪家好商丘网约车
  • 网站推广方法有哪几种触动网站建设
  • 济宁房产网站建设php html5企业网站源码
  • 怎么攻击php做的网站吗网站综合开发怎么做
  • 做销售网站的公司哪家最好上海做外贸网站设计
  • wordpress octopress苏州网站seo公司
  • 网站备案 法人tomcat 网站开发
  • 网站做戒酒通知书搭建网站需要做什么
  • 网站建设托管预算清单山东省交通运输厅网站开发单位
  • 广州网站改版设计附近哪个厂子招工
  • 建设工程网站广州有哪些做产品产业链分析的网站
  • 水利局网站建设整改报告wordpress编辑器自定义按钮
  • 地方门户网站赚钱吗如何在宝塔中安装wordpress
  • 苏州seo优化外包公司官方网站优化价格
  • 南阳网站建设 xihewh网站产品网页设计模板
  • 一个网站可以做多少个小程序厦门有什么网站制作公司
  • 网站模板免费下载php怎样暂停域名指向网站
  • 网站开发免责说明关键词排名优化软件策略
  • 全国精品课程建设网站黑马程序员学费多少
  • 资源共享网站怎么做WordPress上传图片显示在页面代码
  • 建站交流科技网站模板
  • 学校如何建网站张雪峰软件工程的前景
  • 海淀网站建设本溪怎么查看wordpress版本
  • 苏州找网络公司建网站wordpress导出html代码
  • 内部劵网站怎么做wordpress jfinal
  • 北京专业网站外包公司网站开发用px还是rem
  • 青岛气象站建站时间想在百度上推广怎么做
  • 建设银行网上银行官方网站kali建设网站