当前位置:首页 > Saas > 正文内容

saas介绍和原理

关中浪子2个月前 (02-21)Saas163
【腾讯云】2核2G4M云服务器新老同享99元/年,续费同价

SaaS就是多租户,一个应用可以分给很多用户使用,而应用只需要维护一个。那么应用就需要做好各种资源的隔离(数据库,文件,缓存,队列,后台,命令行等等)。
有两种类型的多租户SaaS形式:

1,单数据库SaaS:

租户共享一个数据库,其数据使用 where tenant_id=1 子句分隔。



代码原理,利用scoping插入租户过滤:


缺点: 所有语句都需要租户过滤,所有数据库都需要租户识别(+tenant_id),不兼容第三方组件,开发繁琐困难,同时不好维护。


2,多数据库SaaS:

每个租户都有自己的数据库。


代码原理,识别租户后,切换数据库和相关租户资源:


优点:基本上相当便捷的把原来的单租户程序变成多租户,同时多租户也容易转为单租户。很容易的利用原有技术开发,利用生态的第三方插件/包,技术上是高效便利,商业上成本低廉,就是我们需要的方案。


更多详细,可以参考PPT:SaaS多租户技术是什么 – 湾区梁工 (liangdabiao.com)




多数据库SaaS开发要注意:

注意0:租户识别

多数据库租赁】模式,是我们要探讨的,关键在于租户识别(Tenant identification),整个流程大概如下:
1,租户域名–》识别租户–》切换租户数据库–》切换各种资源–》运行应用–》运行相应任务命令
2,主域名–》识别管理员–》切换主数据库–》运行管理后台–》管理租户

注意1:队列Queue要标识

注意2:命令行要标识



不指定租户的情况,就是轮询全部租户,执行命令:

注意3:上传图片/文件要识别和隔离

注意4:缓存要识别

例如redis,主要是通过加上前缀[prefix_XX]来识别和隔离缓存资源。

注意5:调用外部资源要识别

例如在webhook 的url 加上 租户的识别 tenant_id



介绍Laravel SaaS 多租户包 :archtechx/tenancy

GitHub – archtechx/tenancy: Automatic multi-tenancy for Laravel. No code changes needed.
文档:https://tenancyforlaravel.com/docs/v3/introduction
简单DEMO:https://github.com/Abbotton/saas-skeleton
github有几个类似的SaaS包,不过这个是最简单高效,能够实现以上所说的saas功能,所以就推荐这个,接下来都是以这个saas包来讲解。

archtechx/tenancy 包原理:

1,租户域名触发多租户事件,进入多租户的路由和执行相关中间件middleware
2,多租户中间件middleware 选择合适的租户,并且执行相关切换和任务。具体流程如下:

$this->tenancy->initialize($tenant);  //初始化租户
  • 租户触发事件:TheStancl\Tenancy\Tenancyclass sets the$tenantas the current tenant and fires aTenancy Initializedevent

  • 事件触发启动任务:TheBootstrap Tenancyclass catches the event and executes classes known as tenancy bootstrappers.

  • 任务启动租户资源隔离:The tenancy bootstrappers make changes to the application to make it “scoped” to the current tenant. This by default includes:

    • Switching the database connection

    • ReplacingCacheManagerwith a scoped cache manager

    • Suffixing filesystem paths

    • Making queues store the tenant id & initialize tenancy when being processed

  • 最后结束,恢复主库:
    Conversely, when theTenancy Endedevent fires, theRevert To Central Contextevent transitions the app back into the central context.



开发SaaS的好处:

  • 节省成本,付费灵活

  • 开发容易,把原有系统改造成saas

  • 维护容易,只需要维护一个程序

  • 【自定义样式 + 自定义 form 】:让客户低代码实现功能,例如模板设计

  • 可安装插件,扩展功能容易

  • 可以分配账号:管理员,员工账号

  • 新技术的尝新,减少障碍使用人工智能,大数据等新技术

  • 资源隔离,数据安全,同时也方便客户把应用转变为私有应用。


扫描二维码推送至手机访问。

版权声明:本文由码农翻生发布,如需转载请注明出处。

本文链接:https://lubojian.cn/post/266.html

分享给朋友:
返回列表

没有更早的文章了...

下一篇:SaaS平台切换数据源实现原理

相关文章

SaaS平台切换数据源实现原理

SaaS平台切换数据源实现原理

前言 :SaaS平台的实现模式有3种 简单来说分别是 分字段 分表 分库这里作者展示的是隔离性最高的高的分库 当然对应的服务器成本也更高图一如图所示 总公司能够创建数据库并分账号图二创建数据库这里展示一下核心代码1.测试数据是否能正常连接p...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。