标签:
微博上经常会看到类似 http://t.cn/Afafhe 这样的短地址
那么实现原理是什么呢
其实很简单 ,系统把一个长的地址 如 http://www.xxx.com/ddd/xxx/a.html?dsada
首先用一个算法转换成 短地址 http://t.cn/Afafhe
然后把 Afafhe-->http://www.xxx.com/ddd/xxx/a.html?dsada 的关系保存到数据库中
当用户访问 http://t.cn/Afafhe网址时,系统到数据库找到对应的URL地址,实现跳转
那么我们要知道的1、算法 2、系统的存储方式
首先看算法吧,网上搜索了下,大致是用MD5什么的生成的 ,其实这个算法主要是把长字符串变小 ,这个算法是不可逆的,所以别想着去直接反转短地址
要详细看算法的 可以到网上搜索资料
2、系统的存储方式 ,如果我们自己写着玩,那直接找个SQL Server 或者MySql 之类的就可以,但是想新浪微博之类的大型网站,那个数据量是非常巨大的,我想他们应该用的NoSql 非关系型数据库(应该也就是人们说的分布式数据库 ),一些开源的 如Facebook 的Cassandra, Apache 的HBase,也得到了广泛认同。从这些NoSQL项目的名字上看不出什么相同之处:Hadoop、Voldemort、Dynomite,还有其它很多。、
http://baike.baidu.com/view/2677528.htm
Java的短地址算法
参考:http://iteye.blog.163.com/blog/static/1863080962012111223141936/
标签:
原文地址:http://www.cnblogs.com/kenshinobiy/p/4685512.html