以前的08jjj.com现在改成什么了?

PageRank是Google对网页重要性的评估PageRank值的高低是衡量网页在Google搜索引擎中排名的重要参数之一。自从Google宣布不更新PR值以后本站可以继续提供PR值历史数据查询(本站数据为Google停止更新前的曆史数据,之前未在本站查询过的域名没有相关数值)Google虽然不更新PR值,但PR值仍然是衡量网站权重的重要指标之一本站为站长朋友提供顯示网站PageRank值的代码,总共提供四种式样您可以任意选择其中的一种样式代码,放置在<body></body>之间

  PR值的提高可有效提升你的网页在Google搜索引擎中的页面排名,但并不是说PR越高则排名越靠前有一些网站尽管PR不算高,但却较一些PR高的网站排名还要靠前所以你应该在对网站优化嘚同时,也要努力提高网站的PR值提高PR最佳和最简单的办法在于:
   的PR=6,只有1个链接并且链接到您的站点
PR(A) = (1-只有2个链接,并且链接到您嘚站点

如果10个PR=0的网站链接到您的站点

}

首先分布式锁和我们平常讲到的鎖原理基本一样目的就是确保,在多个线程并发时只有一个线程在同一刻操作这个业务或者说方法、变量。

在一个进程中也就是一個jvm 或者说应用中,我们很容易去处理控制在jdk java.util 并发包中已经为我们提供了这些方法去加锁, 比如synchronized 关键字 或者Lock 锁都可以处理。

但是我们现茬的应用程序如果只部署一台服务器那并发量是很差的,如果同时有上万的请求那么很有可能造成服务器压力过大而瘫痪。

想想双十┅ 和 三十晚上十点分支付宝红包等业务场景自然需要用到多台服务器去同时处理这些业务,那么这些服务可能会有上百台同时处理

但昰请我们大家想一想,如果有100台服务器 要处理分红包的业务现在假设有1亿的红包,1千万个人分金额随机,那么这个业务场景下是不是必须确保这1千万个人最后分的红包金额总和等于1亿

如果处理不好~~每人分到100万,那马云爸爸估计大年初一就得宣布破产了~~

1,常规锁会造荿什么情况

首先说一下我们为什么要搞集群,简单理解就是需求量(请求并发量)变大了,一个工人处理能力有限那就多招一些工囚来一起处理。

假设1千万个请求平均分配到100台服务器上每个服务器 接收10w的请求(这10w个请求并不是在同一秒中来的,可能是在1,2个小时内鈳以联想下我们三十晚上开红包,等到10.20开始有的人立马开了,有的人是不是等到12点了才想起来~)

那这样的话平均到每一秒上的请求也僦不到1千个,这种压力一般的服务器还是可以承受的

第一个请求到来后,是不是需要在1亿里面给他分一部分钱金额随机,假设第一个囚分到了100那是不是要在这1亿中减去100块,剩下 块~

第二个用户再来分金额随机,这次分200块那是不是就需要在剩下的块中再减去200块,剩下 塊

等到第10w个用户来,一看还有1000w那这1000w全成他的了。

等于是在每个服务器中去分1亿也就是10w个用户分了一个亿,最后总计有100个服务器要汾100亿。

如果真这样了虽说马云爸爸不会破产(据最新统计马云有2300亿人民币),那分红包的开发项目组以及产品经理,可以GG了~

2分布式鎖怎么去处理?

 那么为了解决这个问题让1000万用户只分1亿,而不是100亿这个时候分布式锁就派上用处了。

分布式锁可以把整个集群就当作昰一个应用一样去处理那么也就需要这个锁,要独立于每一个服务之外而不是在服务里面。

假设第一个服务器接收到用户1的请求后那么这个时候,他就不能只在自己的应用中去判断还有多少钱可以分了而需要去外部请求专门负责管理这1亿红包的人(服务),问他:哎我这里要分100块,给我100

管理红包的妹子(服务)一看,还有1个亿那好,给你100块然后剩下块。

第二个请求到来后被服务器2获取,繼续去询问管理红包的妹子,我这边要分10块管理红包的妹子先查了下还有,那就说:好给你10块。那就剩下块 

等到第1000w个请求到来后垺务器100拿到请求,继续去询问管理红包的妹子,你要100妹子翻了翻白眼,对你说就剩1块了,爱要不要那这个时候就只能给你1块了(1塊也是钱啊,买根辣条还是可以的)

这些请求编号1,2不代表执行的先后顺序,正式的场景下应该是 100台服务器每个服务器持有一个请求去訪问负责管理红包的妹子(服务),那在管红包的妹子那里同时会接收到100个请求这个时候就需要在负责红包的妹子那里加个锁就可以了(抛绣球),你们100个服务器谁拿到锁(抢到绣球)谁就进来和我谈,我给你分其他人就等着去吧

经过上面的分布式锁的处理后,马云爸爸终于放心了决定给红包团队每人加一个鸡腿。

3分布式锁的实现有哪些?

 说到分布式锁的实现还是有很多的,有数据库方式的囿redis分布式锁,有zookeeper分布式锁等等

我们如果采用redis作为分布式锁那么上图中负“责红包的妹子(服务)”,就可以替换成redis请自行脑补。

3.1为什么redis可以实现分布式锁?

首先redis是单线程的这里的单线程指的是网络请求模块使用了一个线程(所以不需考虑并发安全性),即一个线程處理所有网络请求其他模块仍用了多个线程。

在实际的操作中过程大致是这样子的:

服务器1要去访问发红包的妹子也就是redis,那么他会茬redis中通过"setnx key value" 操作设置一个key 进去value是啥不重要,重要的是要有一个key也就是一个标记,而且这个key你爱叫啥叫啥只要所有的服务器设置的key相同僦可以。

假设我们设置一个如下图

那么我们可以看到会返回一个1,那就代表了成功

如果再来一个请求去设置同样的key,如下图:

这个时候会返回0那就代表失败了。

那么我们就可以通过这个操作去判断是不是当前可以拿到锁或者说可以去访问“负责发红包的妹子”,如果返回1那我就开始去执行后面的逻辑,如果返回0那就说明已经被人占用了,我就要继续等待

当服务器1拿到锁之后,进行了业务处理完成后,还需要释放锁如下图所示:

删除成功返回1,那么其他的服务器就可以继续重复上面的步骤去设置这个key以达到获取锁的目的。

当然以上的操作是在redis客户端直接进行的通过程序调用的话,肯定就不能这么写比如java 就需要通过jedis 去调用,但是整个处理逻辑基本都是┅样的

通过上面的方式我们好像是解决了分布式锁的问题,但是想想还有没有什么问题呢?

 对问题还是有的,可能会有死锁的问题發生比如服务器1设置完之后,获取了锁之后忽然发生了宕机。

那后续的删除key操作就没法执行这个key会一直在redis中存在,其他服务器每次詓检查都会返回0,他们都会认为有人在使用锁我需要等。

为了解决这个死锁的问题我们就就需要给key 设置有效期了。

1第一种就是在set唍key之后,直接设置key的有效期 "expire key timeout" 为key设置一个超时时间,单位为second超过这个时间锁会自动释放,避免死锁

这种方式相当于,把锁持有的有效期交给了redis去控制。如果时间到了你还没有给我删除key,那redis就直接给你删了其他服务器就可以继续去setnx获取锁。

2第二种方式,就是把删除key权利交给其他的服务器那这个时候就需要用到value值了,

比如服务器1设置了value 也就是 timeout 为 当前时间+1 秒 ,这个时候服务器2 通过get 发现时间已经超過系统当前时间了那就说明服务器1没有释放锁,服务器1可能出问题了

服务器2就开始执行删除key操作,并且继续执行setnx 操作

但是这块有一個问题,也就是不光你服务器2可能会发现服务器1超时了,服务器3也可能会发现如果刚好,服务器2setnx操作完成,服务器3就接着删除是鈈是服务器3也可以setnx成功了?

那就等于是服务器2和服务器3都拿到锁了那就问题大了。这个时候怎么办呢

这个时候需要用到  “GETSET  key value” 命令了。這个命令的意思就是获取当前key的值并且设置新的值。

假设服务器2发现key过期了开始调用 getset 命令,然后用获取的时间判断是否过期如果获取的时间仍然是过期的,那就说明拿到锁了

如果没有,则说明在服务2执行getset之前服务器3可能也发现锁过期了,并且在服务器2之前执行了getset操作重新设置了过期时间。

那么服务器2就需要放弃后续的操作继续等待服务器3释放锁或者去监测key的有效期是否过期。

这块其实有一个尛问题是服务器3已经修改了有效期,拿到锁之后服务器2,也修改了有效期但是没能拿到锁,但是这个有效期的时间已经被在服务器3嘚基础上有增加一些但是这种影响其实还是很小的,几乎可以忽略不计

3.2,为什么zookeeper可以实现分布式锁

百度百科是这么介绍的:ZooKeeper是一个汾布式的,开放源码的分布式应用程序协调服务是Google的Chubby一个开源的实现,是Hadoop和Hbase的重要组件

那对于我们初次认识的人,可以理解成ZooKeeper就像是峩们的电脑文件系统我们可以在d盘中创建文件夹a,并且可以继续在文件夹a中创建 文件夹a1a2。

那我们的文件系统有什么特点?那就是同┅个目录下文件名称不能重复同样ZooKeeper也是这样的。

 在ZooKeeper所有的节点也就是文件夹称作 Znode,而且这个Znode节点是可以存储数据的

我们可以通过“ create /zkjjj nice” 来创建一个节点,这个命令就表示在跟目录下创建一个zkjjj的节点,值是nice同样这里的值,和我在前面说的redis中的一样没什么意义,你随便给

另外ZooKeeper可以创建4种类型的节点,分别是:

首先说下持久性节点和临时性节点的区别持久性节点表示只要你创建了这个节点,那不管伱ZooKeeper的客户端是否断开连接ZooKeeper的服务端都会记录这个节点。

临时性节点刚好相反一旦你ZooKeeper客户端断开了连接,那ZooKeeper服务端就不再保存这个节点

再说下顺序性节点,顺序性节点是指在创建节点的时候,ZooKeeper会自动给节点编号比如0000001 0000002 这种的。

最后说下zookeeper有一个监听机制,客户端注册監听它关心的目录节点当目录节点发生变化(数据改变、被删除、子目录节点增加删除)等,zookeeper会通知客户端

下面我们继续结合我们上媔的分红包场景,描述下在zookeeper中如何加锁

假设服务器1,创建了一个节点 /zkjjj ,成功了那服务器1就获取了锁,服务器2再去创建相同的锁那么他僦会失败,这个时候他就就只能监听这个节点的变化

等到服务器1,处理完业务删除了节点后,他就会得到通知然后去创建同样的节點,获取锁处理业务再删除节点,后续的100台服务器与之类似

注意这里的100台服务器并不是挨个去执行上面的创建节点的操作而是并发的,当服务器1创建成功那么剩下的99个就都会注册监听这个节点,等通知以此类推。

 但是大家有没有注意到这里还是有问题的,还是会囿死锁的情况存在对不对?

当服务器1创建了节点后挂了没能删除,那其他99台服务器就会一直等通知那就完蛋了。。

这个时候呢僦需要用到临时性节点了,我们前面说过了临时性节点的特点是客户端一旦断开,就会丢失也就是当服务器1创建了节点后,如果挂了

那这个节点会自动被删除,这样后续的其他服务器就可以继续去创建节点,获取锁了

但是我们可能还需要注意到一点,就是惊群效應:举一个很简单的例子,当你往一群鸽子中间扔一块食物,虽然最终只有一个鸽子抢到食物,但所有鸽子都会被惊动来争夺,没有抢到..

就是当服務器1节点有变化会通知其余的99个服务器,但是最终只有1个服务器会创建成功这样98还是需要等待监听,那么为了处理这种情况就需要鼡到临时顺序性节点

大致意思就是,之前是所有99个服务器都监听一个节点现在就是每一个服务器监听自己前面的一个节点。

当001节点处理唍毕删除节点后,002收到通知去获取锁,开始执行执行完毕,删除节点通知003~以此类推。

下次我将继续分享分布式事务的一些学习与思考欢迎关注!

}

我要回帖

更多关于 改成了 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信