0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線(xiàn)課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

求一種SaaS模式下多租戶(hù)系統(tǒng)數(shù)據(jù)隔離實(shí)現(xiàn)方案

jf_ro2CN3Fa ? 來(lái)源:稀土掘金 ? 2023-07-27 10:34 ? 次閱讀

1.背景

開(kāi)發(fā)過(guò)SaaS系統(tǒng)平臺(tái)的小伙伴一定對(duì)多租戶(hù)這個(gè)概念不陌生,簡(jiǎn)單來(lái)說(shuō)一個(gè)租戶(hù)就是一個(gè)公司客戶(hù),多個(gè)租戶(hù)共用同一個(gè)SaaS系統(tǒng),一旦SaaS系統(tǒng)不可用,那么所有的租戶(hù)都不可用。你可以這么理解SaaS系統(tǒng)就像一棟大樓,而租戶(hù)就是大樓里面租辦公樓層的公司,平時(shí)每家公司做著自己的業(yè)務(wù),互不干擾,但是一旦大樓的電梯壞了,那么影響到的就是所有的公司。

多租戶(hù)問(wèn)題,其是一種架構(gòu)設(shè)計(jì)方式,就是在一臺(tái)或者一組服務(wù)器上運(yùn)行的SaaS系統(tǒng),可以為多個(gè)租戶(hù)(客戶(hù))提供服務(wù),目的是為了讓多個(gè)租戶(hù)在互聯(lián)網(wǎng)環(huán)境下使用同一套程序,且保證租戶(hù)間的數(shù)據(jù)隔離。

從這種架構(gòu)設(shè)計(jì)的模式上,不難看出來(lái),多租戶(hù)架構(gòu)的重點(diǎn)就是同一套程序下多個(gè)租戶(hù)數(shù)據(jù)的隔離。由于租戶(hù)數(shù)據(jù)是集中存儲(chǔ)的,所以要實(shí)現(xiàn)數(shù)據(jù)的安全性,就是看能否實(shí)現(xiàn)對(duì)租戶(hù)數(shù)據(jù)的隔離,防止租戶(hù)數(shù)據(jù)不經(jīng)意或被他人惡意地獲取和篡改。在講多租戶(hù)數(shù)據(jù)隔離實(shí)現(xiàn)之前,先來(lái)看看什么是SaaS系統(tǒng)。

什么是SaaS系統(tǒng) ?

SaaS平臺(tái)是運(yùn)營(yíng)saas軟件的平臺(tái)。SaaS提供商為企業(yè)搭建信息化所需要的所有網(wǎng)絡(luò)基礎(chǔ)設(shè)施及軟件、硬件運(yùn)作平臺(tái),并負(fù)責(zé)所有前期的實(shí)施、后期的維護(hù)等一系列服務(wù),租戶(hù)(企業(yè))無(wú)需購(gòu)買(mǎi)軟硬件、建設(shè)機(jī)房、招聘IT人員,即可通過(guò)互聯(lián)網(wǎng)使用信息系統(tǒng)。SaaS 是一種軟件布局模型,其應(yīng)用專(zhuān)為網(wǎng)絡(luò)交付而設(shè)計(jì),便于用戶(hù)通過(guò)互聯(lián)網(wǎng)托管、部署及接入。

簡(jiǎn)單來(lái)說(shuō)就是租戶(hù)給SaaS平臺(tái)付租金就能使用平臺(tái)提供的功能服務(wù),當(dāng)下比較典型就是各種云平臺(tái)、云服務(wù)廠商。

基于 Spring Boot + MyBatis Plus + Vue & Element 實(shí)現(xiàn)的后臺(tái)管理系統(tǒng) + 用戶(hù)小程序,支持 RBAC 動(dòng)態(tài)權(quán)限、多租戶(hù)、數(shù)據(jù)權(quán)限、工作流、三方登錄、支付、短信、商城等功能

項(xiàng)目地址:https://github.com/YunaiV/ruoyi-vue-pro

視頻教程:https://doc.iocoder.cn/video/

2.多租戶(hù)數(shù)據(jù)隔離架構(gòu)設(shè)計(jì)

目前saas多租戶(hù)系統(tǒng)的數(shù)據(jù)隔離有三種架構(gòu)設(shè)計(jì),即為每個(gè)租戶(hù)提供獨(dú)立的數(shù)據(jù)庫(kù)、獨(dú)立的表空間、按字段區(qū)分租戶(hù),每種方案都有其各自的適用情況。

一個(gè)租戶(hù)獨(dú)立一個(gè)數(shù)據(jù)庫(kù)

一個(gè)租戶(hù)獨(dú)立使用一個(gè)數(shù)據(jù)庫(kù),那就意味著我們的SaaS系統(tǒng)需要連接多個(gè)數(shù)據(jù)庫(kù),這種實(shí)現(xiàn)方案其實(shí)就和分庫(kù)分表架構(gòu)設(shè)計(jì)是一樣的,好處就是數(shù)據(jù)隔離級(jí)別高、安全性好,畢竟一個(gè)租戶(hù)單用一個(gè)數(shù)據(jù)庫(kù),但是物理硬件成本,維護(hù)成本也變高了。

獨(dú)立的表空間

這種方案的實(shí)現(xiàn)方式,就是所有租戶(hù)共用一個(gè)數(shù)據(jù)庫(kù)系統(tǒng),但是每個(gè)租戶(hù)在數(shù)據(jù)庫(kù)系統(tǒng)中擁有一個(gè)獨(dú)立的表空間。

按租戶(hù)id字段隔離租戶(hù)

這種方案是多租戶(hù)方案中最簡(jiǎn)單的數(shù)據(jù)隔離方法,即在每張表中都添加一個(gè)用于區(qū)分租戶(hù)的字段(如tenant_id或org_id啥的)來(lái)標(biāo)識(shí)每條數(shù)據(jù)屬于哪個(gè)租戶(hù),當(dāng)進(jìn)行查詢(xún)的時(shí)候每條語(yǔ)句都要添加該字段作為過(guò)濾條件,其特點(diǎn)是所有租戶(hù)的數(shù)據(jù)全都存放在同一個(gè)表中,數(shù)據(jù)的隔離性是最低的,完全是通過(guò)字段來(lái)區(qū)分的,很容易把數(shù)據(jù)搞串或者誤操作。

三種數(shù)據(jù)隔離架構(gòu)設(shè)計(jì)的對(duì)比如下:

隔離方案 成本 支持租戶(hù)數(shù)量 優(yōu)點(diǎn) 缺點(diǎn)
獨(dú)立數(shù)據(jù)庫(kù)系統(tǒng) 數(shù)據(jù)隔離級(jí)別高,安全性,可以針對(duì)單個(gè)租戶(hù)開(kāi)發(fā)個(gè)性化需求 數(shù)據(jù)庫(kù)獨(dú)立安裝,物理成本和維護(hù)成本都比較高
獨(dú)立的表空間 較多 提供了一定程度的邏輯數(shù)據(jù)隔離,一個(gè)數(shù)據(jù)庫(kù)系統(tǒng)可支持多個(gè)租戶(hù) 數(shù)據(jù)庫(kù)管理比較困難,表繁多,同時(shí)數(shù)據(jù)修復(fù)稍復(fù)雜
按租戶(hù)id字段區(qū)分 維護(hù)和購(gòu)置成本最低,每個(gè)數(shù)據(jù)庫(kù)能夠支持的租戶(hù)數(shù)量最多 隔離級(jí)別最低,安全性也最低

大部分公司都是采用第三種:按租戶(hù)id字段隔離租戶(hù) 架構(gòu)設(shè)計(jì)實(shí)現(xiàn)多租戶(hù)數(shù)據(jù)隔離的。接下來(lái)我們就來(lái)看看代碼層面怎么實(shí)現(xiàn)多租戶(hù)數(shù)據(jù)隔離的。

基于 Spring Cloud Alibaba + Gateway + Nacos + RocketMQ + Vue & Element 實(shí)現(xiàn)的后臺(tái)管理系統(tǒng) + 用戶(hù)小程序,支持 RBAC 動(dòng)態(tài)權(quán)限、多租戶(hù)、數(shù)據(jù)權(quán)限、工作流、三方登錄、支付、短信、商城等功能

項(xiàng)目地址:https://github.com/YunaiV/yudao-cloud

視頻教程:https://doc.iocoder.cn/video/

3.mybatis-plus優(yōu)雅實(shí)現(xiàn)多租戶(hù)數(shù)據(jù)權(quán)限隔離

上面我們說(shuō)過(guò)按租戶(hù)id字段隔離租戶(hù) 這種方式就是在獲取數(shù)據(jù)的時(shí)候?qū)γ恳粭lSQL語(yǔ)句添加租戶(hù)id作為過(guò)濾條件來(lái)隔離租戶(hù)數(shù)據(jù)的。但是這樣意味著每個(gè)查詢(xún)SQL都必須加上租戶(hù)id這個(gè)過(guò)濾條件,如果漏加就意味著會(huì)查詢(xún)出不同租戶(hù)的數(shù)據(jù),這是絕對(duì)不允許的,同時(shí)每個(gè)查詢(xún)接口都需要手動(dòng)設(shè)置過(guò)濾條件,重復(fù)勞動(dòng),一點(diǎn)都不夠優(yōu)雅。這時(shí)候就不得不說(shuō)說(shuō)mybatis-plus的多租戶(hù)插件了,看看它如何優(yōu)雅實(shí)現(xiàn)多租戶(hù)隔離的?

再講述之前,我們先思考一下如何優(yōu)雅實(shí)現(xiàn)數(shù)據(jù)隔離?首先我們要求每一條SQL都加上租戶(hù)id這個(gè)過(guò)濾條件,這意味著我們需要解析原始SQL在合適的地方加上租戶(hù)id過(guò)濾條件,我們知道m(xù)ybatis提供擴(kuò)展點(diǎn)就是攔截器,可以對(duì)SQL語(yǔ)句處理前后進(jìn)行增強(qiáng)邏輯,分頁(yè)插件就是這么做的,所以我們這里要增強(qiáng)SQL自然也是這樣,接下來(lái)我們就來(lái)看看mybatis-plus多租戶(hù)插件是怎么實(shí)現(xiàn)多租戶(hù)數(shù)據(jù)隔離的。

該攔截器部分源碼如下:

publicclassTenantLineInnerInterceptorextendsJsqlParserSupportimplementsInnerInterceptor{
//多租戶(hù)處理器
privateTenantLineHandlertenantLineHandler;

//改SQL,添加多租戶(hù)id條件
publicvoidbeforeQuery(Executorexecutor,MappedStatementms,Objectparameter,RowBoundsrowBounds,ResultHandlerresultHandler,BoundSqlboundSql)throwsSQLException{
if(!InterceptorIgnoreHelper.willIgnoreTenantLine(ms.getId())){
MPBoundSqlmpBs=PluginUtils.mpBoundSql(boundSql);
mpBs.sql(this.parserSingle(mpBs.sql(),(Object)null));
}
}

publicvoidbeforePrepare(StatementHandlersh,Connectionconnection,IntegertransactionTimeout){
MPStatementHandlermpSh=PluginUtils.mpStatementHandler(sh);
MappedStatementms=mpSh.mappedStatement();
SqlCommandTypesct=ms.getSqlCommandType();
if(sct==SqlCommandType.INSERT||sct==SqlCommandType.UPDATE||sct==SqlCommandType.DELETE){
if(InterceptorIgnoreHelper.willIgnoreTenantLine(ms.getId())){
return;
}

MPBoundSqlmpBs=mpSh.mPBoundSql();
mpBs.sql(this.parserMulti(mpBs.sql(),(Object)null));
}

}

//礙于篇幅問(wèn)題,下面省略的代碼就是繼承抽象類(lèi)JsqlParserSupport解析SQL然后添加多租戶(hù)id條件的,可以自行查看源碼
......
}

接著我們來(lái)看看處理器TenantLineHandler,這是一個(gè)接口,需要我們提供自定義實(shí)現(xiàn),指定多租戶(hù)相關(guān)配置:

publicclassTenantDatabaseHandlerimplementsTenantLineHandler{
privatefinalSetignoreTables=newHashSet<>();

publicTenantDatabaseHandler(TenantPropertiesproperties){
//將配置文件配置的忽略表名同步大小寫(xiě),適配不同寫(xiě)法
properties.getIgnoreTables().forEach(table->{
ignoreTables.add(table.toLowerCase());
ignoreTables.add(table.toUpperCase());
});
}

/**
*獲取租戶(hù)字段名
*

*默認(rèn)字段名叫:tenant_id,我這里使用org_id * *@return租戶(hù)字段名 */ @Override publicStringgetTenantIdColumn(){ return"org_id"; } @Override publicExpressiongetTenantId(){ //這里通過(guò)登錄信息上下文返回租戶(hù)id給多租戶(hù)攔截器增強(qiáng)SQL使用 returnnewLongValue(RequestUserHolder.getCurrentUser().getOrgId()); } @Override publicbooleanignoreTable(StringtableName){ //忽略多租戶(hù)的表 returnCollUtil.contains(ignoreTables,tableName); } }

配置屬性如下:

@ConfigurationProperties(prefix="ptc.tenant")
@Data
publicclassTenantProperties{


/**
*全局控制是否開(kāi)啟多租戶(hù)功能
*/
privateBooleanenable=Boolean.TRUE;

/**
*需要忽略多租戶(hù)的表
*
*即默認(rèn)所有表都開(kāi)啟多租戶(hù)的功能,所以記得添加對(duì)應(yīng)的tenant_id字段喲
*/
privateSetignoreTables=Collections.emptySet();
}

接下來(lái)注入攔截器插件即可:

@Bean
publicMybatisPlusInterceptormybatisPlusInterceptor(TenantPropertiesproperties){
MybatisPlusInterceptormybatisPlusInterceptor=newMybatisPlusInterceptor();
//必須保證多租戶(hù)插件在分頁(yè)插件之前,這個(gè)是MyBatis-plus的規(guī)定
if(properties.getEnable()){
mybatisPlusInterceptor.addInnerInterceptor(newTenantLineInnerInterceptor(newTenantDatabaseHandler(properties)));
}
//分頁(yè)插件
mybatisPlusInterceptor.addInnerInterceptor(newPaginationInnerInterceptor());
returnmybatisPlusInterceptor;
}

使用示例如下:這里提供了一個(gè)常見(jiàn)的案例:用戶(hù)和角色關(guān)聯(lián)查詢(xún)的SQL:getUserList()


selectu.*fromuseru
leftjoinuser_roleronu.id=r.user_id


andu.status=#{query.status}


andr.role_id=#{query.roleId}


and((u.namelikeconcat('%',#{query.keyword},'%'))or(u.mobilelikeconcat(#{query.keyword},'%')))


andu.entry_time>=#{query.startEntryTime}






groupbyu.id
orderbyu.iddesc

啟動(dòng)項(xiàng)目,先登錄之后使用token掉接口執(zhí)行下面代碼邏輯:

publicPageResultgetList(UserQueryquery){
Pagepage=newPage<>(query.getPageNo(),query.getPageSize());
ListuserList=userDAO.getUserList(page,query);
ListuserDTOS=toUserDTOList(userList);
returnnewPageResult<>(userDTOS,page.getTotal(),page.getPages());
}

查看控制臺(tái)發(fā)現(xiàn):

[1658720355293990912][DEBUG][2023-05-1714:25:25.504][http-nio-16688-exec-1@23652]com.plasticene.textile.dao.UserDAO.getUserListdebug:==>Preparing:SELECTu.*FROMuseruLEFTJOINuser_rolerONu.id=r.user_idANDr.org_id=3WHEREu.org_id=3GROUPBYu.idORDERBYu.idDESCLIMIT?
[1658720355293990912][DEBUG][2023-05-1714:25:25.505][http-nio-16688-exec-1@23652]com.plasticene.textile.dao.UserDAO.getUserListdebug:==>Parameters:20(Long)

user表u加上u.org_id=3這個(gè)多租戶(hù)過(guò)濾條件,user_role也同樣加上了,說(shuō)明多租戶(hù)插件起作用了。

當(dāng)然如果想忽略掉表user,我們只需要在配置文件如下配置即可:

ptc:
tenant:
ignore-tables:user

這樣user表u就不會(huì)再加上u.org_id=3這個(gè)多租戶(hù)過(guò)濾條件,但是這里有一個(gè)細(xì)節(jié)需要注意,由于user在MySQL中是關(guān)鍵字,所以我有時(shí)候?yàn)榱艘?guī)范書(shū)寫(xiě)SQL,會(huì)按照如下編寫(xiě):

selectu.*from`user`u
leftjoinuser_roleronu.id=r.user_id

這時(shí)候你會(huì)發(fā)現(xiàn)上面配置的忽略表user不起作用,還是會(huì)加上u.org_id=3這個(gè)多租戶(hù)過(guò)濾條件,跟源碼才發(fā)現(xiàn)我們上面自定義的多租戶(hù)處理器TenantLineHandler只對(duì)表名進(jìn)行了大小寫(xiě)適配,然而這里SQL解析出來(lái)的表名是: user ,所以匹配不到配置不起作用。

當(dāng)然我們有可能需要針對(duì)單一SQL語(yǔ)句不加多租戶(hù)過(guò)濾條件,可以使用@InterceptorIgnore注解:

publicinterfaceUserDAOextendsBaseMapperX{

@InterceptorIgnore(tenantLine="true")
ListgetUserList(IPageuserPage,@Param("query")UserQueryquery);
}

這樣調(diào)用getUserList()不再會(huì)加多租戶(hù)過(guò)濾條件了。

通過(guò)上面我們知道了這個(gè)多租戶(hù)插件其實(shí)就是通過(guò)解析SQL,然后進(jìn)行拼接多租戶(hù)id過(guò)濾條件來(lái)實(shí)現(xiàn)SQL增強(qiáng)從而做到數(shù)據(jù)隔離,解析SQL的框架叫:JSqlParser

官方文檔:

https://github.com/JSQLParser/JSqlParser/wiki

Druid也可以解析SQL,我們都知道SQL語(yǔ)句會(huì)生成語(yǔ)法樹(shù),兩者對(duì)SQL解析的孰強(qiáng)孰弱(特別是復(fù)雜SQL)不得而知,可以自行驗(yàn)證對(duì)比,我這里給出一個(gè)JSqlParser解析出錯(cuò)的情況,把上面的SQL語(yǔ)句user_role r 改為 user_role ur

selectu.*fromuseru
leftjoinuser_roleuronu.id=ur.user_id

按照上面一樣調(diào)用執(zhí)行g(shù)etUserList(), 會(huì)報(bào)解析錯(cuò)誤:

Causedby:com.baomidou.mybatisplus.core.exceptions.MybatisPlusException:Failedtoprocess,ErrorSQL:selectu.*fromuseru
leftjoinuser_roleuronu.id=ur.user_id
groupbyu.id
orderbyu.iddesc
atcom.baomidou.mybatisplus.core.toolkit.ExceptionUtils.mpe(ExceptionUtils.java:39)
atcom.baomidou.mybatisplus.extension.parser.JsqlParserSupport.parserSingle(JsqlParserSupport.java:52)
atcom.baomidou.mybatisplus.extension.plugins.inner.TenantLineInnerInterceptor.beforeQuery(TenantLineInnerInterceptor.java:65)
atcom.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor.intercept(MybatisPlusInterceptor.java:78)
atorg.apache.ibatis.plugin.Plugin.invoke(Plugin.java:62)
atcom.sun.proxy.$Proxy178.query(UnknownSource)
atorg.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:151)
...101commonframesomitted
Causedby:net.sf.jsqlparser.parser.ParseException:Encounteredunexpectedtoken:"ur"
atline2,column29.

我在mybatis-plus的官方提了一個(gè)issue:https://github.com/baomidou/mybatis-plus/issues/5086,也得到官方維護(hù)者的迅速回應(yīng)說(shuō)是JSqlParser解析的問(wèn)題,不是mybatis-plus的問(wèn)題~~~,給出的建議就是把別名ur改成別的,或者升級(jí)到JSqlParser的最新版本。

4.總結(jié)

至此,我們對(duì)多租戶(hù)系統(tǒng)數(shù)據(jù)隔離實(shí)現(xiàn)方案,架構(gòu)設(shè)計(jì),以及如何優(yōu)雅實(shí)現(xiàn)全局操作數(shù)據(jù)隔離都講完了,同時(shí)也對(duì)mybati-plus的多租戶(hù)插件實(shí)現(xiàn)原理和源碼流程套路進(jìn)行了淺析,也對(duì)實(shí)際應(yīng)用案例中進(jìn)行了舉證并闡述了相關(guān)細(xì)節(jié)點(diǎn)。

當(dāng)然數(shù)據(jù)權(quán)限不止停留在租戶(hù)(公司)層面上面,大多數(shù)系統(tǒng)的數(shù)據(jù)權(quán)限會(huì)按照業(yè)務(wù)組織架構(gòu)角色來(lái)控制,數(shù)據(jù)權(quán)限其套路和根據(jù)角色判斷菜單權(quán)限一回事。

由于數(shù)據(jù)權(quán)限通常與公司業(yè)務(wù)相關(guān),比較個(gè)性化,每家公司業(yè)務(wù)組織架構(gòu)不盡相同,所以實(shí)際開(kāi)發(fā)項(xiàng)目的數(shù)據(jù)權(quán)限隔離還需要大家按實(shí)際需求進(jìn)行修改,但總的來(lái)說(shuō)我們可以模仿多租戶(hù)隔離實(shí)現(xiàn)方式,比如說(shuō)一個(gè)業(yè)務(wù)系統(tǒng)組織架構(gòu)有公司(org_id),公司下有多個(gè)部門(mén)(dept_id),部門(mén)下有多個(gè)團(tuán)隊(duì)分組(team_id),團(tuán)隊(duì)下有多個(gè)人員(user_id)。

不同角色只能看到不同數(shù)據(jù),部門(mén)經(jīng)理只能看到自己部門(mén)的數(shù)據(jù),小組長(zhǎng)只能看到自己小組的數(shù)據(jù),這些實(shí)現(xiàn)邏輯套路都可以模仿多租戶(hù)插件的方式進(jìn)行優(yōu)雅實(shí)現(xiàn),這也是我后面有時(shí)間想研究的,后續(xù)會(huì)再出一篇數(shù)據(jù)權(quán)限的實(shí)現(xiàn)方案總結(jié)。






審核編輯:劉清

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 處理器
    +關(guān)注

    關(guān)注

    68

    文章

    18927

    瀏覽量

    227231
  • SQL
    SQL
    +關(guān)注

    關(guān)注

    1

    文章

    750

    瀏覽量

    43900
  • SaaS
    +關(guān)注

    關(guān)注

    1

    文章

    358

    瀏覽量

    36752
  • MYSQL數(shù)據(jù)庫(kù)

    關(guān)注

    0

    文章

    95

    瀏覽量

    9348
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    什么是SaaS

    額外的成本,企業(yè)仍然需要購(gòu)買(mǎi)、構(gòu)建和維護(hù)自己獨(dú)立的IT基礎(chǔ)設(shè)備。SaaS為企業(yè)提供了另外一種選擇。如今,企業(yè)可以自行安裝注冊(cè),并通過(guò)互聯(lián)網(wǎng)使用共享的基礎(chǔ)設(shè)施服務(wù)。 促使客戶(hù)采取SaaS解決方案
    發(fā)表于 07-13 09:23

    一種基于嵌入式系統(tǒng)隔離硬件設(shè)計(jì)

    本文在對(duì)已有的防火墻技術(shù)及物理隔離技術(shù)進(jìn)行分析的基礎(chǔ)上,提出了帶緩沖區(qū)的雙通道實(shí)時(shí)開(kāi)關(guān)技術(shù),通過(guò)該技術(shù)所設(shè)計(jì)出的網(wǎng)絡(luò)隔離器能滿(mǎn)足實(shí)時(shí)數(shù)據(jù)的傳輸,同時(shí)本文提出了一種物理
    發(fā)表于 04-25 07:58

    一種通道同步數(shù)據(jù)采集及壓縮系統(tǒng)的設(shè)計(jì)方案  

    一種通道同步數(shù)據(jù)采集及壓縮系統(tǒng)的設(shè)計(jì)方案?! ?/div>
    發(fā)表于 04-28 06:13

    大神分享一種高速突發(fā)模式誤碼測(cè)試儀的FPGA實(shí)現(xiàn)方案

    大神分享一種高速突發(fā)模式誤碼測(cè)試儀的FPGA實(shí)現(xiàn)方案
    發(fā)表于 04-29 06:58

    大佬分享一種光譜可見(jiàn)光遙感圖像壓縮系統(tǒng)的設(shè)計(jì)方案

    大佬分享一種光譜可見(jiàn)光遙感圖像壓縮系統(tǒng)的設(shè)計(jì)方案
    發(fā)表于 06-02 06:39

    一種基于Android和Zigbee技術(shù)實(shí)現(xiàn)的家庭環(huán)境監(jiān)控系統(tǒng)的設(shè)計(jì)方案

    齊全、運(yùn)行穩(wěn)定的家庭監(jiān)控系統(tǒng)將具有非常大的市場(chǎng)競(jìng)爭(zhēng)力。本文提出了一種基于Android和Zigbee技術(shù)實(shí)現(xiàn)的家庭環(huán)境監(jiān)控系統(tǒng)的設(shè)計(jì)方案,該
    發(fā)表于 07-26 08:08

    一種基于STM8系列單片機(jī)的無(wú)線(xiàn)通信系統(tǒng)的設(shè)計(jì)與實(shí)現(xiàn)方案

    一種基于STM8系列單片機(jī)的無(wú)線(xiàn)通信系統(tǒng)的設(shè)計(jì)與實(shí)現(xiàn)方案
    發(fā)表于 12-17 06:23

    一種基于單片機(jī)的拖尾式模式流水燈系統(tǒng)仿真設(shè)計(jì)

    一種基于單片機(jī)的拖尾式模式流水燈系統(tǒng)仿真設(shè)計(jì)
    發(fā)表于 02-17 06:59

    奧威軟件SaaS BI系統(tǒng)站式數(shù)據(jù)可視化解決方案

    SaaS BI 系統(tǒng)是 Software as a Service 商業(yè)智能的縮寫(xiě),是一種基于云計(jì)算的商業(yè)智能解決方案。它允許用戶(hù)通過(guò)互聯(lián)網(wǎng)訪問(wèn)和分析
    發(fā)表于 08-01 10:21

    一種租戶(hù)場(chǎng)景基于SLO的調(diào)度機(jī)制

    針對(duì)租戶(hù)集群中無(wú)法保證作業(yè)服務(wù)水平目標(biāo)( SLO)的問(wèn)題,提出了一種租戶(hù)場(chǎng)景基于SLO的調(diào)
    發(fā)表于 01-12 15:37 ?0次下載

    可信云租戶(hù)隔離機(jī)制

    安全隔離機(jī)制的建設(shè)和管理過(guò)程,因此他們難以對(duì)云租戶(hù)隔離機(jī)制的安全有效性建立信心.將透明性要求視為可信云租戶(hù)隔離機(jī)制的
    發(fā)表于 01-13 10:21 ?0次下載

    Kubernetes租戶(hù)集群的概念和常見(jiàn)的應(yīng)用模式

    KaaS 租戶(hù)方案通常與云服務(wù)提供商有關(guān)。在這種場(chǎng)景,業(yè)務(wù)平臺(tái)的服務(wù)通過(guò) Kubernetes 控制平面直接暴露給不同租戶(hù)的用戶(hù)。最終用
    的頭像 發(fā)表于 05-15 16:13 ?1075次閱讀
    Kubernetes<b class='flag-5'>多</b><b class='flag-5'>租戶(hù)</b>集群的概念和常見(jiàn)的應(yīng)用<b class='flag-5'>模式</b>

    基于SpringBoot實(shí)現(xiàn)租戶(hù)架構(gòu):支持應(yīng)用租戶(hù)部署和管理

    租戶(hù)架構(gòu)是指在個(gè)應(yīng)用中支持多個(gè)租戶(hù)(Tenant)同時(shí)訪問(wèn),每個(gè)租戶(hù)擁有獨(dú)立的資源和數(shù)據(jù),并
    的頭像 發(fā)表于 06-05 10:20 ?1200次閱讀

    什么叫做saas,mybatis-plus優(yōu)雅實(shí)現(xiàn)租戶(hù)數(shù)據(jù)權(quán)限隔離方案

    租戶(hù)問(wèn)題,其是一種架構(gòu)設(shè)計(jì)方式,就是在臺(tái)或者組服務(wù)器上運(yùn)行的SaaS
    發(fā)表于 07-27 10:34 ?3813次閱讀

    SaaS 租戶(hù)MES生產(chǎn)車(chē)間管理系統(tǒng)源碼,生產(chǎn)排程,工藝流程,工序采集

    MES系統(tǒng),即制造執(zhí)行系統(tǒng)(Manufacturing Execution System),是一種用于管理和監(jiān)控制造過(guò)程的軟件系統(tǒng)。 它位于企業(yè)資源計(jì)劃(ERP)
    的頭像 發(fā)表于 08-14 17:31 ?158次閱讀
    <b class='flag-5'>SaaS</b> <b class='flag-5'>多</b><b class='flag-5'>租戶(hù)</b>MES生產(chǎn)車(chē)間管理<b class='flag-5'>系統(tǒng)</b>源碼,生產(chǎn)排程,工藝流程,工序采集