一次关于LINUX端口占用的问题分析

        某系统启动通讯组件过程中,服务端组件启动报错“33801端口已被占用”,而作为服务端监听的端口集合本身无重复,通过查看连接发现,为客户端通过该端口建立的SOCKET连接。

客户端建立SOCKET连接的过程未指定端口,则由操作系统内核指定未被占用的端口,由于服务端组件监听启动在后,客户端连接启动在前,所以对应的服务端端口被提前分配给客户端使用,导致服务端无法建立监听。

既然问题已经明确,那接下来就是如何解决啦。首先,想出了方案一,既然服务端可以指定监听端口,那客户端是不是也可以指定连接的端口呢,只要我不使用服务端对应的端口,那问题就解决啦。然后就发现了如下代码:


原来不仅服务端可以使用bind方法,客户端也可以。感觉看到了希望的曙光,可是深入思考后发现了问题,在通讯组件中,尤其是SOCKET短连接的连接池,一笔交易就对应一个端口,如何管理这些可以使用的端口呢?结合连接池,瞬间想到了可以模仿设置一个端口号池,每次建联前从端口号池中获取一个端口号用于连接,小的问题就是,如果在高并发下,对应端口使用的过多,而连接断开后处于TIME_WAIT状态,该端口同样无法使用。。。。有了,我可以设置连接池先进先出呀,然后设置reuse参数,那么就能尽量避免端口处于不可用状态啦~

解决方案有了雏形后,总感觉自己跑偏了,回想使用的各个通讯框架和分布式服务框架,它们都没有对此进行处理,额,肯定有问题,而且通讯框架的底层应该是最基础的通讯方式,这种端口号的设计都已经到操作系统内核,完全超出了作用范围。

回到问题本身,就是服务端端口被客户端所占用,本身端口分配就是操作系统完成的,那么它是不是对应有什么处理呢?于是发现了新大陆

net.ipv4.ip_local_port_range 它指定了本地发起连接请求时可以获取的随机端口

ip_local_reserved_ports     它指定了本地预留的服务端监听端口,默认无

查看现在的测试环境,发现net.ipv4.ip_local_port_range没有进行修改,仍然采用默认

32768 61000,而出现问题的通讯组件所监听的33801端口正好在该范围内,于是豁然开朗

既然操作系统有解决方案,那通讯组件还是不插手啦~看来服务端的端口监听还是要注意选取范围呀。

参考来自:

https://www.cnblogs.com/gaoyuechen/p/7725336.html   

https://blog.csdn.net/xygg0801/article/details/55195083   

https://blog.csdn.net/afer198215/article/details/6834041

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

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,580评论 18 139
  • 网络编程 网络编程对于很多的初学者来说,都是很向往的一种编程技能,但是很多的初学者却因为很长一段时间无法进入网络编...
    程序员欧阳阅读 1,998评论 1 37
  • 计算机网络概述 网络编程的实质就是两个(或多个)设备(例如计算机)之间的数据传输。 按照计算机网络的定义,通过一定...
    蛋炒饭_By阅读 1,207评论 0 10
  • 关于Mongodb的全面总结 MongoDB的内部构造《MongoDB The Definitive Guide》...
    中v中阅读 31,893评论 2 89
  • 人物|骆驼祥子,灵魂质变的标本 文/燕赵北羽 老舍先生在这部小说里通过剪纸似的描述,向我们展示了一个原本内心纯洁、...
    燕赵北羽阅读 1,594评论 0 7