我正在模拟一个银行系统,其中要运行 100,000 笔交易。每种类型的事务都实现了可运行的,并且我有各种类型的事务可以发生。
transactions 是一个 Runnable 数组。
理想情况下,以下代码可以解决我的问题:
for (Transaction transaction : transactions) {
new Thread(transaction).start();
}
但是,显然 java.lang.OutOfMemoryError: unable to create new native thread 在尝试启动 100,000 个线程时必然会发生。
接下来我尝试实现一个 ExecutorService 来创建一个线程池来管理我的 100,000 个可运行对象。
ExecutorService service;
int cpus = Runtime.getRuntime().availableProcessors();
// cpus == 8 in my case
service = Executors.newFixedThreadPool(cpus);
for (Transaction transaction : transactions) {
service.execute(transaction);
}
尝试这种方法时,长进程会“占用”JVM。例如,一种类型的交易需要 30 - 60 秒才能执行。在分析应用程序时,不允许其他线程在长事务发生时运行。
在这种情况下,线程 6 在其处理完成之前不允许任何其他线程运行。
所以我的问题是:如何在不遇到内存问题的情况下尽可能快地运行 100,000 个事务?如果 ExecutorService 是答案,那么我如何才能阻止非常长的事务占用 JVM 并允许其他事务并发运行?
编辑:
我故意强制某些类型的事务发生 30 - 60 秒,以确保我的线程程序正常工作。每笔交易锁定一个账户,共有 10 个账户。这是我占用 JVM 的方法:(由 run() 调用)
public void makeTransaction() {
synchronized(account) {
long timeStarted = System.nanoTime();
long timeToEnd = timeStarted + nanos;
this.view = new BatchView(transactionNumber, account.getId());
this.displayView();
while(true) {
if(System.nanoTime() % 1000000000 == 0) {
System.out.println("batch | " + account.getId());
}
if(System.nanoTime() >= timeToEnd) {
break;
}
}
}
}
每次运行此事务时,只有一个帐户被锁定,剩下 9 个帐户应可用于处理。 为什么 JVM 不再处理任何线程,而是挂起直到这个长事务完成?
这里是项目的缩小版本的链接,用于演示问题:project
最佳答案
When profiling the application, no other threads are being allowed to run while the long transaction takes place.
很可能,此任务正在使用单线程资源。即 ti 的编写方式会阻止并发使用。
How can I run 100,000 transactions as fast as possible without running into memory problems?
如果事务受 CPU 限制,您应该有一个与您拥有的 CPU 数量大小相同的池。
如果事务依赖于数据库,您应该考虑对它们进行批处理以更有效地利用数据库。
If ExecutorService is the answer, then how can I stop very long transactions from hogging the JVM and allow other transactions to run concurrently?
使交易更短。如果您有一个运行时间超过几毫秒的任务,您应该弄清楚为什么要花这么长时间。我将首先查看网络/IO 必须如何使用和分析任务。大多数交易(如果您有大量交易)应该在 0.01 秒左右或更理想。
您应该仔细考虑如何使用共享资源。如果您的任务过多地使用相同的资源,您可能会发现多线程并不快,甚至更慢。
关于java - 并发运行 100,000 个进程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29160702/
总的来说,我对ruby还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用
在选择我想要运行操作的频率时,唯一的选项是“每天”、“每小时”和“每10分钟”。谢谢!我想为我的Rails3.1应用程序运行调度程序。 最佳答案 这不是一个优雅的解决方案,但您可以安排它每天运行,并在实际开始工作之前检查日期是否为当月的第一天。 关于ruby-如何每月在Heroku运行一次Scheduler插件?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/8692687/
exe应该在我打开页面时运行。异步进程需要运行。有什么方法可以在ruby中使用两个参数异步运行exe吗?我已经尝试过ruby命令-system()、exec()但它正在等待过程完成。我需要用参数启动exe,无需等待进程完成是否有任何rubygems会支持我的问题? 最佳答案 您可以使用Process.spawn和Process.wait2:pid=Process.spawn'your.exe','--option'#Later...pid,status=Process.wait2pid您的程序将作为解释器的子进程执行。除
我尝试运行2.x应用程序。我使用rvm并为此应用程序设置其他版本的ruby:$rvmuseree-1.8.7-head我尝试运行服务器,然后出现很多错误:$script/serverNOTE:Gem.source_indexisdeprecated,useSpecification.Itwillberemovedonorafter2011-11-01.Gem.source_indexcalledfrom/Users/serg/rails_projects_terminal/work_proj/spohelp/config/../vendor/rails/railties/lib/r
在MRIRuby中我可以这样做:deftransferinternal_server=self.init_serverpid=forkdointernal_server.runend#Maketheserverprocessrunindependently.Process.detach(pid)internal_client=self.init_client#Dootherstuffwithconnectingtointernal_server...internal_client.post('somedata')ensure#KillserverProcess.kill('KILL',
我正在编写一个gem,我必须在其中fork两个启动两个webrick服务器的进程。我想通过基类的类方法启动这个服务器,因为应该只有这两个服务器在运行,而不是多个。在运行时,我想调用这两个服务器上的一些方法来更改变量。我的问题是,我无法通过基类的类方法访问fork的实例变量。此外,我不能在我的基类中使用线程,因为在幕后我正在使用另一个不是线程安全的库。所以我必须将每个服务器派生到它自己的进程。我用类变量试过了,比如@@server。但是当我试图通过基类访问这个变量时,它是nil。我读到在Ruby中不可能在分支之间共享类变量,对吗?那么,还有其他解决办法吗?我考虑过使用单例,但我不确定这是
Sinatra新手;我正在运行一些rspec测试,但在日志中收到了一堆不需要的噪音。如何消除日志中过多的噪音?我仔细检查了环境是否设置为:test,这意味着记录器级别应设置为WARN而不是DEBUG。spec_helper:require"./app"require"sinatra"require"rspec"require"rack/test"require"database_cleaner"require"factory_girl"set:environment,:testFactoryGirl.definition_file_paths=%w{./factories./test/
我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/
GivenIamadumbprogrammerandIamusingrspecandIamusingsporkandIwanttodebug...mmm...let'ssaaay,aspecforPhone.那么,我应该把“require'ruby-debug'”行放在哪里,以便在phone_spec.rb的特定点停止处理?(我所要求的只是一个大而粗的箭头,即使是一个有挑战性的程序员也能看到:-3)我已经尝试了很多位置,除非我没有正确测试它们,否则会发生一些奇怪的事情:在spec_helper.rb中的以下位置:require'rubygems'require'spork'
我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www