首页 > 系统相关 >Linux学习/TCP Socket通信

Linux学习/TCP Socket通信

时间:2024-08-19 20:04:32浏览次数:14  
标签:Socket address TCP server socket Linux 接字 include addr

案例

案例一

server.c

#include <stdio.h> // 标准输入输出
#include <stdlib.h> //提供通用的工具函数,例如内存分配和程序退出。
#include <string.h> //提供字符串处理函数。
#include <unistd.h> //提供对 POSIX 操作系统 API 的访问,包括对文件描述符的操作。
#include <arpa/inet.h> //提供与 Internet 地址转换相关的函数和数据结构。

#define PORT 8082 //PORT 是服务器监听的端口号,设置为 8082。
#define BUFFER_SIZE 1024 //定义了缓冲区的大小,用于接收数据,设置为 1024 字节。

int main()
{
    int server_fd; //用于存储服务器套接字的文件描述符
    int new_socket; //客户端连接的套接字描述符
    struct sockaddr_in address; //sockaddr_in 结构体,表示服务器的地址信息。
    int opt = 1; //用于设置套接字选项(端口重用)。
    int addrlen = sizeof(address); //服务器地址结构的大小。
    char buffer[BUFFER_SIZE] = {0}; //用于接收客户端发送的消息,并初始化为零。

    /*使用 socket 函数创建一个套接字。参数 AF_INET 指定使用 IPv4,SOCK_STREAM 表示使用 TCP 协议。
     *如果创建失败,函数返回值为 -1,输出错误信息并退出程序。*/
    if ((server_fd = socket(AF_INET, SOCK_STREAM, 0)) < 0)
    {
        perror("server create failed\n");
        exit(EXIT_FAILURE);
    }

    /*使用 setsockopt 函数允许套接字重用地址。设置选项 SO_REUSEADDR,这使得即使在套接字关闭后,新的套接字也可以绑定到同一端口。
     *如果设置选项失败,输出错误信息并退出程序。*/
    if (setsockopt(server_fd, SOL_SOCKET, SO_REUSEADDR, &opt, sizeof(opt)))
    {
        perror("setsockopt");
        exit(EXIT_FAILURE);
    }

    // 配置服务器地址结构
    address.sin_family = AF_INET; //设置 address 的地址家族为 AF_INET,表示 IPv4。
    // address.sin_addr.s_addr = INADDR_ANY; //使用 INADDR_ANY,表示服务器将监听所有可用的网络接口。
    inet_pton(AF_INET, "127.0.0.1", &address.sin_addr);
    address.sin_port = htons(PORT);//使用 htons 函数将主机字节序转换为网络字节序,以确保在不同平台上端口号的正确性。

    /*使用 bind 函数将套接字与指定的地址(包含 IP 和端口)进行绑定。如果绑定失败,输出错误信息并退出程序。*/
    if (bind(server_fd, (struct sockaddr *)&address, sizeof(address)) < 0)
    {
        perror("bind failed");
        exit(EXIT_FAILURE);
    }

    /*使用 listen 函数使套接字进入监听状态,准备接受客户端连接。第二个参数指定最大等待连接的数量(3)。
     *如果监听失败,输出错误信息并退出程序。*/
    if (listen(server_fd, 3) < 0)
    {
        perror("listen");
        exit(EXIT_FAILURE);
    }

    printf("等待连接...\n");
    /*使用 accept 函数接受来自客户端的连接。如果接受失败,输出错误信息并退出程序。成功后,new_socket 用于与客户端进行通信。*/
    if ((new_socket = accept(server_fd, (struct sockaddr *)&address, (socklen_t *)&addrlen)) < 0)
    {
        perror("accept");
        exit(EXIT_FAILURE);
    }

    /*使用 read 函数从与客户端连接的套接字读取数据,存储到 buffer 中,最多接收 BUFFER_SIZE 字节的数据。*/
    read(new_socket, buffer, BUFFER_SIZE);
    printf("接收到消息: %s\n", buffer);

    // 发送回应给客户端
    const char *msg = "Hello from server";
    /*使用 send 函数将这个消息发送到客户端,传入消息长度(strlen(msg))和标志参数(这里为 0)。*/
    send(new_socket, msg, strlen(msg), 0);

    /*使用 close 函数关闭与客户端的套接字(new_socket),释放相应的资源。
     *关闭服务器套接字(server_fd),释放相应的资源。*/
    close(new_socket);
    close(server_fd);
    return 0;
}

client.c

#include <stdio.h> 
#include <stdlib.h> 
#include <string.h> 
#include <unistd.h> 
#include <arpa/inet.h> 

#define PORT 8082 
#define BUFFER_SIZE 1024 

int main()
{
    int sock = 0;
    struct sockaddr_in serv_addr;
    char *message = "Hello from client";
    char buffer[BUFFER_SIZE] = {0};

    // 创建套接字
    if ((sock = socket(AF_INET, SOCK_STREAM, 0)) < 0)
    {
        printf("\n Socket creation error \n");
        return -1;
    }

    // 配置服务器地址结构
    serv_addr.sin_family = AF_INET;
    serv_addr.sin_port = htons(PORT);

    /*使用 inet_pton 将字符串格式的 IP 地址("127.0.0.1")转换为二进制格式并存储在 serv_addr.sin_addr 中。这个IP地址指的是本机。*/
    if (inet_pton(AF_INET, "127.0.0.1", &serv_addr.sin_addr) <= 0)
    {
        printf("\nInvalid address/ Address not supported \n");
        return -1;
    }

    // 连接到服务器
    if (connect(sock, (struct sockaddr *)&serv_addr, sizeof(serv_addr)) < 0)
    {
        printf("\nConnection Failed \n");
        return -1;
    }

    // 发送消息到服务器
    send(sock, message, strlen(message), 0);
    printf("消息已发送\n");

    // 接收服务器消息
    read(sock, buffer, BUFFER_SIZE);
    printf("接收到回应: %s\n", buffer);

    // 关闭套接字
    close(sock);
    return 0;
}

终端执行结果
先执行server打开监听,再执行client开始连接

标签:Socket,address,TCP,server,socket,Linux,接字,include,addr
From: https://www.cnblogs.com/songpoetry/p/18368018

相关文章

  • TCPIP路由技术第一卷第八章OSPF 第三部分-1 NETWORK Type-3 FR-Star
    tcp/ip_ospfoverframe-relay2第二部分:部分互联1.三台设备接口同一网段部分全互联,网络类型broadcast,确保hub为dr,在星型拓扑下会出现二层封装问题,encapsulationfailed解决方案,增加pvc映射2.三台设备接口同一网段部分互联:网络类型nbma,确保hub作为dr,在dr上单播指定邻......
  • tcp与udp的总结+connect阻塞+tcp三次握手、四次挥手+常见的服务器IO(发送数据+接收数
    一,TCP与UDP的基本总结TCP(传输控制协议)和UDP(用户数据报协议)是两种主要的传输层协议。TCP是面向连接的,提供可靠、顺序的传输,适用于需要高可靠性的应用,如网页浏览和文件传输。它通过重传机制和流量控制确保数据完整性。UDP是无连接的,速度快但不保证数据的可靠性和顺序,适用于对实时性......
  • 【Linux_install】详细的Ubuntu和win双系统安装指南
    @目录1.前期准备1.1制作启动盘1.2关闭快速启动、安全启动、bitlocker1.2.1原因1.2.2进入BIOSshell命令行进入BIOSwindows设置中高级启动在开机时狂按某个键进入BIOS1.2.3关闭Fastboot和Secureboot1.3划分磁盘空间1.3.1查看目前的虚拟内存大小2.开始安装2.1使用启动盘启动......
  • Linux---systemctl常用命令以及service文件配置
    简介1.1什么是systemctl命令        systemctl是一个在Linux系统中用于管理系统服务的命令。它是systemd这个初始化系统的一部分,通过控制和监视系统的服务和单位文件,提供了对系统进程的强大管理功能。1.2systemctl的作用和用途        systemctl可以用于......
  • Linux CentOS手动安装Node.js(图文教程)
    本章教程主要介绍如何在centos7上安装指定版本的Node.js一、下载nodejs前往Node.js官网,根据自己需要安装的版本进行下载。官网下载地址:https://nodejs.org/zh-cn/download/prebuilt-binaries本文,以v14.21.3版本介绍整个安装过程。二、上传压缩包下载之后,你会得......
  • Linux安装MQTT 服务器(图文教程)
    MQTT(MessageQueuingTelemetryTransport)是一种轻量级的消息传输协议,专为低带宽和不稳定的网络环境设计,非常适合物联网(IoT)应用。官网地址:https://www.emqx.com/一、版本选择根据自己的操作系统进行下载即可,推荐使用rpm安装方式。下载地址:https://www.emqx.com/zh/do......
  • ubuntu(linux): 编译安装使用python3.12.5
    一,python官网:https://www.python.org/下载页面:https://www.python.org/downloads/source/如图:二,安装1,下载:wget从命令行下载:liuhongdi@lhdpc:/usr/local/source/python$wgethttps://www.python.org/ftp/python/3.12.5/Python-3.12.5.tgz2,解压:liuhongdi@lhdpc:/......
  • 探索GitHub的无限可能:从注册到Linux环境下的库分支链接
            在这个数字化时代,GitHub已成为开发者们不可或缺的宝藏库。无论你是编程新手还是资深开发者,GitHub都能为你打开一扇通往无限创意与协作的大门。今天,就让我们一起踏上这段探索之旅,从GitHub的注册开始,再到如何在Linux环境中链接库分支并发送,让你轻松掌握GitHub的......
  • linux安装go 环境
    嗯,每个人的工作方法不一样,不喜勿喷哈这是我安装的go不是最新的[root@simetra-ecs-01go]#goversiongoversiongo1.19.8linux/amd64[root@simetra-ecs-01go]#首先先去下载golang的安装包,我用的是go1.19.8.linux-amd64.tar.gz解压到/usr/local目录下[root@k8s......