Linux系统编程——网络通信

2024-08-22 22:52

本文主要是介绍Linux系统编程——网络通信,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  共享内存(Shared Memory)

是一种进程间通信(Inter-Process Communication, IPC)机制,允许多个进程共享同一段内存区域。它是实现进程间高效数据交换的一种方式。

    1.共享内存的特点

       高效性、同步机制、内存映射、系统资源、跨进程访问、内存管理、灵活性、安全性。

     2.共享内存的原理

         1.内存映射  2.操作系统支持 3.同步机制 4.生命周期管理

Socket函数的作用和使用


在Linux系统中,socket函数是网络编程的基础,用于创建一个套接字(socket),这是一个通信端点,允许应用程序通过网络发送和接收数据。socket函数的原型如下:

#include <sys/types.h>
#include <sys/socket.h>
 
int socket(int domain, int type, int protocol);


  1. domain参数指定通信的地址族,如AF_INET用于IPv4通信。
  2 type参数指定套接字的类型,常见的有SOCK_STREAM(面向连接的流式套接字,如TCP)和       SOCK_DGRAM(无连接的数据报套接字,如UDP)。
  3.protocol参数通常设置为0,以使用type指定的默认协议。如果需要指定特定的协议,可以在支持的情况下指定非零值。
socket函数成功时返回一个非负的套接字描述符,失败时返回-1。

 sendto函数的作用和使用


sendto函数在网络编程中用于发送数据报,它可以将数据发送到一个指定的网络地址,而不需要建立一个连接。这个函数通常用于无连接的套接字,如使用UDP协议时。sendto函数的原型如下:

#include <sys/types.h>
#include <sys/socket.h>
 
ssize_t sendto(int sockfd, const void *buf, size_t len, int flags,
               const struct sockaddr *dest_addr, socklen_t addrlen);


  1.sockfd:已创建的套接字文件描述符。
  2.buf:指向要发送的数据的指针。
  3.len:要发送的数据的长度。
  4.flags:控制发送行为的标志,通常设置为0。
  5.dest_addr:指向包含目标地址的sockaddr结构的指针。
  6.addrlen:dest_addr结构的长度。
sendto函数返回成功发送的字节数,如果发生错误则返回-1。

recvfrom函数的作用和使用


recvfrom函数在网络编程中用于接收数据报,并同时获取发送数据报的源地址信息。这个函数通常用于无连接的套接字,如使用UDP协议时。recvfrom函数的原型如下:

#include <sys/types.h>
#include <sys/socket.h>
 
ssize_t recvfrom(int sockfd, void *buf, size_t len, int flags,
                 struct sockaddr *src_addr, socklen_t *addrlen);


  1.sockfd:已创建的套接字文件描述符。
  2.buf:指向接收数据缓冲区的指针。
  3.len:缓冲区的大小,以字节为单位。
  4.flags:控制接收行为的标志,通常设置为0。
  5.src_addr:指向sockaddr结构的指针,用于接收发送方的地址信息。
  6.addrlen:指向sockaddr结构大小的指针,在函数调用前设置为src_addr的大小,函数返回后包含实际存储的地址大小。
recvfrom函数成功时返回实际接收的字节数,如果连接被关闭则返回0,如果发生错误则返回-1。

bind函数的作用和使用


bind函数在网络编程中用于将一个套接字(socket)与一个特定的网络地址(IP地址和端口号)绑定。这个函数通常在服务器端使用,以便服务器进程可以监听来自客户端的连接请求。在创建套接字后,套接字默认没有绑定到任何地址,通过bind函数可以为套接字指定一个地址,这样就可以在网络上监听该地址的通信。
bind函数的原型如下:

#include <sys/types.h>
#include <sys/socket.h>
 
int bind(int sockfd, const struct sockaddr *addr, socklen_t addrlen);


  1.sockfd:已创建的套接字文件描述符。
  2.addr:指向包含地址信息的sockaddr结构的指针。
  3.addrlen:sockaddr结构的长度。
如果bind调用成功,它返回0;如果发生错误,返回-1。

TCP c/s模型


listen函数的作用和使用
listen函数在网络编程中用于将一个套接字设置为监听状态,这样它就可以接受客户端的连接请求。在TCP服务器编程中,listen函数通常在bind函数之后调用,用于告诉操作系统内核服务器套接字已经准备好接受连接。
listen函数的原型如下:

#include <sys/socket.h>
 
int listen(int sockfd, int backlog);


  1.sockfd:已通过socket函数创建并通过bind函数绑定地址的套接字文件描述符。
  2.backlog:指定内核中待处理的已完成连接队列的最大长度。这个值是一个提示,实际队列长度可能会由内核调整。
listen函数成功时返回0,如果发生错误则返回-1。

accept函数的作用和使用


accept函数在网络编程中用于从已监听的套接字上接受一个新的连接。当服务器套接字处于监听状态并且有客户端尝试连接时,accept函数会从等待连接队列中取出第一个完成的连接,并创建一个新的套接字来处理这个连接。这个新的套接字可以用于与客户端进行通信,而原始的监听套接字仍然可用于接受更多的连接请求。
accept函数的原型如下:

#include <sys/types.h>
#include <sys/socket.h>
 
int accept(int sockfd, struct sockaddr *addr, socklen_t *addrlen);


  1.sockfd:监听套接字的文件描述符。
  2.addr:指向一个sockaddr结构的指针,用于接收客户端的地址信息。如果不需要客户端地址信息,这个参数可以设置为NULL。
  3.addrlen:指向一个socklen_t类型的变量的指针,用于存储客户端地址的长度。在函数调用之前,这个变量应该被初始化为sizeof(struct sockaddr),函数执行后,它会包含实际接收到的地址的长度。
accept函数成功时返回一个新的套接字文件描述符,用于与客户端通信;如果发生错误,返回-1。

connect函数的作用和使用


connect函数用于建立一个到指定地址的套接字连接。在客户端编程中,connect函数用于初始化一个套接字,通过指定服务器的地址和端口来建立一个TCP连接。一旦连接成功,客户端就可以通过这个套接字发送和接收数据。
connect函数的原型如下:

#include <sys/socket.h>
 
int connect(int sockfd, const struct sockaddr *addr, socklen_t addrlen);


 

1.sockfd:通过socket函数创建的套接字文件描述符。
  2.addr:指向包含服务器地址和端口信息的sockaddr结构的指针。
  3.addrlen:addr参数所指向结构的长度。
connect函数成功时返回0,如果连接失败则返回-1,并设置errno以指示错误原因.

这篇关于Linux系统编程——网络通信的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Linux使用nload监控网络流量的方法

《Linux使用nload监控网络流量的方法》Linux中的nload命令是一个用于实时监控网络流量的工具,它提供了传入和传出流量的可视化表示,帮助用户一目了然地了解网络活动,本文给大家介绍了Linu... 目录简介安装示例用法基础用法指定网络接口限制显示特定流量类型指定刷新率设置流量速率的显示单位监控多个

ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法

《ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法》本文介绍了Elasticsearch的基本概念,包括文档和字段、索引和映射,还详细描述了如何通过Docker... 目录1、ElasticSearch概念2、ElasticSearch、Kibana和IK分词器部署

Linux流媒体服务器部署流程

《Linux流媒体服务器部署流程》文章详细介绍了流媒体服务器的部署步骤,包括更新系统、安装依赖组件、编译安装Nginx和RTMP模块、配置Nginx和FFmpeg,以及测试流媒体服务器的搭建... 目录流媒体服务器部署部署安装1.更新系统2.安装依赖组件3.解压4.编译安装(添加RTMP和openssl模块

linux下多个硬盘划分到同一挂载点问题

《linux下多个硬盘划分到同一挂载点问题》在Linux系统中,将多个硬盘划分到同一挂载点需要通过逻辑卷管理(LVM)来实现,首先,需要将物理存储设备(如硬盘分区)创建为物理卷,然后,将这些物理卷组成... 目录linux下多个硬盘划分到同一挂载点需要明确的几个概念硬盘插上默认的是非lvm总结Linux下多

在不同系统间迁移Python程序的方法与教程

《在不同系统间迁移Python程序的方法与教程》本文介绍了几种将Windows上编写的Python程序迁移到Linux服务器上的方法,包括使用虚拟环境和依赖冻结、容器化技术(如Docker)、使用An... 目录使用虚拟环境和依赖冻结1. 创建虚拟环境2. 冻结依赖使用容器化技术(如 docker)1. 创

linux进程D状态的解决思路分享

《linux进程D状态的解决思路分享》在Linux系统中,进程在内核模式下等待I/O完成时会进入不间断睡眠状态(D状态),这种状态下,进程无法通过普通方式被杀死,本文通过实验模拟了这种状态,并分析了如... 目录1. 问题描述2. 问题分析3. 实验模拟3.1 使用losetup创建一个卷作为pv的磁盘3.

CentOS系统Maven安装教程分享

《CentOS系统Maven安装教程分享》本文介绍了如何在CentOS系统中安装Maven,并提供了一个简单的实际应用案例,安装Maven需要先安装Java和设置环境变量,Maven可以自动管理项目的... 目录准备工作下载并安装Maven常见问题及解决方法实际应用案例总结Maven是一个流行的项目管理工具

Linux环境变量&&进程地址空间详解

《Linux环境变量&&进程地址空间详解》本文介绍了Linux环境变量、命令行参数、进程地址空间以及Linux内核进程调度队列的相关知识,环境变量是系统运行环境的参数,命令行参数用于传递给程序的参数,... 目录一、初步认识环境变量1.1常见的环境变量1.2环境变量的基本概念二、命令行参数2.1通过命令编程

Linux之进程状态&&进程优先级详解

《Linux之进程状态&&进程优先级详解》文章介绍了操作系统中进程的状态,包括运行状态、阻塞状态和挂起状态,并详细解释了Linux下进程的具体状态及其管理,此外,文章还讨论了进程的优先级、查看和修改进... 目录一、操作系统的进程状态1.1运行状态1.2阻塞状态1.3挂起二、linux下具体的状态三、进程的

Linux编译器--gcc/g++使用方式

《Linux编译器--gcc/g++使用方式》文章主要介绍了C/C++程序的编译过程,包括预编译、编译、汇编和链接四个阶段,并详细解释了每个阶段的作用和具体操作,同时,还介绍了调试和发布版本的概念... 目录一、预编译指令1.1预处理功能1.2指令1.3问题扩展二、编译(生成汇编)三、汇编(生成二进制机器语