我有一个 PHP 脚本作为我的后端数据库的 JSON API。
意思是,您向它发送一个 HTTP 请求,例如:http://example.com/json/?a=1&b=2&c=3 ...它将返回一个 json 对象,其中包含来 self 的数据库的结果集。
PHP 对此非常有用,因为它实际上只有大约 10 行代码。
但我也知道 PHP 很慢,这是一个有时每秒被调用大约 40 次的 API,而 PHP 正在努力跟上。
有没有一种方法可以将我的 PHP 脚本编译为执行速度更快的格式?我已经在使用 PHP-APC,它是针对 PHP 和 FastCGI 的字节码优化。
或者,有人推荐我重写脚本的语言,以便 Apache 仍然可以处理 example.com/json/请求吗?
谢谢
更新:我刚刚运行了一些基准测试:
如您所见,PHP 在生成结果时确实慢了 1 个数量级。在这种情况下,网络似乎不是主要瓶颈,但我同意它通常是根本原因。
最佳答案
在开始优化某些东西之前,首先要弄清楚它是否存在问题。考虑到它只有 10 行代码(根据您的说法),我非常怀疑您没有问题。时间脚本执行的时间。请记住,网络延迟通常会使琐碎的脚本执行时间相形见绌。
换句话说:在你遇到问题之前不要解决问题。
您已经在使用操作码缓存 (APC)。没有比这更快的了。更重要的是,它很少需要比这更快。
如果有的话,您的数据库会出现问题。连接太多(不太可能是每秒 20 次),连接速度太慢或大连接:查询太慢。如果您发现自己处于这种情况,10 次中有 9 次有效的索引和数据库调优就足够了。
如果不是,则需要进行某种缓存:memcached、beanstalkd 等。
但老实说,每秒 20 次意味着这些解决方案几乎可以肯定是为一些不成问题的问题过度设计。
关于php - 我可以将我的 PHP 脚本编译成执行速度更快的格式吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1647826/
类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc
我在使用omniauth/openid时遇到了一些麻烦。在尝试进行身份验证时,我在日志中发现了这一点:OpenID::FetchingError:Errorfetchinghttps://www.google.com/accounts/o8/.well-known/host-meta?hd=profiles.google.com%2Fmy_username:undefinedmethod`io'fornil:NilClass重要的是undefinedmethodio'fornil:NilClass来自openid/fetchers.rb,在下面的代码片段中:moduleNetclass
我正在寻找执行以下操作的正确语法(在Perl、Shell或Ruby中):#variabletoaccessthedatalinesappendedasafileEND_OF_SCRIPT_MARKERrawdatastartshereanditcontinues. 最佳答案 Perl用__DATA__做这个:#!/usr/bin/perlusestrict;usewarnings;while(){print;}__DATA__Texttoprintgoeshere 关于ruby-如何将脚
使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta
查看Ruby的CSV库的文档,我非常确定这是可能且简单的。我只需要使用Ruby删除CSV文件的前三列,但我没有成功运行它。 最佳答案 csv_table=CSV.read(file_path_in,:headers=>true)csv_table.delete("header_name")csv_table.to_csv#=>ThenewCSVinstringformat检查CSV::Table文档:http://ruby-doc.org/stdlib-1.9.2/libdoc/csv/rdoc/CSV/Table.html
我有一个在Linux服务器上运行的ruby脚本。它不使用rails或任何东西。它基本上是一个命令行ruby脚本,可以像这样传递参数:./ruby_script.rbarg1arg2如何将参数抽象到配置文件(例如yaml文件或其他文件)中?您能否举例说明如何做到这一点?提前谢谢你。 最佳答案 首先,您可以运行一个写入YAML配置文件的独立脚本:require"yaml"File.write("path_to_yaml_file",[arg1,arg2].to_yaml)然后,在您的应用中阅读它:require"yaml"arg
我发现ActiveRecord::Base.transaction在复杂方法中非常有效。我想知道是否可以在如下事务中从AWSS3上传/删除文件:S3Object.transactiondo#writeintofiles#raiseanexceptionend引发异常后,每个操作都应在S3上回滚。S3Object这可能吗?? 最佳答案 虽然S3API具有批量删除功能,但它不支持事务,因为每个删除操作都可以独立于其他操作成功/失败。该API不提供任何批量上传功能(通过PUT或POST),因此每个上传操作都是通过一个独立的API调用完成的
我遵循了教程http://gettingstartedwithchef.com/,第1章。我的运行list是"run_list":["recipe[apt]","recipe[phpap]"]我的phpapRecipe默认Recipeinclude_recipe"apache2"include_recipe"build-essential"include_recipe"openssl"include_recipe"mysql::client"include_recipe"mysql::server"include_recipe"php"include_recipe"php::modul
我是一个Rails初学者,但我想从我的RailsView(html.haml文件)中查看Ruby变量的内容。我试图在ruby中打印出变量(认为它会在终端中出现),但没有得到任何结果。有什么建议吗?我知道Rails调试器,但更喜欢使用inspect来打印我的变量。 最佳答案 您可以在View中使用puts方法将信息输出到服务器控制台。您应该能够在View中的任何位置使用Haml执行以下操作:-puts@my_variable.inspect 关于ruby-on-rails-如何在我的R
我正在阅读SandiMetz的POODR,并且遇到了一个我不太了解的编码原则。这是代码:classBicycleattr_reader:size,:chain,:tire_sizedefinitialize(args={})@size=args[:size]||1@chain=args[:chain]||2@tire_size=args[:tire_size]||3post_initialize(args)endendclassMountainBike此代码将为其各自的属性输出1,2,3,4,5。我不明白的是查找方法。当一辆山地自行车被实例化时,因为它没有自己的initialize方法