首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

linux局域网通信源代码

Linux 局域网通信可以通过套接字(socket)编程来实现。以下是一个简单的示例代码,展示了如何在 Linux 系统中进行局域网通信。

服务器端代码

代码语言:txt
复制
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <arpa/inet.h>

#define PORT 8080
#define BUFFER_SIZE 1024

int main() {
    int server_fd, new_socket;
    struct sockaddr_in address;
    int addrlen = sizeof(address);
    char buffer[BUFFER_SIZE] = {0};

    // 创建套接字
    if ((server_fd = socket(AF_INET, SOCK_STREAM, 0)) == 0) {
        perror("socket failed");
        exit(EXIT_FAILURE);
    }

    // 绑定套接字到端口
    address.sin_family = AF_INET;
    address.sin_addr.s_addr = INADDR_ANY;
    address.sin_port = htons(PORT);

    if (bind(server_fd, (struct sockaddr *)&address, sizeof(address)) < 0) {
        perror("bind failed");
        exit(EXIT_FAILURE);
    }

    // 监听连接
    if (listen(server_fd, 3) < 0) {
        perror("listen");
        exit(EXIT_FAILURE);
    }

    // 接受连接
    if ((new_socket = accept(server_fd, (struct sockaddr *)&address, (socklen_t*)&addrlen)) < 0) {
        perror("accept");
        exit(EXIT_FAILURE);
    }

    // 读取数据
    read(new_socket, buffer, BUFFER_SIZE);
    printf("Received: %s\n", buffer);

    // 发送响应
    char *response = "Hello from server!";
    send(new_socket, response, strlen(response), 0);

    // 关闭套接字
    close(new_socket);
    close(server_fd);

    return 0;
}

客户端代码

代码语言:txt
复制
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <arpa/inet.h>

#define PORT 8080
#define SERVER_IP "127.0.0.1"
#define BUFFER_SIZE 1024

int main() {
    int sock = 0;
    struct sockaddr_in serv_addr;
    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);

    // 将IP地址转换为二进制形式
    if (inet_pton(AF_INET, SERVER_IP, &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;
    }

    // 发送数据
    char *message = "Hello from client!";
    send(sock, message, strlen(message), 0);

    // 读取响应
    read(sock, buffer, BUFFER_SIZE);
    printf("Received: %s\n", buffer);

    // 关闭套接字
    close(sock);

    return 0;
}

基础概念

  1. 套接字(Socket):套接字是网络通信的基本构建块,允许不同计算机之间的进程进行通信。
  2. IP地址:标识网络中的设备。
  3. 端口号:用于区分同一台计算机上的不同服务。

优势

  • 灵活性:可以轻松实现各种网络协议和服务。
  • 跨平台:Linux套接字编程可以在不同的操作系统上运行。
  • 高效性:直接与操作系统底层交互,性能较高。

类型

  • TCP(传输控制协议):提供可靠的、面向连接的通信。
  • UDP(用户数据报协议):提供无连接的、不可靠的通信,但速度较快。

应用场景

  • 文件传输:如FTP服务。
  • 远程登录:如SSH服务。
  • 实时通信:如聊天应用、在线游戏。

常见问题及解决方法

  1. 连接失败
    • 检查IP地址和端口号是否正确。
    • 确保防火墙允许相关端口的通信。
    • 使用netstatss命令检查端口是否被占用。
  • 数据传输错误
    • 使用校验和或其他错误检测机制。
    • 实现重传机制以确保数据的完整性。

通过以上代码和解释,你应该能够在Linux系统中实现基本的局域网通信。如果有更多具体问题,可以进一步探讨。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

linux局域网传输文件,局域网传输文件详解

局域网传输文件详解(转) 相信很多朋友都有过这样的经历,在办公室需要通过局域网传输文件。如果顺利自然不必说了,但有时难免也会遇到“不测”,尤其是直接移动文件,万一失败损失惨重,虽然几率不大但毕竟存在。...大家知道,本身的复制功能是不能实现断点续传的,也就是说如果在局域网中复制文件一旦失败,原先复制的文件就要重新复制,这种情况相信大家也曾有过体会,难道在局域网中复制文件还不如在互联网上下载文件那么可靠吗?...以上架设的FTP服务器,局域网中的其他用户也能通过它来访问共享文件夹,换言之局域网中的其他用户也能用到续传文件的功能。...现在局域网中就只有你可以用FTP服务器来访问共享文件夹,而其他用户就不能通过你的FTP服务器来访问共享资源了。...除了在局域网中复制文件时可以继点续传外,在单机中复制文件也同样可以实现文件的续传,操作方法同上。

5.3K20
  • 【Linux】:数据链路层(以太网 & 局域网通信 & ARP协议 & ARP 欺骗 & DDos 攻击)

    (子网,内网)范围内唯一标识设备的地址,一般只能在同一局域网内进行通信(寻址 和 转发),例如:以太网的数据链路层使用MAC地址进行设备之间的通信 IP地址可以在广域网(公网,外网)范围内唯一标识设备的地址...结论:MAC地址用于局域网内通信,IP地址用于广域网通信,即起点和终点 三、局域网通信  假设有如下子网,有若干设备,此时如果主机A想和主机D通信,那么MAC帧的报头字段的源地址为macA,目的地址为macD...MSS 的值就是在 TCP 首部的 40 字节变长选项中(kind=2) 查看硬件地址和MTU大小 Linux下使用 ifconfig 命令 3....局域网通信的传输细节 这里我们先来 简单 模拟一下局域网通信的过程: 在局域网中有若干主机 ABCD…,主机 A 此时向 G 发送信息。...总结:IP 和 MAC 缺一不可 场景 IP 地址的作用 MAC 地址的作用 跨网络通信(如北京→纽约) 告诉全球路由器“数据要到哪里” 无关(只在目标局域网内使用) 局域网内通信(如家庭 Wi-Fi)

    12210

    【Linux】进程间通信——管道通信

    进程间通信 什么是进程间通信 进程间通信(IPC)是指不同进程之间交换数据或协作的机制。由于每个进程都有独立的地址空间,它们不能直接访问彼此的内存,因此需要 IPC 机制来进行数据传输和同步。...进程间通信的方式 常见的通信方式有:管道,消息队列,共享内存,信号量,信号,套接字等等 这期我们主要讲的是管道通信 管道通信 什么是管道通信 管道通信是一种 进程间通信 方式,允许 相关进程 之间通过...管道通信的过程 上图就是管道通信的过程。...总结 管道(Pipe)作为 Linux 进程间通信(IPC)机制之一,提供了一种简单而高效的字节流通信方式,特别适用于父子进程之间的数据传输。...在不同场景下,选择合适的通信方式,才能充分发挥 Linux 进程间通信的优势,提高程序的稳定性和性能。

    5800

    Linux进程通信

    Linux进程通信 1 管道(pipe) 1.1 无名管道 1.1.1 概念和相关知识 1.1.2 相关函数 1.2 命名管道 1.2.1 概念及相关知识 1.2.2 相关函数 2 信号量(semaphore...在Linux系统中专门设置了一种特殊的系统文件-管道文件——FIFO的文件形式存在于文件系统中,这样,即使与FIFO的创建进程不存在亲缘关系的进程,只要可以访问该路径,就可以通过FIFO进行彼此间的通信...比如,登录Linux时,系统会自动分配给登录用户一个控制终端,在这个终端运行的所有程序,包括前台和后台进程组,一般都属于同一个会话。...6 套接字(socket) 套接字是一种进程间通信机制,可用于不同机器间的进程通信。...在Linux系统中,1024以下的端口只有拥有root权限的程序才能绑定。

    1.9K20

    【Linux】进程通信之匿名管道通信

    一、进程间进行通信的目的 我们往往需要多个进程协同,共同完成一些事情。 数据传输:一个进程需要将它的数据发送给另一个进程 资源共享:多个进程之间共享同样的资源。...操作系统提供的资源不同,就决定了有不同的通信方式。 二、管道通信 2.1、匿名管道通信的原理 基于文件的方式,让不同进程看到同一份资源的通信方式,叫做管道,管道通信只能为单向通信。...前面也说过,管道通信为单向通信,所以如果想让父进程写子进程读,就关闭父进程的读端关闭子进程的写端,反之亦然。...匿名管道只能让具有血缘关系的进程进行进程通信,常用于父子进程之间进行进程通信。...2.3、匿名管道通信的简单实现 #include #include #include #include #include

    17310

    Linux进程通信——管道

    管道 进程通信概念 管道 匿名管道 创建匿名管道的过程 管道读写的特性 管道本身的特征 基于管道的进程池设计 命名管道 让两个无血缘关系的进程通信 进程通信概念 什么是进程通信 首先我们清楚,进程是具有独立性的...,如果想让进程通信,那么成本一定不低。...怎么进行通信 目前通信有两套标准: POSIX——让通信过程可以跨主机 System V——聚焦在本地通信(比较陈旧的标准) 重点:共享内存 管道 管道是Unix中最古老的进程间通信的形式。...那么两个进程通信: 第一个条件就是操作系统需要给双方进程提供内存空间。 第二个条件是要通信的进程看到同一份资源。...管道本身的特征 1.管道的生命周期是进程的生命周期 2.管道可以用来进行具有血缘关系的进程之间进行通信,常用于父子通信。

    4K70

    Linux 进程间通信

    进程间通信(interprocess communication,简称 IPC)指两个进程之间的通信。...系统中的每一个进程都有各自的地址空间,并且相互独立、隔离,每个进程都处于自己的地址空间中,因此相互通信比较难,Linux 内核提供了多种进程间通信的机制。...Linux 内核提供了多种 IPC 机制,基本是从 UNIX 系统继承而来,而对 UNIX 发展做出重大贡献的两大主力 AT&T 的贝尔实验室及 BSD(加州大学伯克利分校的伯克利软件发布中心)在进程间通信方面的侧重点有所不同...Linux 则把两者继承了下来,如下如所示: 早期的 UNIX IPC 包括:管道、FIFO、信号;System V IPC 包括:System V 信号量、System V消息队列、System V...Linux 提供了一组精心设计的信号量接口来对信号量进行操作,它们声明在头文件 sys/sem.h 中。

    3.2K20

    【Linux】进程间通信

    进程间通信 顾名思义,进程通信( InterProcess Communication,IPC)就是指进程之间的信息交换。...进程间通信本质 进程间通信的本质: 必须让不同的进程看到同一份"资源" "资源"指特定形式的内存空间 这个"资源"一般是由操作系统提供并管理 一般操作系统会有一个独立的通信模块,隶属于文件系统(即IPC...通信模块) 进程间通信发展 进程间通信经历了很长一段时间的发展,衍生出了许多通信方法和标准,其中包括以下几种主要的方式: 管道 SystemV进程间通信(本机内部通信) POSIX...进程间通信(网络通信) 进程间通信分类 管道 匿名管道pipe 命名管道 System V IPC System V 消息队列 System V 共享内存 System...V 信号量 POSIX IPC 消息队列 共享内存 信号量 互斥量 条件变量 读写锁 结语 希望这篇关于 linux进程间通信 的博客能对大家有所帮助,欢迎大佬们留言或私信与我交流

    6910

    Linux进程间通信

    我们在Linux信号基础中已经说明,信号可以看作一种粗糙的进程间通信(IPC, interprocess communication)的方式,用以向进程封闭的内存空间传递信息。...为了让进程间传递更多的信息量,我们需要其他的进程间通信方式。这些进程间通信方式可以分为两种: 管道(PIPE)机制。...在Linux文本流中,我们提到可以使用管道将一个进程的输出和另一个进程的输入连接起来,从而利用文件操作API来管理进程间通信。...从原理上,管道利用fork机制建立(参考Linux进程基础和Linux从程序到进程),从而让两个进程可以连接到同一个PIPE上。...互联网通信实际上也是一个进程间通信的问题,只不过这多个进程分布于不同的电脑上。网络连接是通过socket实现的。由于socket内容庞大,所以我们不在这里深入。

    3.8K101

    【分享】精简Linux的源代码

    作者:付汉杰 Linux是现在最流行的操作系统,含有大量的源代码。Xilinx 2020.1使用的Linux 5.4,含有大约67430个文件。大部分文件没有被使用到。...如果我们知道Linux的编译流程的起始时间,那么删除所有访问时间比Linux的编译起始时间早的文件,就能达到精简Linux的源代码的目的。在编译Linux之前,可以通过touch命令创建一个文件。...这个文件的atime,就是编译Linux开始时间。因此比较这个文件,和其它Linux文件,就能找到所有访问时间比Linux的编译起始时间早的文件,从而实现精简Linux的源代码。...再恢复对应文件,既精简了Linux的源代码,也不影响Linux的编译流程。对Linux 5.4进行精简后,剩余大约8800个文件,减少了大约58000个文件,精简了超过87%的文件数量。...以后可以考虑使用tinyconfig来精简Linux的源代码。

    2.7K20

    Linux之制作局域网yum源

    在《Linux之CentOS本地资源库(yum源)的配置》的博文中,小菌为大家介绍了如何在CentOS制作本地yum源,相信大家已经熟练掌握了。...原因: 因为linux的防火墙禁止他人访问自己的80端口 解决: 通知防火墙放行 关闭防火墙 原因: 为了方便内网中集群间机器的相互操作,通常会关闭防火墙 service iptables stop...制作局域网yum源 先确定把哪一台服务器设置成局域网yum源,这里我以hadoop001为例 将hadoop001服务器的iso源的路径复制到指定的路径 # 将iso源的路径复制到指定的路径...-r /mnt/cdrom/* /var/www/html/CentOS-6.9 打开浏览器输入192.168.100.111/CentOS-6.9,我们可以发现成功把原先本地yum源的文件放到了局域网上...yum源需要先下载httpd服务,利用httpd把一个服务器的yum源文件上传到局域网上,让同一个局域网下的其他服务器也能连接上,省去了每台服务器都需要配置本地yum源的麻烦。

    3.3K20

    Linux内核源代码分析经验

    Linux的最大的好处之一就是它的源码公开。...同时,公开的核心源码也吸引着无数的电脑爱好者和程序员;他们把解读和分析Linux的核心源码作为自己的 最大兴趣,把修改Linux源码和改造Linux系统作为自己对计算机技术追求的最大目标。   ...所有源文件均是相对于目录/usr/src/linux的。   要分析Linux内核源码,首先必须找到各个模块的位置,也即要弄懂源码的文件组织形式。...1、Linux核心源程序通常都安装在/usr/src/linux下,而且它有一个非常简单的编号约定:任何偶数的核心(的二个数为偶数,例如 2.0.30)都是一个稳定地发行的核心,而任何奇数的核心(例如...对具有GPL版权的源代码改动而形成的程序,或使用GPL工具产生的程序,具有使用GPL发表的义务,如公开源代码。   ◆ CREDITS: 光荣榜。

    2.8K20
    领券