注意:其实socket也没有层的概念,它只是一个facade设计模式的应用,让编程变的更简单。是一个软件抽象层。在网络编程中,我们大量用的都是通过socket实现的。...然后,应用程序以该描述符作为传递参数,通过调用函数来完成某种操作(例如通过网络传送数据或接收输入的数据)。...具体如何实现,可以看看linux的内核 5.Linux C Socket简单实例与详细注释 程序为简单的“回射”,客户端将控制台输入的信息发送给服务器端,服务器原样返回信息。...C Socket编程原理及简单实例 2....Linux的SOCKET编程详解 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
(NIC) 为什么是这样从上到下的贯穿?...在Linux系统中,我们可以通过ifconfig命令来查看自己机器的MAC地址: ether后面就是mac地址。...IP层的引入屏蔽了底层网络差异(如以太网、Wi-Fi、光纤),通过逻辑化的IP地址实现全球路由,让不同技术的网络能无缝互联。 二、socket编程预备 IP在网络中,用来标识一个主机的唯一性。...我们之前在学习系统编程的时候, 学习了 pid 表示唯一一个进程 ; 此处我们的端口号也是唯一表示一个进程. 那么这两者之间是怎样的关系 ?...2.4、sockaddr 结构 socket API 是一层抽象的网络编程接口 , 适用于各种底层网络协议 , 如 IPv4 、 IPv6, 以及后面要讲的 UNIX Domain Socket.
在前面的文章中,我们使用了UDP进行网络编程,这篇文章我们就来使用另一个TCP进行网络编程,我们知道UDP和TCP都是传输层协议,但是特点不同,前者无连接,不可靠传输,面向数据报,后者有连接,可靠传输...大体框架 1.1 补充 首先,在之前的UDP网络编程中,我们是直接使用的硬编码,例如退出码直接就设为1、2、3等,显然这并不是一个很好的选择,那么这里我们可以统一设计一个服务器的退出码,就像之前设计日志等级一样...一般多进程多线程比较适合长服务,线程池适合短服务,但也不是绝对的,这里我们只简单提一下,当然也可以将死循环改一下,那客户端数量就不会仅限于5个了,感兴趣可以自己下来尝试一下 4....直接向目标服务器发起建立连接的请求 return 0; } 我们这里也不需要显式bind,关于原因我们在udp网络编程时已经说明了,那我们应该做什么呢?...,上层服务我们可以和UDP网络编程一样,直接在服务端主程序调用其他的服务,就比如之前实现的翻译和路由转发,然后在服务端接收数据时,将数据回调处理,最后将结果写回客户端。
Linux Socket编程 ---- 目录 前言 Socket的功能 Socket基础 Socket类型 基本结构 基本转换函数 基本Socket使用 TCP Socket实例 UDP Socket实例...疑难问题记录 总结 ---- 前言 socket(套接字)是网络编程编程的一种技巧。...本篇不涉及太底层的网络原理,仅说明socket的基本使用方法。主要参考《Linux网络编程》。本篇源码获取方式见文底小字。...getprotobyname()函数 —— 获得网络协议名。 TCP Socket实例 TCP Socket可以理解为Inet使用流式套接字,为保证通讯稳定而采用TCP协议。...网络编程非常有趣,能够实现天南海北之间的通讯,让远距离的人与人、人与物或者物与物之间产生联系,很有意思! 最后 用心感悟,认真记录,写好每一篇文章,分享每一框干货。
就会给服务器带来比较大的压力,对于这种情况,可以通过使用线程池来优化: 通过使用线程池,解决了短时间内有大量客户端发送请求之后就断开了的问题,但是如果说客户端持续的发送请求处理响应,那么连接就会保持很久,这样的场景下使用多线程...多路复用来解决,相比于处理请求的时间,大部分时间可能都是在阻塞等待,如果可以让一个线程同时给多个客户提供服务就可以了,IO 多路复用就是在操作系统内部提供的功能(IO 多路复用具体实现的方案有多种),例如 Linux...下的 epoll ,就是在内核中创建了一个数据结构,可以把多个 socket (每一个 socket 对应一个客户端)放到这个数据结构中,同一时刻,大部分的 socket 都是处于阻塞等待,少部分收到数据的...就代表数据传输中数据发生了改变,就会丢弃这次传输 此外还可能会发生传输过程中校验和的信息也发生改变了,也就是传输过程中校验和变成了 checksum3,此时接收方重新计算校验和得到了 checksum4 ,这种情况下两个校验和大概率是不相等的...,使通信继续进行,如果网络还是有问题,复位报文没有得到回应,此时 TCP 就会单方面放弃连接 确认应答和超时重传这两个核心机制共同构建了 TCP 的“可靠传输机制”
Linux系统下的多线程遵循POSIX线程接口,称为 pthread。编写Linux下的多线程程序,需要使用头文件pthread.h,连接时需要使用库libpthread.a。...顺便说一下,Linux 下pthread的实现是通过系统调用clone()来实现的。...clone()是 Linux所特有的系统调用,它的使用方式类似fork,关于clone()的详细情况,有兴趣的读者可以去查看有关文档说明。...另外,因为pthread的库不是linux系统的库,所以在进行编译的时候要加上-lpthread,否则编译不过,会出现下面错误 thread_test.c: 在函数 ‘create’ 中: thread_test.c
一般具有定制协议或者标准的资格的组织或者公司都必须是业界公认或者具有江湖地 位的组织或者公司, 下面是文心一言生成的标准制定组织, 大家看一下就可以。...之前我们在学习系统编程的时候知道访问公共资源就是临界资源,那么这里的局域网就是一个临界资源(以太网中, 任何时刻, 只允许一台机器向网络中发送数据)。...: IP 网络层存在的意义: 提供网络虚拟层, 让世界的所有网络都是 IP 网络, 屏蔽 最底层网络的差异 Socket 编程预备 理解源 IP 地址和目的 IP 地址 IP在网络中是用来标识主机的唯一性...sockadder结构 socket API 是一层抽象的网络编程接口,适用于各种底层网络协议,如 IPv4、 IPv6,以及 后面要讲的 UNIX Domain Socket....关于Socket套接字编程后续文章会详细讲解。
Socket soket接口是TCP/IP网络的API。网络的socket数据传输是一种特别的I/O,socket也是一种文档描述符。...),SOCK_RAW(原始socket,允许socket调用底层协议) protocol:通常赋值为0 socket描述符是一个指向内部数据结构的指针,执行描述符表的入口 两个网络程式之间的一个网络连接包括...,而sin_addr则无需转换 internet上数据以高位优先 顺序传输,故需要实现进行转换 htonl(); 把32位值从主机字节序转换为网络字节序 htons(); 把16位值从主机字节序转换为网络字节序...ntohl(); 把32位值从网络字节序转换为主机字节序 ntohs(); 把16位值从网络字节序转换为主机字节序 bind函数在成功调用后,返回0,出错返回-1并将errno设置为响应的错误号... from是sockaddr结构的变量,保存源机的IP地址和端口号,fromlen指向sizeof (struct sockaddr)的变量 结束传输 close(sockfd); 实例代码
Linux系统下的多线程遵循POSIX线程接口,称为 pthread。编写Linux下的多线程程序,需要使用头文件pthread.h,连接时需要使用库libpthread.a。...顺便说一下,Linux 下pthread的实现是通过系统调用clone()来实现的。...clone()是 Linux所特有的系统调用,它的使用方式类似fork,关于clone()的详细情况,有兴趣的读者可以去查看有关文档说明。...多线程编程 http://www.makeru.com.cn/course/details/1937?...s=45051 linux基础 http://www.makeru.com.cn/course/details/2058?s=45051
文章目录 前言 一、UDP是什么 二、UDP 数据报服务特点 二、UDP 编程流程 1.服务器 2.客户端 3.输出结果 总结 前言 浅谈UDP。...二、UDP 编程流程 1.服务器 代码如下(示例): int main() { int sockfd = socket(AF_INET,SOCK_DGRAM,0); assert( sockfd
TCP/IP协议 TCP/IP 协议栈是一系列网络协议(protocol)的总和,是构成网络通信的核心骨架,它定义了电子设备如何连入因特网,以及数据如何在它们之间进行传输。...OSI 7层模型和TCP/IP四层网络模型对应关系 计算机网路基础的知识不过多讲解,主要是让大家明白接下来的Linux网络编程数据流属于那一层,具体如下图 TCP/IP协议数据流示意图 我们接下来讲解的...Linux网络编程Tcp协议是属于传输层的协议 Linux Socket 网络编程 TCP协议 TCP是面向连接的可靠的传输层协议。...TCP编程 Linux中的网络编程是通过socket接口来进行的。socket是一种特殊的I/O接口,它也是一种文件描述符。常用于不同机器上的进程之间的通信,当然也可以实现本地机器上的进程之间通信。...*address//协议族地址 ,socklen_t address_len); //协议族长度 - address: 协议族地址,通用的socket地址 通用的socket地址不是很好用,所以Linux
一台机器上可能会有大量的进程,但并不是所有的进程都要进行网络通信,可能有很大一部分的进程是不需要进行网络通信的本地进程,此时PID虽然也可以标识这些网络进程的唯一性,但在该场景下就不太合适了。...也就是说,在不同的场景下可能需要不同的编号来标识某种事物的唯一性,因为这些编号更适合用于该场景,其实这也就是解耦。 系统底层如何通过port找到对应进程的?...TCP协议和UDP协议 这里简单介绍一下这两份协议,后续我会更新两篇文章重点介绍他们的使用方法和报头部分的信息的意义和作用。...为什么网络字节序采用的是大端?而不是小端? 网络字节序采用的是大端,而主机字节序一般采用的是小端,那为什么网络字节序不采用小端呢?...socket编程接口 socket常见接口: 创建套接字:(TCP/UDP,客户端+服务器) int socket(int domain, int type, int protocol); 绑定端口号
先要学习网络知识才谈得上编程 讲述计算机网络的最经典的当属Andrew S.Tanenbaum的《计算机网络》第五版,这本书难易适中。...详解的作者还写了另外2本经典著作,《Unix环境高级编程》,《Unix网络编程》二卷本。...说明:搞Linux网络编程的,想学TCP/IP的一定要看大师W.Richard Stevens这六本书,基本上六本书看完基础也就搭好了。 ? ? ? ? ? ?...本书称不上非常的通俗,但是在有一定的基础的情况下还是比较容易看懂的。本书是世面上极少见的讲述内部网关路由技术的经典书籍,内容极为丰富。...网络体系结构:linux内核中网络协议的设计与实现》 ?
上篇文章我们实现了英译汉的网络字典,客服端向服务端发送英文,服务端接收数据后回调处理,将翻译后的中文再转发给客户端,这其实和EchoSever一样都是一对一的网络通信。...UdpServer.hpp——服务端通信 这里我们服务端需要修改一下,我们现在接收客户端发来的消息后,并不是要将该消息处理好之后再次转发回原来的客户端,而是需要回调进行路由转发,将消息转发给所有在线用户...UdpServer.cc——服务端主程序 这里我们要实例化出一个路由转发的类,由它提供路由转发的服务 #include #include "UdpServer.hpp" #include...因此,在多线程环境下,推荐使用 inet_ntop。...目标缓冲区,用于存储转换后的字符串 size:目标缓冲区的大小 返回值 成功:指向 dst 的指针 失败:NULL,设置 errno 所以我们下面可以将 InetAddr 类中的网络字节序转换为点分十进制字符串格式的函数修改一下
网络通信部分 首先我们网络通信不需要改变,只需要稍微修改添加一些新的变量,服务端在接收客户端发来的数据,然后回调去处理翻译这个动作,所以我们可以使用包装器function来包装一个函数指针,用于回调处理翻译...Udpserver.cc 服务端主程序已经有网络通信的功能了,我们现在只需要实例化字典对象,先加载字典到哈希表中,再在网络通信时进行翻译 代码如下: #include #include...Enable_Console_Log_Strategy(); // 字典对象提供翻译功能 Dict dict; dict.LoadDict(); // 网络服务器对象提供网络通信功能...buffer[m] = 0; std::cout << buffer << std::endl; } } return 0; } 运行测试一下:...}); 那么包装器也需要增加一个参数 using func_t = std::function; 再来测试一下
创建一个能用的SOCKET是非常简单的,因为GLIBC已经为你做了很多简化工作,但是从另一个角度来说,一个通用的SOCKET不代表一个高效性能的网络应用。...都是LINUX下的一个打开的设备描述符。内核通过这个描述符进行I/O操作。进行I/O操作就有一个性能问题,这个性能问题在于两个条件,一个条件是对同一个FD,有多个客户进行操作时如何更好的排队。...但是LINUX比较搞,它是上层用SELECT,实际上底层还是用的POLL....在LINUX下实际上POLL性能比SELECT要高一点,POLL也是监视FD集合,不过将这个FD集合单独使用一个数据结构pollfd. struct pollfd { int...这种模式下内核会一直触发,直到事件被用户消费掉。也就是说在这种情况下FD上的数据一定被写完或者读完才不会有下一次的触发事件。
1、网络字节序和主机字节序 网络字节序是TCP/IP中规定好的一种数据表示格式,它与具体的CPU类型、操作系统等无关,从而可以保证数据在不同主机之间传输时能够被正确解释。...网络字节序采用big endian排序方式。 不同的CPU有不同的字节序类型,这些字节序是指 整数 在内存中保存的顺序,这个叫做主机字节序,有大端小端两种。...unsigned long s_addr; }; 3、inet_addr和inet_ntoa 函数inet_addr(),将IP地址从字符串转换成无符号长整型,注意,inet_addr()返回的地址已经是网络字节格式...在这种情况下,listen syscall的backlog参数表示完成队列的大小 8、accept()函数 accept()函数实际做的是在已完成连接队列列头返回下一个已完成连接,服务器三路握手在listen
概念了解 scp 是 secure copy 的缩写 scp 是 linux 系统下基于 ssh 登录进行安全的远程文件拷贝命令 scp 是加密的,rcp 是不加密的,scp 是 rcp 的加强版...简易写法 scp [可选参数] file_source file_target 详细规则,请参考 【 文档 —— Linux scp命令】 ②....实例操作 操作分为两类:a.从本地复制到远程、b.从远程复制到本地 此处,以“将远程服务器的目录拷贝到本服务器的自定义目录” 操作为例: scp -r -P 56886 fetowsweb1@118.190.117.44...52zhenmi.com/wx/ 目标服务器存储目录 如下,即为实际传输效果视频 如果条件允许,可在同一内网下进行数据传输,只需将目标服务器id写成类似 10.112.21.12,可对比一下传输效果