如何利用数据库和Redis为每个系统开发独立的自增ID生成器 DROPTABLEIFEXISTSsys_id_re / 如何利用数据库和Redis为每个系统开发独立的自增ID生成器 DROPTABLEIFEXISTSsys_id_re

这个设计的核心思想是数据库控制各个子系统的起始值和步长,然后将值放到redis队列中,从队列中依此取值。当从redis中消耗掉后再次从数据库中取一批值,依此循环。

总结
package com.davidwang456.test;  import java.util.ArrayList; import java.util.List;  import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.redis.core.RedisTemplate; import org.springframework.stereotype.Service;  @Service public class IDGenerateServiceImpl implements IDGenerateService {    @Autowired    private SysIdRecordDao sysIdRecordDao;        @Autowired    private RedisTemplate redisTemplate;      @Override     public String getIDGenerateBySys(String sysId) {         init(sysId);         Object idSys=redisTemplate.opsForList().rightPop(sysId);         if(idSys==null) {             List records=sysIdRecordDao.getEnabledSysIdRecord(sysId);             if(records!=null&&records.isEmpty()) {                 SysIdRecord record=records.get(0);                                  List buf_ids=new ArrayList();                 for(int i=1;i<record.getLenth+1;i++) {                     buf_ids.add(record.getIdFrom+i);                 }                 redisTemplate.opsForList().leftPushAll(sysId, buf_ids);                 record.setIdFrom(record.getIdFrom()+record.getLenth());                 sysIdRecordDao.save(record);                 idSys=redisTemplate.opsForList().rightPop(sysId);             }         }         return sysId+":"+idSys;     }          private void init(String sysId) {         if(!redisTemplate.hasKey(sysId)) {             List records=sysIdRecordDao.getEnabledSysIdRecord(sysId);             if(records==null||records.isEmpty()) {                 SysIdRecord record=new SysIdRecord();                 //TODO                 sysIdRecordDao.save(record);             }         }      }  } 
接口服务实现
package com.davidwang456.test;   public interface IDGenerateService {   String getIDGenerateBySys(String sysId); }
定义服务接口
主要代码
DROP TABLE IF EXISTS sys_id_record; CREATE TABLE sys_id_record( id INT UNSIGNED AUTO_INCREMENT, sys_id VARCHAR(40) NOT NULL COMMENT '子系统ID', sys_name VARCHAR(100) NOT NULL COMMENT '子系统名称', id_from INT NOT NULL DEFAULT 1 COMMENT '子系统ID起始值', lenth SMALLINT NOT NULL DEFAULT 10 COMMENT '子系统ID长度', enabled VARCHAR(1) NOT NULL DEFAULT 'Y', created_by VARCHAR(40) NOT NULL COMMENT '创建人', created_date DATETIME COMMENT '创建时间', updated_by VARCHAR(40) NOT NULL COMMENT '更新人', updated_date DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间', PRIMARY KEY ( id ) )ENGINE=INNODB DEFAULT CHARSET=utf8; 
数据库设计(mysql)
各系统独立的自增ID生成器

为了解决各个系统独自生成自增的唯一ID的需求,而又实现简单有效,做了如下设计。

而因为Redis的高性能和单线程特性,使它在这方面有独特的优势。

JavaScript是一种广泛应用于Web开发的脚本语言,它能够为网页添加交互性和动态效果。学习JavaScript是成为一名优秀Web开发者必不可少的一步。本文将介绍几种学习JavaScript的最佳方法。

第一种方法是通过在线课程学习。许多在线教育平台都提供了丰富的JavaScript课程,如Coursera、Udacity、edX和Codecademy等。这些平台提供了一系列的视频教程、练习和项目,让你能够在自己的节奏下学习JavaScript。另外,这些平台还提供了与其他学习者互动和交流的机会,可以从其他人的经验中学习到更多。

第二种方法是阅读JavaScript书籍。有很多优秀的JavaScript书籍,它们提供了深入的学习和实践经验,包括《JavaScript权威指南》、《JavaScript高级程序设计》、《你不知道的JavaScript》等。这些书籍不仅可以帮助你深入理解JavaScript的工作原理,而且还能够教你如何编写高效、可维护的代码。

第三种方法是参与开源项目。参与开源项目是学习JavaScript的另一种好方法,因为你可以看到其他开发者是如何使用JavaScript解决实际问题的。你可以从中学习到如何编写可维护、可扩展的代码,以及如何与其他开发者协作。GitHub是一个非常好的平台,它提供了大量的开源JavaScript项目,你可以浏览并尝试贡献。

最后,建议尽可能多地实践。无论你是通过在线课程、书籍还是开源项目学习JavaScript,最终都需要在实践中巩固所学知识。你可以尝试编写一些小型的JavaScript项目,如一个简单的表单验证、一个图片轮播等。在实践中,你会遇到各种问题和挑战,这也是你不断学习和进步的机会。

总之,学习JavaScript并不是一件容易的事情,但是通过上述几种最佳方法,你可以更加高效地学习和掌握JavaScript,成为一名优秀的Web开发者。

文章结束。