V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
爱意满满的作品展示区。
ququzone
V2EX  ›  分享创造

开源一个短网址微服务项目

  •  
  •   ququzone ·
    ququzone · 2016-03-10 13:44:18 +08:00 · 4696 次点击
    这是一个创建于 3185 天前的主题,其中的信息可能已经有所发展或是发生改变。

    最近项目中要用到短网址功能,顺便写成了一个微服务,欢迎大家提提意见 https://github.com/ququzone/shorturl

    微服务采用的是 Spring Boot ,数据库 PostgreSQL ,计数用的 ZooKeeper

    第 1 条附言  ·  2016-03-11 12:16:09 +08:00
    去掉 PostgreSQL 数据库,将数据直接存在 redis 中
    18 条回复    2016-03-11 13:00:52 +08:00
    qinxi
        1
    qinxi  
       2016-03-10 15:40:06 +08:00
    看了楼主代码.没上缓存(热点 url),没处理同一 url 连续两次转换出现不同结果的情况.
    int64ago
        2
    int64ago  
       2016-03-10 15:41:36 +08:00 via Android   ❤️ 1
    安利下我自己的

    https://302.at/

    GitHub 在右下角
    int64ago
        3
    int64ago  
       2016-03-10 15:42:22 +08:00 via Android
    @qinxi 你第二点不成立,参考 goo.gl
    ququzone
        4
    ququzone  
    OP
       2016-03-10 16:09:25 +08:00
    @qinxi 你的第一条倒是提醒我了,我还不如把数据库去掉,直接换成 redis
    qinxi
        5
    qinxi  
       2016-03-10 18:12:48 +08:00
    @int64ago
    @ququzone
    我比较菜 请问是 zookeeper 做到的吗 ` AtomicValue<Long> value = distributedAtomicLong.increment();`?
    qinxi
        6
    qinxi  
       2016-03-10 18:22:29 +08:00
    @int64ago
    @ququzone
    但是好像不是吧...increment 不是计数器+1 吗....也没看到哪里处理了同一 URL 转换结果

    对于 zookeeper 仅限于知道名字=.=

    能不能讲一下
    int64ago
        7
    int64ago  
       2016-03-10 18:25:37 +08:00
    @qinxi 额,我不是针对代码说的

    同一个 URL 转成短地址每次不一样坏处是浪费空间,但是好处也很多,最鲜见的就是类似 goo.gl 的统计功能,其实去重本身是很简单的,大可不必计较这些
    ququzone
        8
    ququzone  
    OP
       2016-03-10 18:42:01 +08:00 via iPhone
    @int64ago
    @qinxi
    重复不处理稍微好些,上面那段代码是实现一个分布式 long ,是基于 zookeeper 的,主要是为了集群部署。
    qinxi
        9
    qinxi  
       2016-03-10 18:45:21 +08:00
    @ququzone
    @int64ago 明白了
    lyf362345
        10
    lyf362345  
       2016-03-10 18:47:46 +08:00
    见过别人写的一个短网址, 就几十行代码, 纯文件: 行写入, 把指向文件的位置转为 16 进制, 反转时, 行读取, 也能满足需要了, 设计好了也没容量问题
    ququzone
        11
    ququzone  
    OP
       2016-03-10 18:54:18 +08:00 via iPhone
    @lyf362345
    基于文件行的话基本不能用在生产环节,解决不了大规模并发
    hxsf
        12
    hxsf  
       2016-03-10 20:37:41 +08:00
    新鲜出炉的 https://github.com/hxsf/shortURL
    前台样式 = undefined;
    Andy1999
        13
    Andy1999  
       2016-03-10 20:40:51 +08:00
    重复生成 https://302.at/Z62x4
    https://302.at/YxOW1 没有简单的严重
    十几秒刷爆 VPS 数据库
    @int64ago
    lyf362345
        14
    lyf362345  
       2016-03-10 21:52:55 +08:00
    @ququzone 文件 load 到内存就是
    thinkmore
        15
    thinkmore  
       2016-03-11 09:46:49 +08:00
    @ququzone 请问下短网址实现的原理是什么呢?
    iyannik0215
        16
    iyannik0215  
       2016-03-11 10:01:20 +08:00
    @Andy1999 确实。。。直接起飞。。
    ququzone
        17
    ququzone  
    OP
       2016-03-11 12:15:16 +08:00
    @thinkmore 长整形计数,然后将 10 进制转成 62 进制

    目前的版本去掉了数据库,直接将数据存在 redis 里面了
    int64ago
        18
    int64ago  
       2016-03-11 13:00:52 +08:00
    @Andy1999 真想刷爆,跟重复与否没啥关系吧?脚本也可以每次变化着 D

    而且,你仔细看下,我并没有用数据库…… 用的 LeanCloud ,他们本身有一定抗 D 能力
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3489 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 29ms · UTC 04:43 · PVG 12:43 · LAX 20:43 · JFK 23:43
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.