java多进程端口复用_多个程序监听同一端口 - socket端口复用技术
对于多个程序绑定同一个端口我们遇到最多的是(Port 80 was already in use),也就是说端口被占用,不能重复绑定,但是操作系统内核支持通过配置socket参数的方式来实现多个进程绑定同一个端口。
简单示例
package main
import (
"context"
"golang.org/x/sys/windows"
"net"
"syscall"
)
var listenConfig = net.ListenConfig{
Control: MyControl,
}
func MyControl(network, address string, c syscall.RawConn) error {
return c.Control(func(fd uintptr) {
err := windows.SetsockoptInt(windows.Handle(fd), windows.SOL_SOCKET, windows.SO_REUSEADDR, 1)
if err != nil {
panic(err)
}
})
}
func main() {
listener, err := listenConfig.Listen(context.Background(), "tcp", "127.0.0.1:8080")
if err != nil {
panic(err)
}
defer listener.Close()
for {
conn, err := listener.Accept()
if err == nil {
println("new connection ", conn.RemoteAddr().String())
}
}
}
执行该程序后发现多个进程可以绑定同一端口
port_reuse.png
进程12720,3632和13612同时绑定了8080端口
原理解析
这个例子关键代码是设置socket的SO_REUSEADDR参数
实现多个程序绑定一个端口windows下需要设置SO_REUSEADDR参数
linux下需要设置SO_REUSEADDR和SO_REUSEPORT参数
相关问题:
how-do-so-reuseaddr-and-so-reuseport-differ
可以看出Windows下SO_REUSEADDR可以用来端口复用,在Linux下SO_REUSEADDR为了实现TIME_WAIT阶段的快速绑定,SO_REUSEPORT用来配置端口复用
安全问题
由此引发了一个安全问题,如果一个正常的web程序监听80端口提供服务,其它恶意程序同样监听了80端口,那么发送到80端口的请求就会被恶意程序接收并处理,这是我们不愿看到的。
Linux下处理方式为所有端口复用的进程必须在同一个用户下
Windows下处理方式为添加SO_EXECLUSIVEADDRUSE参数,程序设置该参数后,其它程序就不能复用这个端口
SO_REUSEADDR: Allows a socket to bind to an address and port already in use. The SO_EXCLUSIVEADDRUSE option can prevent this.
开箱即用
c语言程序直接调用setsockopt(fd, SOL_SOCKET, SO_REUSEPORT, &reuse_port, sizeof(reuse_port));函数即可
golang包greuse提供了开箱即用的端口复用功能,兼容多系统 https://github.com/gogf/greuse
有疑问加站长微信联系(非本文作者)
java多进程端口复用_多个程序监听同一端口 - socket端口复用技术相关推荐
- java多进程端口复用_多个程序监听同一端口 - socket端口复用技术
对于多个程序绑定同一个端口我们遇到最多的是(Port 80 was already in use),也就是说端口被占用,不能重复绑定,但是操作系统内核支持通过配置socket参数的方式来实现多个进程绑 ...
- python监听多个udp端口_Python的Socket编程过程中实现UDP端口复用的实例分享
关于端口复用 一个套接字不能同时绑定多个端口,如果客户端想绑定端口号,一定要调用发送信息函数之前绑定( bind )端口,因为在发送信息函数( sendto, 或 write ),系统会自动给当前网络 ...
- 怎么利用完成端口监听多个不同端口的socket
你可以试一试 创建两个监听线程,用事件event模型让其出发链接事件,然后两个不同的线程去处理send,recv 1.对于每个端口,都单独开一个监听线程 2.在每个线程里,有客户端连接的时候,用 Cr ...
- 微信小程序监听 watch方法
微信小程序监听 watch方法 使用过vue框架的应该使用过watch监听变量 那么 在微信小程序中 怎么使用watch 首先我们需要引入一个watch.js文件到我们的全局中 // 监听页面数据变化 ...
- docker 添加端口映射_苟且偷生的程序猿没法摸鱼了,从docker搭建elasticsearch集群开始学习...
最近刚换了公司,然后公司刚好使用的docker.而本人作为一个石锤的搬砖员,之前只知道搬砖们,对于这些东西确实没学过.今天在本地使用docker搭建elasticsearch集群,记录下过程,而且el ...
- 自学java编译老是出错_编写HelloWorld程序编译时提示写入HelloWorld时出错是什么意思...
编写HelloWorld程序编译时提示写入HelloWorld时出错是什么意思 这个能出错的地方就难说了,能给出代码或者错误提示吗 为什么javac编译后说写入错误呢HelloWorld.java : ...
- 指定端口传输_高速数字传输链路测试 - 高速数字电路仿真设计与测试技术发展趋势综述(二)...
对传输链路的关注程度越来越高 随着信号速率跃升到 Gbps 级别乃至今天的几十 Gbps 和全面的差分串行化,从最初关心的趋肤效应(Skin Effect)问题,开始更多关心介质损耗(Dielectr ...
- 升级bigsur_升级 macOS Big Sur 后,程序监听端口报错
作为一个喜欢尝试新事物,并且有一些安全意识的人,总是会第一时间升级新系统.在 macOS Big Sur 发布稳定版的第一天,我就升级了,从最开始不习惯圆滚滚的图标,现在也习惯了.不过今天在使用过程中 ...
- java计算器监听_计算器及事件监听
import java.awt.*; import java.awt.event.*; import java.util.Date; import javax.swing.*; public clas ...
最新文章
- 如何用 OS X 的 Xcode 写C语言程序
- poj 2078(搜索+剪枝)
- 在线识图翻译_拍照翻译ios版下载在线识图翻译-免费拍照翻译软件苹果版下载...
- javaWEB学习之filter
- 【OpenCV 例程200篇】26. 图像的旋转(以原点为中心)
- 作为一名程序员,他们工作时的快乐来源于哪里?不仅仅是高工资!
- 关于if 判断等于0 和‘0’的问题
- 0-1背包问题的简单解释
- Python开发不可不知的虚拟环境
- 易班自动答题脚本_在线答题系统,支持多种题型,增加问答题编辑器样式
- 计算机软件企业账务处理,企业购买软件会计上如何处理
- 火狐浏览器分辨率_Firefox在全球浏览器市场占有率达到20%
- 数据结构教程 李春葆主编 (第5版)绪论笔记
- MHL中的packedpixel概念
- torch.Tensor详解
- snap telemetry-Intel 网络遥测框架简介
- C语言调用 free 函数释放内存后指针指向及内存中的值是否改变的问题
- 目标跟踪算法--Camshift 和Meanshift
- o.s.s.s.TaskUtils$LoggingErrorHandler : Unexpected error occurred in scheduled task
- STM32 标准外设库(Standard Peripheral Library)
热门文章
- nmtui网络配置命令
- matplotlib中subplot的用法
- seurat的 addmodule循环画图 等同于基因的叠加图 识别细胞类型 空转与单细胞得到的marker基因联合
- D - Book Club Gym - 100783D 最大流Dinic
- 在Excel2003中,用A表示第1列,B表示第2列......Z表示第26列,AA表示第27列,AB表示第28列......以此类推。请写出一个函数,输入用字母表示的列号编码,输出它是第几列。
- 蓝桥杯 基础练习(六)杨辉三角 C语言
- 在ubuntu使用easyconnect
- 小学计算机走进魔力画室教案,第15课 创意绘画初体验 教案
- 虚拟网卡是什么?教教大家添加虚拟网卡的方法
- 杭州计算机职业学校,杭州中专职业学校排名