×
Copy
Open
Link
Embed
Share
Beginning
This slide
Copy link URL
Copy link URL
Copy iframe embed code
Copy iframe embed code
Copy javascript embed code
Copy javascript embed code
Share
Tweet
Share
Tweet
Slide 1
Slide 1 text
如何构建 SaaS 应用 王子龙 @cookiebody
Slide 2
Slide 2 text
SaaS 是什么? 面向企业的互联网软件。
Slide 3
Slide 3 text
SaaS 是什么? 面向企业的互联网软件。
Slide 4
Slide 4 text
SaaS 是什么? 面向企业的互联网软件。
Slide 5
Slide 5 text
SaaS 市场潜力怎样?
Slide 6
Slide 6 text
SaaS 市场潜力怎样?
Slide 7
Slide 7 text
消费市场 企业市场
Slide 8
Slide 8 text
构建 SaaS 之架构 虚拟化 Virtualization 多租户 Multitenancy
Slide 9
Slide 9 text
自动部署和更新 虚拟化
Slide 10
Slide 10 text
多租户 所有数据都通过租户区分 所有操作都包含租户ID
Slide 11
Slide 11 text
多租户数据存储架构 尽量避免运行期间执行DDL
Slide 12
Slide 12 text
构建 SaaS 之架构 一体化 Monolithic 微服务 Microservice
Slide 13
Slide 13 text
示例 数据库 博客 论坛 应用进程 添加验证码图片 添加全文搜索
Slide 14
Slide 14 text
一体化 数据库 博客 论坛 全文搜索 验证码 应用进程 全文索引 Image Magick CaptchaModule.generate CaptchaModule.validate(id, value) SearchModule.build(para) SearchModule.search(keyword)
Slide 15
Slide 15 text
微服务 数据库 博客 论坛 全文搜索 验证码 应用进程 全文索引 Image Magick 应用进程 应用进程 HTTP.post("captcha/generate") HTTP.post("captcha/validate", id, value) HTTP.post("search/build", para) HTTP.post("search", keyword)
Slide 16
Slide 16 text
No content
Slide 17
Slide 17 text
No content
Slide 18
Slide 18 text
构建 SaaS 之性能优化 热点数据长期缓存 慢操作异步化处理 Cache Database 获取 更改 App Worker Queue SSE Ajax Poll
Slide 19
Slide 19 text
构建 SaaS 之扩展 垂直扩展 水平扩展
Slide 20
Slide 20 text
三层结构 DB App App Web Server
Slide 21
Slide 21 text
水平扩展 DB App App Web Server Web Server App DB Load Balancer Replication 放在负载均衡之后 无状态的App,直接加 集群中加节点
Slide 22
Slide 22 text
水平扩展之数据库 Sharding 适合非结构化数据 无需跨DB的事务
Slide 23
Slide 23 text
水平扩展 节点1 节点2 节点3 同个用户的数据,都存储在同个节点中 每个节点,都包含完整的基础设施 10K+ 用户 / 节点 50+ 节点
Slide 24
Slide 24 text
Ruby 相关技术栈 App Server Web framework Database library
Slide 25
Slide 25 text
以往的企业软件,是为了提升工作效率。 目前,软件的机会,在于变革工作本身。 @levie Box CEO