草庐IT

Windows批处理文件备份sql数据库

全部标签

ruby - Ruby 的 stdlib Logger 类能否安全地处理来自多个进程的编写器?

我正在开发一个需要进行日志记录的Ruby库。理想情况下,我希望多个工作进程能够登录同一个文件。查看来自Ruby标准库的Logger类的源代码,我看到努力从多个线程同步写入日志(正如对IsRuby'sstdlibLoggerclassthread-safe?的回答中所指出的)。当多个进程写入同一个日志文件时,似乎存在类似的问题:根据底层决定缓冲/拆分写入的方式,每个日志消息可能无法保持其完整性。那么,有没有一种方法可以使用标准的Logger类来允许多个进程安全地记录到一个文件中?如果不是,这在Ruby项目中通常是如何完成的?这就是我所说的“安全”的意思:每个日志行都是“原子的”——在下一

sql - rails union hack,如何将两个不同的查询放在一起

我有一个查询,它在同一个表中搜索两个单独的字段...寻找最有可能是特定城市但也可能是国家的位置...即需要两个字段。表格看起来像:CountryCityGermanyAachenUSAAmarilloUSAAustin结果:KeywordSideinfoAachenGermanyUSACountryAustinUSAGermanyCountry基本上我想知道是否有更简洁的方法来执行此操作,因为我必须使用两个单独的查询,然后将它们加在一起,对它们进行排序等(效果很好):defself.ajax(search)countries=Location.find(:all,:select=>'c

ruby - Ruby 如何在语义上处理赋值?

在Ruby中,我们使用=运算符为对象赋值。将此与隐式类型结合起来,我们经常会遇到这样的情况:myVar=:asymbol上面的行既创建了一个新的符号对象,又将该对象绑定(bind)到变​​量名myVar。语义上,这是如何完成的?我一直在脑海中反复强调,=运算符不是解释器中内置的神奇语法,但实际上只是对象的语法糖.=(value)方法。考虑到这一点,我最好的猜测是,当解释器看到我们试图给一个undefinedvariable名赋值时,它首先创建一个特殊类型的新对象,比如undefined或null或其他东西,然后将:=消息传递给该对象,有效负载是我们尝试分配的值。但是,在未实例化的对象上

sql-server - Ruby 连接到 SQL Server

我在将Ruby连接到MicrosoftSQLServer时遇到问题。我正在运行MacOSX,但目标环境是UbuntuLinux。这是我尝试过的:安装unixODBC安装FreeTDS使用了选项--with-unixodbc=/usr/local/etc--with-tdsver=8.0然后我在/usr/local/etc中有了这些文件:odbc.iniodbcinst.inifreetds.conf我在odbcinst.ini文件中将对FreeTDS驱动程序的引用添加到我的ODBC驱动程序文件中,如下所示:;;odbcinst.ini;;[FreeTDS]Driver=/usr/loc

Ruby:打开的文件太多@rb_sysopen

在使用File.new(big_file)打开一个文件(不关闭它)1016次(Ubuntu)或1017次(CentOS)后,似乎有一个限制并引发:Toomanyopenfiles@rb_sysopen-big_file(Errno::EMFILE)有什么办法可以提高这个限制吗?在我的系统上,ulimit设置为unlimited。 最佳答案 EMFILE是在您的进程中打开的文件太多。ENFILE是整个系统打开的文件太多。所以Errno::EMFILE是因为ruby​​进程打开了太多文件。此限制可能设置为默认1024可以看到:$ulim

ruby-on-rails - 防止 Rails 测试删除种子数据

我正在使用seeds.rb填充一些状态模型引用数据:State.create:name=>'Alabama',:abbreviation=>'AL'State.create:name=>'Alaska',:abbreviation=>'AK'#...虽然我没有使用状态固定装置(因为它是种子数据,我认为纯粹为了测试而复制它不会是DRY),Rails测试框架似乎删除了所有状态种子数据测试。(我正在删除、重新创建、迁移和重新播种测试数据库,并在单元测试运行之前确认数据在那里。)结果是此断言在seeds.rb中成功但在单行测试中失败:assert_equal51,State.all.size1

sql - Rails 中独立于数据库的 SQL 字符串连接

我想在Rails查询中进行数据库端字符串连接,并以独立于数据库的方式进行。SQL-92指定双杠(||)作为连接运算符。不幸的是,MSSQLServer似乎不支持它;它使用+代替。我猜Rails的SQL语法抽象已经解决了特定于数据库的运算符问题。如果它确实存在,我该如何使用它? 最佳答案 我遇到了同样的问题,但从未想出任何内置于Rails中的东西。所以我写了这个小方法。#Symbolsshouldbeusedforfieldnames,everythingelsewillbequotedasastringdefdb_concat(*a

ruby - Sinatra:提供普通旧文件的正确方法是什么?

这是有效的,但它是在黑暗中刺伤。我对Ruby知之甚少。为给定资源提供普通旧文件的公认方式是什么?get'/xyz'doFile.read'abc.html'end 最佳答案 您可以使用set:public来指定静态文件的目录。然后,您可以使用send_file()提供文件,例如:get'/static_file'dosend_file('my_static_file')end 关于ruby-Sinatra:提供普通旧文件的正确方法是什么?,我们在StackOverflow上找到一个类似的

ruby-on-rails - 如何在 Ruby 中从下到上读取文件?

我一直在为Rails应用开发日志查看器,发现我需要从下到上阅读大约200行的日志文件,而不是默认的从上到下阅读。日志文件可能会变得非常大,所以我已经尝试并排除了IO.readlines("log_file.log")[-200..-1]方法。有没有其他方法可以在不需要插件或gem的情况下在Ruby中反向读取文件? 最佳答案 执行此操作且适用于大型文件的唯一正确方法是从末尾一次读取n个字节,直到获得所需的行数。这基本上就是Unixtail的工作方式。IO#tail(n)的示例实现,它将最后的n行作为Array返回:classIOTAI

ruby - 将 Ruby 打包成可移植的可执行文件

长期以来,我一直在努力寻找一个好的解决方案:是否有可靠的方法将ruby​​安装到可在该平台上移植的文件夹中?我想要一个文件夹,我可以轻松地将其复制到我正在制作的发行版中,这样我就可以“随时随地”拥有一个ruby​​环境。如果我需要编译源代码和其他东西,那很好,只要我最终安装了可移植的ruby​​安装即可。我找到了一些试图解决这个问题的资源,但没有一个让我满意。PortableRubyonRailsenvironmenthttp://hcettech.blogspot.pt/2012/05/windows-portable-rails-development.html对我来说,这是Rub