Java Nio 部署调优 50w 并发

备份转载金总的Note

概述

本文描述了在 Linux 服务器上部署 example broker 上的相关过程及步骤, 为运维及开发人员提供参考。

example broker

example broker 是一款使用 Java 编写的 Mqtt 服务器。能够为符合 Mqtt 规范的客户端提供基于 Mqtt 的消息订阅, 发送服务。example broker 对于 Java 版本有着严格的要求,只能运行在 Java 8 或是以上版本, 不提供向下兼容。

操作系统

example broker 并未在 Windows 平台上进行过测试,因此建议生产环境部署在 Linux。以下相关的命令都是基于 Cent OS X86_64 版本, 部分命令可能需要 root 权限。

内核参数

为了保证 example broker 能够达到要求的连接数, 因此需要对内核参数进行如下的修改, 来支撑大量的 tcp/ip 连接(大于等于 500,000)。

系统文件数

运行 cat /etc/security/limits.conf 查看操作系统当前允许打开的最大文件数,确认运行 example broker 的用户能够打开 500,000 以上的文件, (建议修改为 1,000,000) 以下的配置示例是允许所有用户修改文件数的值为 1,048,576:

* soft nofile 1048576
* hard nofile 1048576

其中的 * 代表影响系统所有用户, 可以根据实际需要修改为运行 example broker 的用户。soft 对应的为警告值, 而 hard 则是真正起作用的限制值。

运行 sysctl -a | grep file 查看 fs.file-max 的值应符合 1,000,000 左右的数值, 并小于上面提及的允许修改数, 这个数字将会影响整个操作系统能够打开的最大文件数。

启动 example broker 之前, 在当前 shell 中执行 ulimit -n 1000000 使当前会话中允许打开的最大文件数设置生效。具体会在启动 example broker 部分进行介绍。

TCP/IP 及网络相关参数

执行 lsmod | grep nf_conntrack_ipv4 查看系统是否启用 firewalld service。
由于 tcp/ip 连接数上升后会造成 防火墙的相关功能及日志写入的工作量上升, 从而影响 tcp/ip 请求的正常连接, 因此现阶段的临时解决方案使关闭防火墙 服务。在实际生产环境的解决措施仍待考虑。执行 systemctl stop firewalld, 然后再次执行 lsmod | grep nf_conntrack_ipv4 查看服务是否已经关闭。

tcp/ip 的 backlog 参数也会影响 tcp/ip 的连接速度及稳定性, 因此可以执行以下命令, 将参数设置为 4096(参考值)。
sysctl -w net.ipv4.tcp_max_syn_backlog=4096

所需软件

在部署和使用 example broker 前,请按照如下步骤安装所需的软件,并确认软件安装正确。

Java

请执行 java -version 确认服务器上是否安装 Java, 或是已经安装的 Java 版本。如前文所述, example broker 依赖 Java 8 或是以上版本, 如果服务器现有 Java 的版本较低,请更新至所需的高版本。

在同一个操作系统上存在多个版本 Java 时容易引起一些不必要的麻烦,或是由于环境变量等因素额外增加不必要的工作, 因此我们推荐安装 jEnv 来管理不同版本的 Java。具体的安装过程请参考官方网站, 本文不再赘述。

Kafka

example broker 依赖 Kafka 消息中间件来完成 mqtt 消息的订阅-发布功能, 因此请确认 kafka 服务器的联通性和可用性正常。

Redis

Redis 负责 mqtt 相关消息的存储功能, 因此在运行 example broker 时确认连接的 redis 能够正常工作。

安装 example broker

example broker 本身为 jar 包, 且包含了运行所需的所有依赖类库。因此只需要上传至用户安装所需的目录即可,无需额外的特殊操作。

运行

使用原生的 java 命令即可运行 example broker 服务。但是为了便捷, 我们建议编写一个独立的 shell 脚本来完成该项工作。以下是一个运行 example broker 的示例脚本。

#!/bin/bash
ulimit -n 1000000
JAVA_OPTS="-server -Xms4048M -Xmx4048M -Xmn400M -XX:+HeapDumpOnOutOfMemoryError -Dcom.sun.management.jmxremote.port=9988 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false -Djava.rmi.server.hostname=192.168.1.1"
nohup java $JAVA_OPTS -jar example-broker-0.0.1-SNAPSHOT-uber.jar server config.yaml&

首先脚本使用 ulimit -n 1000000 来设置本次 shell session 运行的进程允许最多打开 1,000,000 个文件句柄。

脚本中的 JAVA_OPTS 参数定义了启动 Java 虚拟机所需的相关参数。在示例中我们定义了以 server 模式启动 JVM, 同时定义了Java Heap 部分的最大, 最小内存都为 4048MB, 且最小内存为 400MB。其余的 JVM 参数请参考对应的用户手册, 并根据实际要求要添加或是修改。

其中需要特别指出的是 JMX 相关的参数设置, 启用了 JMX 的监测服务, 允许用户在系统运行阶段使用 JMX 客户端进行连接, 从而实时监控系统的运行参数。

脚本中的剩余部分即为使用后台运行模式来运行 example broker 程序。

验证

在运行 example broker 后, 请使用以下的方式来验证 example broker 是否正常运行。

使用 tail 命令查看 example broker 的日志输出, 查看是否正常启动, 或在启动过程中是否出现异常信息。

使用 jps 命令查看是否存在 example broker 对应的进程。

在条件允许的情况下, 可以使用第三方的 mqtt 客户端对 example broker 进行简单的功能性测试。

Trouble Shooting

按照本文的上述配置, 在内网环境的同一个网段上, 部署单个 example broker 在双核 8G 内存的服务器, 可以轻松的达到 500,000 的长连接数。如果在部署过程中遇到问题, 或是无法达到预期的性能请参考以下的流程进行排查。

  1. 确认操作系统的文件句柄数已经调整, 且大于需要承载的连接数。
  2. 确认 Linux 的 iptables 服务已经关闭。
  3. example broker 依赖的 Kafka 和 Redis 服务能够正常工作。
  4. Linux 上安装的 Java 版本正确。
  5. 启动 example broker 的命令正确。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,684评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,143评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,214评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,788评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,796评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,665评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,027评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,679评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,346评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,664评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,766评论 1 331
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,412评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,015评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,974评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,073评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,501评论 2 343

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,596评论 18 139
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 46,733评论 6 342
  • 备份转载金总的Note 概述 本文描述了对 example broker 进行性能测试时, 客户端所需进行配置的相...
    Shaman阅读 4,949评论 0 1
  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,178评论 11 349
  • 文学会勾勒出人世生活中的各种真实与理想。 无论生活怎样的黑暗,复杂,那些人们内心闪耀的东西依然会存在着。文学就是一...
    登峰方可睥睨四海阅读 232评论 0 5