在为“最近在线的成员”应用 View 创建分页列表时,我们遇到了一个有趣的挑战。挑战的根源在于对定期更新的数据进行分页。
当成员(member)在应用程序中启动 View 时,只需调用数据库即可轻松获取给定位置的列表(例如,根据纽约最近的登录顺序)。这非常适用于第一组(第 1 页)。但是,当成员滚动并且应用程序请求下一组(第 2 页)时,列表可能会在其顶部添加新成员,这会导致结果集 1 和 2 之间发生重叠,依此类推。
为了让事情更复杂一点,我们希望将结果中的帐户 ID 存储在 Redis 中,以防止不必要的重复 MySQL 查询命中数据库并帮助加快速度。
我们考虑过使用时间戳作为起点。这个策略给了我们一个设定的时间点,确保我们的列表总是按顺序返回,直到成员拉取刷新列表。但是,此解决方案的问题意味着数据库每次都会受到攻击,并且无法有效使用 Redis。
此外,成员(member)可能会将他们的应用程序显示在“最近在线” View 中,离开应用程序并在 30 分钟后返回并继续从他们所在的位置滚动,这肯定会导致意想不到的结果。
有没有人有好的解决方案或策略来解决此类问题,同时又不会造成不稳定的用户体验和不必要的服务器资源负担?
最佳答案
我们已经制定了应对这一挑战的战略,这解决了我们正在努力完成的大部分问题。为了解决这个问题,我们正在实现以下措施。
当成员(member)请求“谁最近在线”时,我们会生成一个最多 150 个帐户的本地成员(member)列表。整个列表以逗号分隔的成员 ID 字符串传递给应用程序,以便应用程序拥有一组可以翻页的记录。这解决了依赖 API 了解成员在任何给定时间在列表中的位置的问题。
在初始请求中,我们还包含前 15 个最近登录帐户的成员(member)信息,这样无需再次调用 API 即可填充屏幕。由于我们已经传递了在线即时列表的完整快照,应用程序可以通过将他们的 ID 传递给我们的 API 来请求下一组 15 个帐户,以返回这些帐户详细信息。
当成员(member)执行下拉刷新或离开列表并在移动到应用程序的另一个区域后返回列表时,整个过程将重新开始。
这就是我们解决分页问题的方法。本质上是及时为应用程序提供快照,并让它翻阅该快照,直到需要更新/更新列表为止。
关于php - 数据不断变化时 "Recently Online"列表的排序策略(PHP),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37448123/
我正在尝试测试是否存在表单。我是Rails新手。我的new.html.erb_spec.rb文件的内容是:require'spec_helper'describe"messages/new.html.erb"doit"shouldrendertheform"dorender'/messages/new.html.erb'reponse.shouldhave_form_putting_to(@message)with_submit_buttonendendView本身,new.html.erb,有代码:当我运行rspec时,它失败了:1)messages/new.html.erbshou
我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
为了将Cucumber用于命令行脚本,我按照提供的说明安装了arubagem。它在我的Gemfile中,我可以验证是否安装了正确的版本并且我已经包含了require'aruba/cucumber'在'features/env.rb'中为了确保它能正常工作,我写了以下场景:@announceScenario:Testingcucumber/arubaGivenablankslateThentheoutputfrom"ls-la"shouldcontain"drw"假设事情应该失败。它确实失败了,但失败的原因是错误的:@announceScenario:Testingcucumber/ar
是否有类似“RVMuse1”或“RVMuselist[0]”之类的内容而不是键入整个版本号。在任何时候,我们都会看到一个可能包含5个或更多ruby的列表,我们可以轻松地键入一个数字而不是X.X.X。这也有助于rvmgemset。 最佳答案 这在RVM2.0中是可能的=>https://docs.google.com/document/d/1xW9GeEpLOWPcddDg_hOPvK4oeLxJmU3Q5FiCNT7nTAc/edit?usp=sharing-知道链接的任何人都可以发表评论
我遵循MichaelHartl的“RubyonRails教程:学习Web开发”,并创建了检查用户名和电子邮件长度有效性的测试(名称最多50个字符,电子邮件最多255个字符)。test/helpers/application_helper_test.rb的内容是:require'test_helper'classApplicationHelperTest在运行bundleexecraketest时,所有测试都通过了,但我看到以下消息在最后被标记为错误:ERROR["test_full_title_helper",ApplicationHelperTest,1.820016791]test
我正在尝试从Postgresql表(table1)中获取数据,该表由另一个相关表(property)的字段(table2)过滤。在纯SQL中,我会这样编写查询:SELECT*FROMtable1JOINtable2USING(table2_id)WHEREtable2.propertyLIKE'query%'这工作正常:scope:my_scope,->(query){includes(:table2).where("table2.property":query)}但我真正需要的是使用LIKE运算符进行过滤,而不是严格相等。然而,这是行不通的:scope:my_scope,->(que
我正在尝试编写一个将文件上传到AWS并公开该文件的Ruby脚本。我做了以下事情:s3=Aws::S3::Resource.new(credentials:Aws::Credentials.new(KEY,SECRET),region:'us-west-2')obj=s3.bucket('stg-db').object('key')obj.upload_file(filename)这似乎工作正常,除了该文件不是公开可用的,而且我无法获得它的公共(public)URL。但是当我登录到S3时,我可以正常查看我的文件。为了使其公开可用,我将最后一行更改为obj.upload_file(file
当我尝试安装Ruby时遇到此错误。我试过查看this和this但无济于事➜~brewinstallrubyWarning:YouareusingOSX10.12.Wedonotprovidesupportforthispre-releaseversion.Youmayencounterbuildfailuresorotherbreakages.Pleasecreatepull-requestsinsteadoffilingissues.==>Installingdependenciesforruby:readline,libyaml,makedepend==>Installingrub
有时我需要处理键/值数据。我不喜欢使用数组,因为它们在大小上没有限制(很容易不小心添加超过2个项目,而且您最终需要稍后验证大小)。此外,0和1的索引变成了魔数(MagicNumber),并且在传达含义方面做得很差(“当我说0时,我的意思是head...”)。散列也不合适,因为可能会不小心添加额外的条目。我写了下面的类来解决这个问题:classPairattr_accessor:head,:taildefinitialize(h,t)@head,@tail=h,tendend它工作得很好并且解决了问题,但我很想知道:Ruby标准库是否已经带有这样一个类? 最佳