草庐IT

clojure - 多机分布式Clojure的现状?

coder 2023-06-29 原文

<分区>

在“开发多机分布式并发应用程序的最佳语言是什么”中似乎有几匹领先的马:Go、Erlang、Clojure、Scala,可能还有其他的,例如 Termite/Gambit Scheme、Haskell 等.我研究了很多,据我所知,Erlang 似乎更认可真正的分布式并发,即独立的联网机器、应用程序。正如我在某处读到的那样,Clojure 的并发性首先意味着集中在同一台机器的多核应用程序编写上。 Clojure 是否提出了更多的多机分布式策略?或者这是一个不幸的权衡,即良好的同机多核策略以良好的多机策略为代价……反之亦然?

有关clojure - 多机分布式Clojure的现状?的更多相关文章

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

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

  2. ruby - 控制多机 Vagrant block 执行顺序 - 2

    我有一个多机vagrant设置,其中包含一些我需要更改执行顺序的block。由于vagrant顺序是从外到内,最嵌套的block最后执行。我需要一种方法来使供应block更加嵌套,以便它们最后执行。我尝试添加mach.vm.define但这些block没有执行,我不明白为什么。正常执行,顺序错误Vagrant.require_version">=1.6.0"VAGRANTFILE_API_VERSION="2"require'yaml'machines=YAML.load_file('vagrant.yaml')Vagrant.configure(VAGRANTFILE_API_VER

  3. ruby - 停止分布式 Ruby 服务 - 2

    我有一个启动DRb服务的脚本,然后生成处理程序对象并通过DRb.thread.join等待。我希望脚本一直运行直到被明确杀死,所以我添加了trap"INT"doDRb.stop_serviceend在Ruby1.8下成功停止DRb服务并退出,但在1.9下似乎死锁(在OSX10.6.7上)。对该进程进行采样显示在semaphore_wait_signal_trap中有几个线程在旋转。我假设我在调用stop_service时做错了什么,但我不确定是什么。谁能给我任何关于如何正确处理它的指示? 最佳答案 好的,我想我已经找到了解决方案。如

  4. 【血泪建议】软件测试岗位现状,可惜之前没人告诉我,肠子都晦青了.... - 2

    谈到现状,国内的软件测试行情目前呈现了两极分化的极端情况。一个是早期的手工测试人员吐槽工作不好做,即使有工作也是外包,而且薪资太低;一方面是很多互联网企业感叹自动化测试人才难找,有技术的自动化测试工程师,高薪难聘。这两者其实并不矛盾。手工测试工作难找也确实是目前真实的行情早期从事功能测试的手工测试人员,在测试方面大多采用手动、人工执行的方式查找软件缺陷和BUG,用行业术语来描述就是“点点点”。这种测试方式耗费大量人力和资源,工作效率却十分低下。在早期软件复杂和迭代程度不高的情况下,有资本的企业会“供养”一批这样的手工测试人员。但对测试员本身来讲,毫无技术难度的工作,和几乎没有保障的薪资水平,直

  5. 1个串口用1根线实现多机半双工通信+开机控制电路 - 2

    功能需求:主机使用一个串口,与两个从机进行双向通信,主机向从机发送数据,从机能够返回数据,由于结构限制,主机与从机之间只有3根线(电源、地、数据线),并且从机上没有设物理的电源开关,需要通过与主机连接的数据线来控制开机,总结如下:1、数据线只有1根2、能够双向通信3、主机能够控制从机开机4、主机可以单独向1个从机发数据,也可以同时向两个从机发送数据根据需求,设计出如下电路:工作原理分析:VCC_24V_IN、GND、LINE_L(LINE_R)三根线接线连接到从机,电源开启电路是从机内部的电源控制。开机的逻辑:*主机先上电,LINE_L因为主机的R1上拉而有高电平,使Q6导通,Q5的G极电压被

  6. java - 如何在 Clojure 中创建命令行可执行文件 - 2

    我用Clojure编写了一个程序,我想在命令行上执行它而不在命令行上专门调用java(例如java-jar)。我想要单个可执行文件,例如myprogram,它接受任何参数并运行我的程序。以下是一些可能会使这更容易的事情:可以假设Java已经安装并且java就在路上。虽然适用于Windows的解决方案会是一个很好的优势,但您可以假设这一切都是在类似UNIX的操作系统(例如MacOSX或Ubuntu)上完成的。可以在某种脚本中调用Java。可以使用其他一些语言,例如Ruby、Python或Perl,用户可能已安装或未安装这些语言。All-bash会很酷,因为我可以假设人们拥有它。如果我必须

  7. ruby - 我如何在 Clojure 中编写 Ruby 的 each_cons? - 2

    如何在Clojure中重写这段Ruby代码?seq=[1,2,3,4,5].each_cons(2)#=>lazyEnumerableofpairsseq.to_a=>[[1,2],[2,3],[3,4],[4,5]]Clojure:(???2[12345]);=>lazyseqof[12][23][34][45] 最佳答案 你要的是slidingwindow在一个惰性序列上。这样你就可以实现这一点user=>(partition21[12345])((12)(23)(34)(45))

  8. ruby - 用 Clojure 编写的阶乘函数的低性能 - 2

    我是Clojure新手。在试验中,我编写了I函数来计算n!。我的Clojure代码如下:(defnfactorial[n](reduce*(biginteger1)(range1(incn))))然后我在repl中运行了以下内容。(time(factorial100))结果是这样的:"Elapsedtime:0.50832msecs"93326215443944152681699238856266700490715968264381621468592963895217599993229915608941463976156518286253697920827223758251185210

  9. BigData/Cloud Computing:基于阿里云技术产品的人工智能与大数据/云计算/分布式引擎的综合应用案例目录来理解技术交互流程 - 2

    BigData/CloudComputing:基于阿里云技术产品的人工智能与大数据/云计算/分布式引擎的综合应用案例目录来理解技术交互流程目录一、云计算网站建设:部署与发布网站建设:简单动态网站搭建云服务器管理维护云数据库管理与数据迁移云存储:对象存储管理与安全超大流量网站的负载均衡二、大数据MOOC网站日志分析搭建企业级数据分析平台基于LBS的热点店铺搜索基于机器学习PAI实现精细化营销基于机器学习的客户流失预警分析使用DataV制作实时销售数据可视化大屏使用MaxCompute进行数据质量核查使用Quick BI制作图形化报表使用时间序列分解模型预测商品销量三、云安全云平台使用安全云上服务

  10. ruby - 是否有 Clojure 等效于 Ruby 的 #tap 方法 - 2

    Ruby提供了#tap方法,它允许您接收一个变量并在其上运行代码,但随后返回原始变量而不是表达式的结果,即:defnumber5.tap{|x|printx}#Prints5,andreturns5endClojure中是否有任何内置函数可以提供此功能? 最佳答案 您正在寻找doto.这是您的示例,使用它重写:(doto5println)它的工作原理类似于->宏,它通过一系列函数传递值。一个关键区别是它返回您传入的初始值,而不是最终函数返回的值。 关于ruby-是否有Clojure等效于

随机推荐