草庐IT

服务器安全

全部标签

ruby-on-rails - 改善缓慢的 Rails 启动时间(rails 控制台、rails 服务器)

我使用多个Rails应用程序,一些在Rails3.2/Ruby2.0上,一些在Rails2.3/Ruby1.8.7上。他们的共同点是,随着他们的成长和添加更多的依赖项/gem,他们需要越来越长的时间来启动。开发、测试、生产、控制台,无所谓;有些需要60多秒。首先分析导致加载时间如此缓慢的原因,其次改善加载时间的首选方法是什么? 最佳答案 有几种情况会导致这种情况。过多的GC遍数和一般的VM缺点-请参阅thisanswer以获得全面的解释。Ruby许多遗留gem必须迭代才能加载文件。如果您使用的是bundler,请尝试bundlecl

ruby-on-rails - 为什么在运行 webrick 服务器时出现未初始化常量设计名称错误?

在我的应用程序中,我使用了ruby​​1.9.2和rails3.0.3,并且还安装了Devisegem。当我运行Webrick服务器时,问题就开始了,我得到了未初始化的常量Devise名称错误。/home/app/Workspace/project/Library_Management/Library_Management/config/initializers/devise.rb:3:in`':uninitializedconstantDevise(NameError)from/home/app/.rvm/gems/ruby-1.9.2-p180/gems/railties-3.0.

ruby-on-rails - 在后台运行 Webrick 服务器?

MBPro:shovellmyname$rubyscript/server=>BootingWEBrick=>Rails2.3.8applicationstartingonhttp://0.0.0.0:3000=>Callwith-dtodetach=>Ctrl-Ctoshutdownserver[2010-08-0115:28:35]INFOWEBrick1.3.1[2010-08-0115:28:35]INFOruby1.9.1(2010-07-02)[i386-darwin10.4.0][2010-08-0115:28:35]INFOWEBrick::HTTPServer#sta

ruby-on-rails - 无法打开 Rails 服务器

我不知道我做了什么。我想我更新了我的RubyonRails。更新后,我在运行$railsserver时总是出错。输出是ruby-1.9.2-p290/lib/ruby/1.9.1/webrick/utils.rb:73:in`initialize':Addressalreadyinuse-bind(2)(Errno::EADDRINUSE)我会重新启动控制台并运行railsserver,它可以正常工作几分钟,但随后它会停止响应,如果我重新启动railsserver,它会再次出现该错误。我尝试在不同的端口(railss-p9191)上运行,它给了我同样的问题。有什么想法我做错了吗?谢谢大

ruby - 自动加载在 Ruby 1.9 中是线程安全的吗?

在我看来,自从thisfamousthread以来,Ruby社区一直对自动加载感到恐惧。,出于线程安全原因,不鼓励使用它。有谁知道这在Ruby1.9.1或1.9.2中是否不再是一个问题?我已经看到一些关于在互斥体中包装要求等的讨论,但是1.9变更日志(或者至少是我能够找到的那么多)似乎没有解决这个特定问题。我想知道我是否可以合理地开始在1.9-only库中自动加载而不会有任何合理的悲伤。提前感谢您的任何见解。 最佳答案 因为我也对此感到好奇,所以在2011年对此进行了更新。目前打开了两张工单:http://redmine.ruby-

ruby-on-rails - 为什么对 params 哈希进行切片会对批量分配造成安全问题?

通过批量分配防止安全风险的官方方法是使用attr_accessible.然而,一些程序员认为这不是模型的工作(或者至少不是仅模型的工作)。在Controller中执行此操作的最简单方法是对params哈希进行切片:@user=User.update_attributes(params[:user].slice(:name))但是文档指出:NotethatusingHash#exceptorHash#sliceinplaceofattr_accessibletosanitizeattributeswon’tprovidesufficientprotection.这是为什么呢?为什么par

ruby - 如何在安全的沙箱中运行不受信任的 Ruby 代码?

我希望能够运行不受信任的ruby​​代码。我希望能够将变量传递给它可能使用的所述不受信任的代码。我还希望上述代码将结果返回给我。这是我在想什么的概念性例子input="sweet"output=nilThread.start{$SAFE=4#...untrustedcodegoeshere,itusestheinputvariable(s)#tocalculatesomeresultthatitplacesintheoutputvariable}#parsetheoutputvariableasastring.澄清一下,我基本上是将不受信任的代码用作函数。我想要提供它的一些输入,然后允

ruby - Ruby/Rack 中的单点登录服务器身份验证

我在Windows服务器上编写和托管Web应用程序以供内部网使用。我的服务器堆栈使用Sinatra(使用Rack)、Thin和(在某些情况下)Apache仅用于反向代理。我想在我们的ActiveDirectory支持的域中支持单点登录(使用NTLM或Kerberos)。我已经看到我可以使用mod_ntlm或mod_auth_kerb当我在Apache后面执行我的NTLM身份验证时。我还没有尝试过,但我认为它会起作用。当我不支持Apache时,我的问题是关于NTLM或Kerberos身份验证,仅使用Thin和Sinatra。我看过rack-ntlm,但那里的使用细节非常稀少。请在Sina

ruby-on-rails - 使用 rails 来使用 web 服务/api

我是Rails世界的新手,我正在尝试构建一个应用程序,让我可以根据用户输入在Amazon和此类网站上搜索内容。我做了一些研究,httpartygem似乎是一个不错的起点?到目前为止,我发现的文件并不是最好的。他们并没有真正给我很多信息(将代码放在哪里等)。是否有任何现有的教程或代码示例可供我使用或查看,以便让我更好地了解它的工作原理? 最佳答案 我现在正在开发这样的应用程序,所以让我提供一些想法。首先,如果您是Rails的新手,那么作为第一步,我建议您采用并行的方法来解决这个问题,有两条路:了解Rails了解如何使用Ruby与API

ruby-on-rails - 如何为 Puma 检查 Rails 应用程序的线程安全

我希望使用Puma网络服务器将我的Rails应用程序部署到Heroku。但是,我不太确定是否所有的Gem都是线程安全的。阅读所有Gems的源代码对我们来说不是可行的选择。有没有办法自动检查所有Gem的线程安全性?或者,如果执行/检测到线程不安全代码,Puma会提示/显示特定的错误日志吗? 最佳答案 一般检测不到线程安全。如果有某种方法可以自动检测到它,您的编译器/解释器可能会警告您。Raceconditions无法被自动系统检测到,它们甚至难以重现。取决于您的解释器:CRuby有GIL,所以使用Puma是没有意义的。如果您使用的是J