MongoDB中怎么利用Springboot实现分布式ID

本篇文章为大家展示了MongoDB中怎么利用Springboot实现分布式ID,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

为平南等地区用户提供了全套网页设计制作服务,及平南网站建设行业解决方案。主营业务为网站设计制作、成都网站制作、平南网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!

MongoDB的ObjectId设计成轻量型的,不同的机器都能用全局唯一的同种方法方便地生成它。MongoDB 从一开始就设计用来作为分布式数据库,处理多个节点是一个核心要求。使其在分片环境中要容易生成得多。

它的格式:

前4 个字节是从标准纪元开始的时间戳,单位为秒。时间戳,与随后的5 个字节组合起来,提供了秒级别的唯一性。由于时间戳在前,这意味着ObjectId 大致会按照插入的顺序排列。这对于某些方面很有用,如将其作为索引提高效率。这4 个字节也隐含了文档创建的时间。绝大多数客户端类库都会公开一个方法从ObjectId 获取这个信息。

接下来的3 字节是所在主机的唯一标识符。通常是机器主机名的散列值。这样就可以确保不同主机生成不同的ObjectId,不产生冲突。

为了确保在同一台机器上并发的多个进程产生的ObjectId 是唯一的,接下来的两字节来自产生ObjectId 的进程标识符(PID)。

前9 字节保证了同一秒钟不同机器不同进程产生的ObjectId 是唯一的。

后3 字节就是一个自动增加的计数器,确保相同进程同一秒产生的ObjectId 也是不一样的。同一秒钟最多允许每个进程拥有2563(16 777 216)个不同的ObjectId。

三、编码

在springboot中引入mongodb:

 org.springframework.boot  spring-boot-starter-test  test  org.springframework.boot  spring-boot-starter-web      org.springframework.boot  spring-boot-starter-data-mongodb

创建一个实体类:

public class Customer {  @Id  public String id;  public String firstName;  public String lastName;  public Customer() {}  public Customer(String firstName, String lastName) {    this.firstName = firstName;    this.lastName = lastName;  }  @Override  public String toString() {    return String.format(        "Customer[id=%s, firstName='%s', lastName='%s']",        id, firstName, lastName);  }  public String getId() {    return id;  }  public void setId(String id) {    this.id = id;  }  public String getFirstName() {    return firstName;  }  public void setFirstName(String firstName) {    this.firstName = firstName;  }  public String getLastName() {    return lastName;  }  public void setLastName(String lastName) {    this.lastName = lastName;  }}

创建mongodb 接口类:

/** * Created by fangzhipeng on 2017/4/1. */public interface CustomerRepository extends MongoRepository {  public Customer findByFirstName(String firstName);  public List findByLastName(String lastName);}

测试类:

@Autowired  CustomerRepository customerRepository;@Testpublic void mongodbIdTest(){Customer customer=new Customer("lxdxil","dd");    customer=customerRepository.save(customer);    logger.info( "mongodbId:"+customer.getId());}

上述内容就是MongoDB中怎么利用Springboot实现分布式ID,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注创新互联行业资讯频道。


标题名称:MongoDB中怎么利用Springboot实现分布式ID
路径分享:http://ybzwz.com/article/gsoieh.html