[muduo网络库]——muduo库Socket类(剖析muduo网络库核心部分、设计思想)

2024-05-12 14:52

本文主要是介绍[muduo网络库]——muduo库Socket类(剖析muduo网络库核心部分、设计思想),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

接着之前我们[muduo网络库]——muduo库Acceptor类(剖析muduo网络库核心部分、设计思想),我们接下来继续看muduo库中的Socket类。

Socket类

Socket类实际上就是封装socket fd。

重要成员变量

const  int sockfd_;
  • 因为Socket类实际上就是封装socket fd,所以成员变量也很简单,只有sockfd_

重要成员方法

  • 绑定bindAddress
void Socket::bindAddress(const InetAddress &localaddr)
{if(0 != ::bind(sockfd_,(sockaddr*)localaddr.getSockAddr(),sizeof(sockaddr_in))){LOG_FATAL("bind sockfd:%d fail\n",sockfd_);}
}

调用系统底层的bind来绑定服务器IP端口

  • 监听listen()
void Socket::listen()
{if (0 != ::listen(sockfd_,1024)){LOG_FATAL("listen sockfd:%d fail\n",sockfd_);}
}

调用系统底层的listen来监听套接字

  • 接受连接accept
int Socket::accept(InetAddress *peeraddr)
{sockaddr_in addr;socklen_t len = sizeof addr;bzero(&addr,sizeof addr);int connfd = ::accept4(sockfd_,(sockaddr*)&addr,&len, SOCK_NONBLOCK | SOCK_CLOEXEC);if(connfd >= 0){peeraddr->setSockAddr(addr); //把客户端地址传出去}return connfd;
}

调用系统底层的accept来接受新客户的连接请求,那么其返回值是由内核自动生成的一个全新的描述字connfd ,代表与返回客户的TCP连接。

  • 关闭写端
void Socket::shutdowmWrite()
{if(::shutdown(sockfd_,SHUT_WR) < 0){LOG_ERROR("shutdownWrite errpr");}
}

调用系统底层的shutdown关闭服务端的写通道。

  • 设置socket选项
void setTcpNoDelay(bool on);void setReuseAddr(bool on);  void setReusePort(bool on);  void setKeepAlive(bool on);

1)setTcpNoDelay禁用 Nagle 算法,避免连续发包出现延迟,这对编写低延迟网络服务很重要
2)SOL_SOCKET 是协议级别,表示我们正在设置套接字级的选。SO_REUSEADDR 设置了一个套接字的地址复用选项。用于允许套接字在关闭后立即重新使用其地址。这在进行服务器编程时特别有用,因为在服务器重启或关闭后,它通常需要立即重新绑定到相同的地址和端口。
3)SO_REUSEPORT 设置了一个套接字的端口复用选项。用于允许多个套接字绑定到同一个端口上。
4)SO_KEEPALIVE 用于启用或禁用 “Keep-Alive” 功能。启用这个功能后,如果套接字在一段时间内没有活动,操作系统会发送一个数据包来检查连接是否仍然有效。

代码地址:https://github.com/Cheeron955/mymuduo/tree/master

好了~ 有关于muduo库的Socket类的细节就到此结束了,Socket还是比较简单,容易理解的。接下来我们会介绍muduo库Buffer类,我们下一节见~~

这篇关于[muduo网络库]——muduo库Socket类(剖析muduo网络库核心部分、设计思想)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/982931

相关文章

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

详解MySQL中DISTINCT去重的核心注意事项

《详解MySQL中DISTINCT去重的核心注意事项》为了实现查询不重复的数据,MySQL提供了DISTINCT关键字,它的主要作用就是对数据表中一个或多个字段重复的数据进行过滤,只返回其中的一条数据... 目录DISTINCT 六大注意事项1. 作用范围:所有 SELECT 字段2. NULL 值的特殊处

Python包管理工具核心指令uvx举例详细解析

《Python包管理工具核心指令uvx举例详细解析》:本文主要介绍Python包管理工具核心指令uvx的相关资料,uvx是uv工具链中用于临时运行Python命令行工具的高效执行器,依托Rust实... 目录一、uvx 的定位与核心功能二、uvx 的典型应用场景三、uvx 与传统工具对比四、uvx 的技术实

MyBatis设计SQL返回布尔值(Boolean)的常见方法

《MyBatis设计SQL返回布尔值(Boolean)的常见方法》这篇文章主要为大家详细介绍了MyBatis设计SQL返回布尔值(Boolean)的几种常见方法,文中的示例代码讲解详细,感兴趣的小伙伴... 目录方案一:使用COUNT查询存在性(推荐)方案二:条件表达式直接返回布尔方案三:存在性检查(EXI

java中Optional的核心用法和最佳实践

《java中Optional的核心用法和最佳实践》Java8中Optional用于处理可能为null的值,减少空指针异常,:本文主要介绍java中Optional核心用法和最佳实践的相关资料,文中... 目录前言1. 创建 Optional 对象1.1 常规创建方式2. 访问 Optional 中的值2.1

如何解决Druid线程池Cause:java.sql.SQLRecoverableException:IO错误:Socket read timed out的问题

《如何解决Druid线程池Cause:java.sql.SQLRecoverableException:IO错误:Socketreadtimedout的问题》:本文主要介绍解决Druid线程... 目录异常信息触发场景找到版本发布更新的说明从版本更新信息可以看到该默认逻辑已经去除总结异常信息触发场景复

Linux网络配置之网桥和虚拟网络的配置指南

《Linux网络配置之网桥和虚拟网络的配置指南》这篇文章主要为大家详细介绍了Linux中配置网桥和虚拟网络的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 一、网桥的配置在linux系统中配置一个新的网桥主要涉及以下几个步骤:1.为yum仓库做准备,安装组件epel-re

python如何下载网络文件到本地指定文件夹

《python如何下载网络文件到本地指定文件夹》这篇文章主要为大家详细介绍了python如何实现下载网络文件到本地指定文件夹,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下...  在python中下载文件到本地指定文件夹可以通过以下步骤实现,使用requests库处理HTTP请求,并结合o

Java Jackson核心注解使用详解

《JavaJackson核心注解使用详解》:本文主要介绍JavaJackson核心注解的使用,​​Jackson核心注解​​用于控制Java对象与JSON之间的序列化、反序列化行为,简化字段映射... 目录前言一、@jsonProperty-指定JSON字段名二、@JsonIgnore-忽略字段三、@Jso

Linux高并发场景下的网络参数调优实战指南

《Linux高并发场景下的网络参数调优实战指南》在高并发网络服务场景中,Linux内核的默认网络参数往往无法满足需求,导致性能瓶颈、连接超时甚至服务崩溃,本文基于真实案例分析,从参数解读、问题诊断到优... 目录一、问题背景:当并发连接遇上性能瓶颈1.1 案例环境1.2 初始参数分析二、深度诊断:连接状态与