如何构建 SaaS 应用 @RubyConfChina2015

0635256624bae219fdf0141893438fa8?s=47 Zilong Wang
October 11, 2015

如何构建 SaaS 应用 @RubyConfChina2015

介绍 SaaS 应用的架构,包括多租户、微服务、水平拓展等。

0635256624bae219fdf0141893438fa8?s=128

Zilong Wang

October 11, 2015
Tweet

Transcript

  1. 如何构建 SaaS 应用 王子龙 @cookiebody

  2. SaaS 是什么? 面向企业的互联网软件。

  3. SaaS 是什么? 面向企业的互联网软件。

  4. SaaS 是什么? 面向企业的互联网软件。

  5. SaaS 市场潜力怎样?

  6. SaaS 市场潜力怎样?

  7. 消费市场 企业市场

  8. 构建 SaaS 之架构 虚拟化 Virtualization 多租户 Multitenancy

  9. 自动部署和更新 虚拟化

  10. 多租户 所有数据都通过租户区分 所有操作都包含租户ID

  11. 多租户数据存储架构 尽量避免运行期间执行DDL

  12. 构建 SaaS 之架构 一体化 Monolithic 微服务 Microservice

  13. 示例 数据库 博客 论坛 应用进程  添加验证码图片  添加全文搜索

  14. 一体化 数据库 博客 论坛 全文搜索 验证码 应用进程 全文索引 Image Magick

    CaptchaModule.generate CaptchaModule.validate(id, value) SearchModule.build(para) SearchModule.search(keyword)
  15. 微服务 数据库 博客 论坛 全文搜索 验证码 应用进程 全文索引 Image Magick

    应用进程 应用进程 HTTP.post("captcha/generate") HTTP.post("captcha/validate", id, value) HTTP.post("search/build", para) HTTP.post("search", keyword)
  16. None
  17. None
  18. 构建 SaaS 之性能优化  热点数据长期缓存  慢操作异步化处理 Cache Database 获取

    更改 App Worker Queue SSE Ajax Poll
  19. 构建 SaaS 之扩展 垂直扩展 水平扩展

  20. 三层结构 DB App App Web Server

  21. 水平扩展 DB App App Web Server Web Server App DB

    Load Balancer Replication 放在负载均衡之后 无状态的App,直接加 集群中加节点
  22. 水平扩展之数据库 Sharding  适合非结构化数据  无需跨DB的事务

  23. 水平扩展 节点1 节点2 节点3 同个用户的数据,都存储在同个节点中 每个节点,都包含完整的基础设施 10K+ 用户 / 节点

    50+ 节点
  24. Ruby 相关技术栈  App Server  Web framework  Database

    library
  25. 以往的企业软件,是为了提升工作效率。 目前,软件的机会,在于变革工作本身。 @levie Box CEO