草庐IT

数据更新

全部标签

ruby-on-rails - Rails 查询执行导致数据库峰值

我的Rails应用程序出现问题,一些随机查询需要大约5秒或更长时间才能完成。大多数时候,查询非常简单(select*fromxwhereid=?),而且字段甚至也被编入索引。这里有一些关于设置的更多信息:反向nginx代理背后的Puma3.5.04个worker,每个worker最少4个,最多8个线程。Rubyv2.2.3,Railsv4.2.4PostgreSQL9.4数据库线程池设置为最多60个连接监控应用8GBRAM、4个CPU、SSD。我在查看Appsignal中的查询性能时发现了这一点。我注意到大多数查询在几毫秒内完成,然后时不时地,仍然在同一个请求中,有多个查询需要5秒以上

ruby-on-rails - 如何定期获取/更新 Rails 中的值?

让我们来看一个场景:counter10seconds用户访问了show.html.erb页show.html.erb从database获取值使用.计数器已启动,计数器的每次迭代都是针对10seconds的.在每10seconds之后我想更改@post.value使用utility类。更新@post.value在数据库中。刷新show.html.erb自动和将显示更新后的值以上过程将循环运行,直到用户移动到其他页面。如果我必须在代码中简化问题,那么它会像这样:查看页面Controller方法defshow@post=Post.find(params[:id])enddefupdate..

ruby-on-rails - 有没有办法检查 Ruby 变量是否包含二进制数据?

我正在使用Ruby2.4和Rails5。我在名为“content”的变量中有文件内容。内容可能包含来自PDF文件、Word文件或HTML文件之类的数据。有什么办法可以判断变量是否包含二进制数据?最后,我想知道这是PDF、MicrosoftOffice还是其他类型的OpenOffice文件。这个答案——Rails:possibletocheckifastringisbinary?--建议我可以检查变量的编码content.encoding它会产生ASCII-8BIT然而,在二进制数据的情况下,我注意到有些情况下存储在变量中的HTML内容也可能返回“ASCII-8BIT”作为content

ruby - 英雄数据库 :pull does not work?

我收到以下错误消息:herokudb:pull--debugpostgres://USERNAME:PASSWORD@localhost/testLoadedTapsv0.3.23Warning:Datainthedatabase'postgres://USERNAME:PASSWORD@localhost/test'willbeoverwrittenandwillnotberecoverable.ReceivingschemaUnabletofetchtablesinformationfromhttp://heroku:foo9dsfsdfsdb465ar@taps19.heroku

ruby - 如何将数据通过管道传输到通过标准输入上的 Net::SSH 启动的进程?

我正在本地机器上生成数据源,我想通过Net::SSH将其传输到远程进程。有点像echofoosball|sed's/foo/bar/g'只是echofoosball部分将是本地计算机上的数据馈送。我不要找的是:data="foosball"ssh.exec!("echo#{data}|sed's/foo/bar/g'")我真的想要实时将数据流传输到流程中;) 最佳答案 好吧,我明白了:#!/usr/bin/envrubyrequire'rubygems'require'net/ssh'res=""c=Net::SSH.start("

ruby-on-rails - 使用 curl 将 JSON 数据发布到简单的 Rails 应用程序

我使用脚手架设置了一个简单的新Rails应用程序,其中包含模型条目、属性title和content。现在我正在尝试使用curl来发布JSON数据(而不是使用浏览器)。以下似乎有效(即成功发布空数据):curl--verbose--header"Accept:application/json"--header"Content-type:application/json"--requestPOST--data""http://localhost:3000/entries以下不起作用:curl--verbose--header"Accept:application/json"--header

ruby-on-rails - 尝试将本地数据库推送到 Heroku 后出现 "ActionView::Template::Error (Unknown primary key for table"

对于我通过Heroku托管的Ruby-on-Rails应用程序,我最近下载了一个备份,在本地恢复它,然后从外部来源将数据添加到数据库中。一切正常。在使用herokupg:pushHEROKU_DATABASE_URL--app将更新后的数据库推送到Heroku之后该应用程序运行良好,我可以看到新添加的数据。但是今天当我尝试在Heroku上登录该应用程序时,我收到了错误消息。在我的日志文件中,我看到了这个错误:ActionView::Template::Error(Unknownprimarykeyfortable...根据这篇SO帖子:Getting"Unknownprimarykey

ruby-on-rails - 为数据库中的多个客户端创建 "walled gardens"的最佳方法是什么?

我正在建立一个SaaS风格的网站,其中我将让多个客户在同一个站点上管理他们的工作流程和数据,因此也管理同一个数据库。我什至不确定这个概念是否有一个词,但是是否有任何既定的自动分离数据的方法,以便对数据库的任何ActiveRecord调用都被用户的正确client_id过滤/限制已登录?当然,最直接的方法是在每个ActiveRecord请求的末尾添加一个“whereclient_id=?”并将用户的客户端ID放入...。模型是否有任何前置过滤器的想法,以便任何查找方法(包括动态方法)都会自动将client_id添加到它们?所以我可以只执行Model.find_by_what_I_want

ruby - 如何解析 CSV 文件,更新字段,然后保存

我需要读取一个CSV文件,更新一个字段,然后保存更改。除了将我的更改保存到我正在更新的字段外,我一切正常:require'csv'@parsed_file=CSV::Reader.parse(File.open("#{RAILS_ROOT}/doc/some.csv"))@parsed_file.each_with_indexdo|row,x|address=row[5]l=Location.address_find(address)ifl!=nilputs"#{l.name}at#{l.address}"row[14]=l.store_codeputsrow[14]elseputs"

css - sass --watch 在初始启动后不更新 (sass 3.1.16)

我正在使用sass为我正在开发的一个简单的静态网站编写css。我运行了sass--watchcustom.scss:custom.css,它在启动时编译良好,并显示消息:Sassiswatchingforchanges.PressCtrl-Ctostop.overwritecustom.css但是,每当我更新.scss文件时,什么也没有发生。我以前没有在Rails应用程序的上下文之外使用过SASS,所以我想知道我是否遗漏了什么?我的scss文件也非常简单,所以我怀疑它有什么问题,特别是因为它在第一次运行时就可以工作。sass-v报告Sass3.1.16(BrainyBetty),在Li