草庐IT

ruby - 分布式事务和队列,ruby,erlang,scala

我有一个涉及多台机器、消息队列和事务的问题。因此,例如用户点击网页,点击将消息发送到另一台机器,该机器将付款添加到用户的帐户。每秒可能有数千次点击。事务的所有方面都应该是容错的。我以前从未遇到过这样的事情,但一些阅读表明这是一个众所周知的问题。所以我的问题。我假设安全的方法是使用两阶段提交,但协议(protocol)是阻塞的,所以我不会获得所需的性能,我是否正确?我通常写Ruby,但似乎Redis之类的数据库和Rescue、RabbitMQ等消息队列系统对我的帮助不大——即使我实现某种两阶段提交,如果Redis崩溃,数据也会丢失,因为它本质上只是内存。所有这些让我开始关注erlang和

ruby - 如何在Elixir中使用AES CBC 128进行加密和解密

我在Rails中有一个具有以下方法的应用程序,该方法可以加密和解密文本并与Java客户端通信。defencrypt(string,key)cipher=OpenSSL::Cipher::AES.new(128,:CBC)cipher.encryptcipher.padding=1cipher.key=hex_to_bin(Digest::SHA1.hexdigest(key)[0..32])cipher_text=cipher.update(string)cipher_textexcenddefhex_to_bin(str)[str].pack"H*"enddefbin_to_hex(

ruby - 使用 ruby​​ 进行套接字编程是个好主意吗?

我选择的语言是Ruby,但因为Twitter,我知道Ruby不能处理很多请求。将它用于套接字开发是个好主意吗?或者我应该像Twitter开发人员那样使用像erlang或haskell或scala这样的函数式语言吗? 最佳答案 我工作的公司使用Ruby作为我们的网站。到目前为止,我们已经处理了超过34,000,000,000次点击。我们每天处理大约10,000,000次点击没有问题。每天的点击量峰值已超过40,000,000次。可扩展性取决于很多因素。例如,与读取相比,我们的数据库执行的写入比例高得不成比例。虽然大多数网站执行大约90

ruby - 任何类似 Erlang 的 RSpec 工具?

Erlang是否有类似RSpecdescribeit的框架? 最佳答案 你见过espec吗:https://github.com/lucaspiller/espec?似乎它可以有类似的语法describe("#generate_headers",fun()->it("shouldgenerateHostandUser-Agentheaders",fun()->[{"Host","api.twitter.com"},{"User-Agent","Twerl"}]=stream_client_util:generate_headers(

ruby - 生成集合的所有 "unique"子集(不是幂集)

假设我们有一个集合S,它包含几个子集:-[a,b,c]-[a,b]-[c]-[d,e,f]-[d,f]-[e]我们还假设S包含六个唯一元素:a、b、c、d、e和f。我们如何找到S的所有可能子集,这些子集恰好包含S的每个唯一元素一次?函数/方法的结果应该是这样的:[[a,b,c],[d,e,f]];[[a,b,c],[d,f],[e]];[[a,b],[c],[d,e,f]];[[a,b],[c],[d,f],[e]].是否有任何最佳实践或任何标准方法来实现这一点?如果有伪代码、Ruby或Erlang示例,我将不胜感激。 最佳答案 听

ruby - Erlang actor 与 OOP 对象有何不同?

假设我有一个这样定义的Erlangactor:counter(Num)->receive{From,increment}->From!{self(),new_value,Num+1}counter(Num+1);end.同样,我有一个这样定义的Ruby类:classCounterdefinitialize(num)@num=numenddefincrement@num+=1endendErlang代码以函数式风格编写,使用尾递归来维护状态。然而,这种差异的有意义的影响是什么?在我天真的眼中,这两个事物的接口(interface)看起来非常相似:您发送一条消息,状态得到更新,然后您返回新

ruby - 为什么 Haskell 没有符号(像 ruby​​)/原子(像 erlang)?

我使用符号的两种语言是Ruby和Erlang,我总是发现它们非常有用。Haskell确实有代数数据类型,但我仍然认为符号会非常方便。立即想到的一个用途是,由于符号与整数同构,您可以在使用整数或字符串“主键”的地方使用它们。原子的语法糖可以是次要的-:something或是一个原子。所有原子都是一个名为Atom的类型的实例,它派生出Show和Eq。然后,您可以将其用于更具描述性的错误代码,例如typeErrorCode=AtomtypeMessage=StringdataError=ErrorErrorCodeMessageloginError=Error:redirect"Please

ruby - Actor 模型取代线程模型?

我在一本书(布鲁斯·A·泰特(BruceA.Tate)七周学习七种语言)中读到关于Matz(Ruby的发明者)的一章说“我会删除线程并添加参与者,或其他一些更高级的并发功能”。为什么actor模型可以成为替代线程的高级并发模型?“高级并发模型”还有哪些其他模型? 最佳答案 与其说actor模型会取代线程,还不如说;在cpu级别,进程仍将有多个线程,这些线程在处理器内核上进行调度和运行。Actor的想法是用一种模型取代这种潜在的复杂性,它的支持者认为,这种模型使程序员更容易编写可靠的代码。actors的想法是拥有独立的控制线程(Erl

ruby - Lisp 和 Erlang 原子、Ruby 和 Scheme 符号。它们有多有用?

在编程语言中具有原子数据类型的特性有多大用处?一些编程语言有原子或符号的概念来表示各种常量。我遇到的语言(Lisp、Ruby和Erlang)之间存在一些差异,但在我看来,一般概念是相同的。我对编程语言设计很感兴趣,我想知道原子类型在现实生活中有什么值(value)。没有它,Python、Java、C#等其他语言似乎也做得很好。我没有Lisp或Ruby的实际经验(我知道语法,但没有在实际项目中使用过)。我已经足够使用Erlang来适应那里的概念。 最佳答案 Atomsareliterals,constantswiththeirownn

javascript - Erlang 和 JavaScript MD5 摘要匹配

在此处测试MD5的Javascript实现:http://www.webtoolkit.info/javascript-md5.html给出以下输出:MD5("muzaaya")="00e081abefbbbf72b2d5258196a9b6d0"转到我的erlangshell,并计算相同值的MD5,我得到了这个:EshellV5.8.4(abortwith^G)1>erlang:md5("muzaaya").>2>如何比较两者?如果来自JavaScript前端应用程序的MD5结果到达我的Erlang后端,我希望能够比较这两个摘要。我怎样才能将JavascriptMD5摘要与Erlan