Maison > Questions et réponses > le corps du texte
最近在做一个测试回归的系统,Server这边需要在每个Test执行的时候为它保留相关的数据,待测试结束后,删掉这些数据。
也就是这个数据只是临时的,一般一次测试用例大概就几分种,因此单挑数据的存在时间非常短。所以想要选用Redis做数据存储。
之前没有使用Key-Value数据存储的经验,我这边简单构想的单挑数据结构如下:
{ sessionId: 123454, gloablData: {}, // 在全局维持的数据 testWins: [ { winId: 123, parentWinId: 123, stats: 'running', testResult: {} } ] }
其中testWinds
为测试用所有可能会出现的窗口(窗口其实为浏览器窗口,这个可以无视),然后会为每个窗口记录信息,然后每个窗口有自己的子测试结果testResult
,是一个复杂数据(但是可以用JSON字符串来储存,因为Server对它的具体内容不关心,输出给需要的接口就行了),globalData也一样,server不关心,设置成JSON字符串
但是查看Redis文档,发现Redis貌似无法构建这么复杂的数据结构。
因此针对这样的需求,该如何设置这个数据库的结构?
我这边的简单设置是这样的:
对于每次测试:
有一条储存globalData:
session_id:globalData
和多条储存testWin数据:
session_id:testWind_id
其中globalData由于我这边的Server不关心也不会做查询,因此只保存JSON字符串,testResult也一样,这样的话,貌似其实就两种类型:
session_id:testWind_id: { winId: 123, parentWindId: 123, stat: 'running', testResult: JSONString } session_id:globalData: JSONString
迷茫2017-04-21 10:59:28
Le stockage et l'utilisation peuvent être encapsulés par des objets.
Pour votre situation, je la conserverais de cette façon.
Clé : "session:123454:globalData" Valeur : hash Le hachage de l'attribut est stocké ici (hget, hset)
Clé : "sesison:123454:testWins" Valeur : la liste stocke les identifiants des victoires de test
Clé : "session:123454:testWins:win_id" Valeur : hash Voici le hachage de l'attribut wins, qui est votre chaîne json.
Si vous le stockez ainsi, vous devez toujours l'encapsuler avec des objets
PHP中文网2017-04-21 10:59:28
Changez pour MongoDB. Il semble que vous ayez besoin d'une base de données basée sur des documents.