V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
• 请不要在回答技术问题时复制粘贴 AI 生成的内容
wingyiu
V2EX  ›  程序员

这种情况怎么设计 restful url 该?

  •  
  •   wingyiu · 2016-11-14 23:03:27 +08:00 · 3558 次点击
    这是一个创建于 2963 天前的主题,其中的信息可能已经有所发展或是发生改变。

    需求,有两对象,一个是程序(program),一个是程序的运行实例( instance)。现在要提供以下接口: 1.重启实例 2.启动新实例 3.停止实例 4.软重启实例 4.软启动 5.软停止

    软 xx 一般就是先把总线的路由策略切换到其他实例,使请求不会被路由到正在操作的实例。

    重启和停止接口还要支持批量操作。

    这 URL 该怎么设计?

    只能想到一个比较贴切的 停止实例 DELETE /instances/

    9 条回复    2016-11-16 09:31:25 +08:00
    mooncakejs
        1
    mooncakejs  
       2016-11-14 23:10:02 +08:00 via iPhone
    post instance/state
    guyskk
        2
    guyskk  
       2016-11-14 23:24:18 +08:00 via Android
    这是 restful 不明确的地方,不要硬套 restful , restful 也有缺陷。
    建议,全部 POST:
    /program/restart
    /program/start
    /program/soft_restart
    ...
    批量操作的参数全部用实例 ID 列表
    schezukNewTos
        3
    schezukNewTos  
       2016-11-14 23:28:57 +08:00
    首先你要设计一个状态机……

    @guyskk 你直接说“抛弃 REST ”好了,用不着写这么长……
    murmur
        4
    murmur  
       2016-11-14 23:31:49 +08:00   ❤️ 1
    这设计要什么 rest 这是典型的面向装逼 /面向简历编程
    传统方式 program?act=reset/new/stop/soft_restart/soft_start/soft_stop
    完美解决
    dremy
        5
    dremy  
       2016-11-15 00:26:26 +08:00 via Android   ❤️ 1
    orvice
        6
    orvice  
       2016-11-15 00:30:31 +08:00
    没必要硬套 rest 的啦。
    smallpath
        7
    smallpath  
       2016-11-15 01:18:29 +08:00 via Android
    rest 多对多就是这么蛋疼
    wupher
        8
    wupher  
       2016-11-15 10:21:42 +08:00
    将对象视作命令比看成资源在这个场景下会更合理一些。

    非要看作资源也不是不能硬套:
    启动新实例 和 停止可看成增删,其余的视作状态修改。
    docee
        9
    docee  
       2016-11-16 09:31:25 +08:00
    Rest 最重要的在于状态转移或无状态,你这个只是 URL 规则生搬硬套而已。传统通过 token 之类的来转移状态,最多只能称为 RESTless 。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5737 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 02:52 · PVG 10:52 · LAX 18:52 · JFK 21:52
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.