草庐IT

Java 大型多人游戏服务器可扩展性

coder 2023-09-17 原文

我为 Android 开发了一款名为 The Infinite Black 的大型多人在线游戏: https://market.android.com/details?id=theinfiniteblack.client

出于天真,我曾预计每月大约 1,000 名玩家的适度增长,并且需要管理大约 20 个实时 TCP/IP 客户端。

该游戏出乎意料地出现了爆炸性增长,一周内有超过 40,000 名新用户,并且平均同时有约 300 个实时连接,并且呈指数级增长。

服务器架构包含每个连接 2 个线程(阻塞读/写),一个用于生成新客户端的 ServerSocket 线程,以及一个轮询每个客户端新操作的 Controller 线程,将其应用于游戏世界,然后刷新数据完成后退出。

服务器是用我不太精通的 Java 构建的,尤其是在这样的高压力情况下。在内存和线程管理方面,C# 真的把我宠坏了。

进入正题.. 我刚刚订购了两个非常强大的系统作为专用游戏服务器运行,并希望最大限度地利用资源。许多有关 Java 资源配置的信息已被证明具有误导性、不正确或已过时。

我目前使用 -Xss512k 作为我的启动参数,并且了解这决定了每个线程的堆栈大小分配,但我并不完全理解它可能需要的所有内容。有什么工具或方法可以告诉我是否超过了目标并可以缩小它?我还应该考虑哪些其他命令行参数?

新服务器配备 16GB RAM 和 i7-2600K Sandy Bridge 3.4GHz 处理器:配置中有哪些选项可以尽可能地利用这一点?我的目标是每台服务器同时处理 1,200 个在线客户端(2,400 个线程)。

我应该关注哪些意想不到的陷阱和问题?

我读过关于最大线程数的极其矛盾的故事:如果我试图插入 2,400 个 Activity 线程,事情会崩溃吗?

Java 似乎不是为此类任务而设计的。我应该考虑将服务器迁移到另一种语言吗?

我目前在 Eclipse 开发中以 Debug模式运行服务器(呃......)

这是我的 Eclipse .ini 配置:

--launcher.XXMaxPermSize 256M

-Xms256m

-Xmx1024m

最佳答案

你还没有说清楚你的疑惑从何而来。

Plurk Comet: Handling 100,000+ Concurrent Connections with Netty (2009)

1999 年,我部署了一个 Java 网络服务器,每小时处理 40,000 个黄页搜索查询(服务器有 400 MHz CPU),2004 年,我开发了一个 Java 应用程序,每个服务器处理 8000 个并发连接(在双 1.2 GHz Sparc 上)服务器)有六台网关服务器和一台主服务器来控制它们和集中事件。

您的配置文件可能有所不同,但我可以说在 C# 发布之前,Java 支持大容量 Web 服务器。

就我个人而言,我不会让每个服务器的并发连接超过 10,000 个,但这只是一个可能不再成立的经验法则。您可以在单个 JVM 中拥有 32,000 个线程。在 Linux 上,它并没有超出这个范围。但是我会在单个服务器上有多个网关 JVM 以最小化完整 GC 时间(最小化完整 GC 时间的最佳方法是丢弃更少的垃圾,但这可能需要更多的努力)

The new servers have 16gb of RAM and i7-2600K Sandy Bridge 3.4GHz processors: What options are available in configuration to take as much advantage of this as possible? My goal is 1,200 online clients at once per server (2,400 threads).

我无法想象为什么这会成为一个问题。

What kind of unexpected pitfalls and problems should I be concerned with?

当您很可能可以将它们全部移除时,您认为您需要关闭所有可能的命令行参数。如果您有 4 个网关 JVM,每个有 300 个连接,这可以使用所有内存,您甚至不需要指定 -Xmx 设置。

Java doesn't seem like it was designed for this type of task. Should I consider migrating the server to another language?

您最好问问自己为什么相信这一点。你有一个应该很容易解决的问题,或者一个可能没有根据的疑问。

This is my Eclipse .ini configuration:

您如何配置 eclipse 并不限制如何设置任何从 eclipse 运行的程序。

BufferedOutputStream 适用于大多数应用程序,并且可能适用于 JVM 中多达 1000 个连接。然而,Java 1.4 (2002) 添加了 NIO,它更轻量级,可以将您的系统扩展到 10,000 个连接甚至更多。

顺便说一句:我在 2003 年开发的服务器是基于 NIO 调度程序的,但它非常复杂,除非你使用像 Netty 这样的标准库。

从那时起,我就成功地使用每个连接模型一个线程来阻止 NIO。我相信这比使用调度程序更易于管理,并且可以具有更低的延迟特性。我有一个监视器线程,它定期检查连接是否阻塞了写入,如果阻塞则关闭它们。我不认为每个连接需要两个线程,但我认为这不会对您的情况产生影响,因为每个服务器没有足够的连接。

正如 glowcoder 所建议的那样,您是否考虑过将 UDP 用于不太重要的广播信息?

关于Java 大型多人游戏服务器可扩展性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7379396/

有关Java 大型多人游戏服务器可扩展性的更多相关文章

  1. ruby - 具有身份验证的私有(private) Ruby Gem 服务器 - 2

    我想安装一个带有一些身份验证的私有(private)Rubygem服务器。我希望能够使用公共(public)Ubuntu服务器托管内部gem。我读到了http://docs.rubygems.org/read/chapter/18.但是那个没有身份验证-如我所见。然后我读到了https://github.com/cwninja/geminabox.但是当我使用基本身份验证(他们在他们的Wiki中有)时,它会提示从我的服务器获取源。所以。如何制作带有身份验证的私有(private)Rubygem服务器?这是不可能的吗?谢谢。编辑:Geminabox问题。我尝试“捆绑”以安装新的gem..

  2. ruby - 使用 C 扩展开发 ruby​​gem 时,如何使用 Rspec 在本地进行测试? - 2

    我正在编写一个包含C扩展的gem。通常当我写一个gem时,我会遵循TDD的过程,我会写一个失败的规范,然后处理代码直到它通过,等等......在“ext/mygem/mygem.c”中我的C扩展和在gemspec的“扩展”中配置的有效extconf.rb,如何运行我的规范并仍然加载我的C扩展?当我更改C代码时,我需要采取哪些步骤来重新编译代码?这可能是个愚蠢的问题,但是从我的gem的开发源代码树中输入“bundleinstall”不会构建任何native扩展。当我手动运行rubyext/mygem/extconf.rb时,我确实得到了一个Makefile(在整个项目的根目录中),然后当

  3. java - 等价于 Java 中的 Ruby Hash - 2

    我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/

  4. ruby-on-rails - 启动 Rails 服务器时 ImageMagick 的警告 - 2

    最近,当我启动我的Rails服务器时,我收到了一长串警告。虽然它不影响我的应用程序,但我想知道如何解决这些警告。我的估计是imagemagick以某种方式被调用了两次?当我在警告前后检查我的git日志时。我想知道如何解决这个问题。-bcrypt-ruby(3.1.2)-better_errors(1.0.1)+bcrypt(3.1.7)+bcrypt-ruby(3.1.5)-bcrypt(>=3.1.3)+better_errors(1.1.0)bcrypt和imagemagick有关系吗?/Users/rbchris/.rbenv/versions/2.0.0-p247/lib/ru

  5. ruby-on-rails - s3_direct_upload 在生产服务器中不工作 - 2

    在Rails4.0.2中,我使用s3_direct_upload和aws-sdkgems直接为s3存储桶上传文件。在开发环境中它工作正常,但在生产环境中它会抛出如下错误,ActionView::Template::Error(noimplicitconversionofnilintoString)在View中,create_cv_url,:id=>"s3_uploader",:key=>"cv_uploads/{unique_id}/${filename}",:key_starts_with=>"cv_uploads/",:callback_param=>"cv[direct_uplo

  6. ruby-on-rails - 在 Rails 中调试生产服务器 - 2

    您如何在Rails中的实时服务器上进行有效调试,无论是在测试版/生产服务器上?我试过直接在服务器上修改文件,然后重启应用,但是修改好像没有生效,或者需要很长时间(缓存?)我也试过在本地做“脚本/服务器生产”,但是那很慢另一种选择是编码和部署,但效率很低。有人对他们如何有效地做到这一点有任何见解吗? 最佳答案 我会回答你的问题,即使我不同意这种热修补服务器代码的方式:)首先,你真的确定你已经重启了服务器吗?您可以通过跟踪日志文件来检查它。您更改的代码显示的View可能会被缓存。缓存页面位于tmp/cache文件夹下。您可以尝试手动删除

  7. java - 从 JRuby 调用 Java 类的问题 - 2

    我正在尝试使用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

  8. c - mkmf 在编译 C 扩展时忽略子文件夹中的文件 - 2

    我想这样组织C源代码:+/||___+ext||||___+native_extension||||___+lib||||||___(Sourcefilesarekeptinhere-maycontainsub-folders)||||___native_extension.c||___native_extension.h||___extconf.rb||___+lib||||___(Rubysourcecode)||___Rakefile我无法使此设置与mkmf一起正常工作。native_extension/lib中的文件(包含在native_extension.c中)将被完全忽略。

  9. java - 我的模型类或其他类中应该有逻辑吗 - 2

    我只想对我一直在思考的这个问题有其他意见,例如我有classuser_controller和classuserclassUserattr_accessor:name,:usernameendclassUserController//dosomethingaboutanythingaboutusersend问题是我的User类中是否应该有逻辑user=User.newuser.do_something(user1)oritshouldbeuser_controller=UserController.newuser_controller.do_something(user1,user2)我

  10. java - 什么相当于 ruby​​ 的 rack 或 python 的 Java wsgi? - 2

    什么是ruby​​的rack或python的Java的wsgi?还有一个路由库。 最佳答案 来自Python标准PEP333:Bycontrast,althoughJavahasjustasmanywebapplicationframeworksavailable,Java's"servlet"APImakesitpossibleforapplicationswrittenwithanyJavawebapplicationframeworktoruninanywebserverthatsupportstheservletAPI.ht

随机推荐