首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

linux网络编程之socket(一):socket概述和字节序、地址转换函数

UNIX Domain Socket的地址格式定义在sys/un.h,用sockaddr_un结构体表示。...各种socket地址结构体的开头都是相同的,对于unix 的某些实现来说 前8位表示整个结构体的长度,后8位表示地址类型,而Linux就没有长度字段,前2个字节都是地址类型。...这样,只要取得某种sockaddr 结构体的首地址,不需要知道具体是哪种类型的sockaddr 结构体,就可以根据地址类型字段确定结构体 的内容。...三、地址转换函数 前面提到的 sockaddr_in 结构体的成员struct in_addr sin_addr表示32位的IP地址。...原始套接字(SOCK_RAW) 参考: 《Linux C 编程一站式学习》 《TCP/IP详解 卷一》

1.9K00

Linux系统下socket编程socket接口介绍(二)

前言 在上一篇文章里面我们介绍了TCP的三次握手和四次挥手过程的介绍以及网络编程里面的一些api接口函数的介绍——Linux系统下socket编程之socket接口介绍(一)。...(如192.168.1.10)为二进制数值,并存储在struct in_addr结构,即第二个参数*inp,函数返回非0表示cp主机有地有效,返回0表示主机地址无效。...(这个转换完后不能用于网络传输,还需要调用htons或htonl函数才能将主机字节顺序转化为网络字节顺序,这两个函数先不讲,实战遇到的话,再进行解析),具体可以看下面Linux的源文: inet_aton...(2)inet_ntop、inet_pton,这两个函数是随IPv6出现的函数,对于IPv4地址和IPv6地址都适用,函数p和n分别代表表达(presentation)和数(numeric)。...在实际编程这个结构体会被一个struct sockaddr_in或者一个struct sockaddr_in6所填充。

3.5K20

Linux网络编程“惊群”问题总结

1、前言   我从事Linux系统下网络开发将近4年了,经常还是遇到一些问题,只是知其然而不知其所以然,有时候和其他人交流,搞得非常尴尬。...今天和大家一起讨论一下网络开发遇到的“惊群”现象。之前只是听说过这个现象,网上查资料也了解了基本概念,在实际的工作还真没有遇到过。今天周末,结合自己的理解和网上的资料,彻底将“惊群”弄明白。...所以,如果服务器采用accept阻塞调用方式,在最新的Linux系统上,已经没有“惊群”的问题了。...在早期的Linux版本,内核对于阻塞在epoll_wait的进程,也是采用全部唤醒的机制,所以存在和accept相似的“惊群”问题。...新版本的的解决方案也是只会唤醒等待队列上的第一个进程或线程,所以,新版本Linux 部分的解决了epoll的“惊群”问题。

98560

Linux】关于Linux的权限

Linux的文件类型和后缀无关(后缀名可以作为提示,用户可以使用后缀区分文件类型),但是对linux来说区分文件和文件本身的后缀是无关的(但是gcc等工具对文件后缀可能有要求)。...开始之前,我们输入ll指令,来看看前面10个字符代表什么意思: 在linux,是通过ll显示的众多属性列的第一列的第一个字符来区分文件类型的。...则无法用ls等命令查看目录的文件内容....可写权限: 如果目录没有可写权限, 则无法在目录创建文件, 也无法在目录删除文件 所以这也是为什么系统规定目录的起始权限从777开始,所有的目录被创建出来,一般都要能够被进入 换句话来讲, 就是只要用户具有目录的写权限..., 用户就可以删除目录的文件, 而不论这个用户是否有这个文件的写权限。

7.2K20

linux网络编程之socket(七):一个进程发起多个连接和gethostbyname等函数

一、在前面讲过的最简单的回射客户/服务器程序,一个客户端即一个进程,只会发起一个连接,只要稍微修改一下就可以让一个客户端发起多个连接,然后只利用其中一个连接发送数据。...先运行服务器程序,再运行客户端,输出如下: simba@ubuntu:~/Documents/code/linux_programming/UNP/socket$ ....解决的办法很简单,只要在handler函数while 循环一下就ok 了,即使5个信号同时到达,只要接收到一个SIGCHLD信号,则5个子进程都会被清理掉,如下所示: signal(SIGCHLD,...类型的指针,再通过  inet_ntoa 函数转换成点分十进制的字符串,即 此语句 inet_ntoa(*(struct in_addr *)hp->h_addr_list[i]);  的意思。...参考: 《Linux C 编程一站式学习》 《TCP/IP详解 卷一》 《UNP》

1.6K00

【网络编程】Linux网络编程基础与实战第二弹——Socket编程

Socket编程 套接字概念 Socket本身有“插座”的意思,在Linux环境下,用于表示进程间网络通信的特殊文件类型。本质为内核借助缓冲区形成的伪文件。...与管道类似的,Linux系统将其封装成文件的目的是为了统一接口,使得读写套接字和读写文件的操作一致。 区别是管道主要应用于本地进程间通信,而套接字多应用于网络进程间数据的传递。...在TCP/IP协议,“IP地址+TCP或UDP端口号”唯一标识网络通讯的一个进程。“IP地址+端口号”就对应一个socket。...网络编程接口 首先先看一下网络套接字的函数以及具体实现流程图: 网络字节序 内存的多字节数据相对于内存地址有大端和小端之分,磁盘文件的多字节数据相对于文件的偏移地址也有大端小端之分。.../in.h 文件

23420

socket inet_pton

inet_pton   Linux下这2个IP地址转换函数,可以在将IP地址在“点分十进制”和“整数”之间转换   而且,inet_pton和inet_ntop这2个函数能够处理ipv4和ipv6。...arpa/inet.h>   int inet_pton(int af, const char *src, void *dst);   这个函数转换字符串到网络地址,第一个参数af是地址族,转换后存在dst...inet_addr的扩展,支持的多地址族有下列:   af = AF_INET   src为指向字符型的地址,即ASCII的地址的首地址(ddd.ddd.ddd.ddd格式的),函数将该地址   转换为in_addr...的结构体,并复制在*dst   af =AF_INET6   src为指向IPV6的地址,,函数将该地址   转换为in6_addr的结构体,并复制在*dst   如果函数出错将返回一个负值,并将errno...socket.h>   #include   int main (void)   {   char IPdotdec[20]; //存放点分十进制IP地址   struct in_addr

2.4K80

linux udp编程_linuxsocket编程

在前面的文件,我们介绍了linux网络编程与IP相关的知识和常用的函数总结,本文针对具体的UDP通信,来详细的介绍UDP通信的使用,包括UDP通信中的点对点通信,多播,广播等。...2、在上面的通信框架,客户端并没有使用bind的操作,确实如此,因为客户端一般作为通信的发起者,都是主动往外发送数据,如1的描述,这个过程由系统聪明的帮我们记录的端口信息,当服务端有数据回复的时候,...3、关于服务端的bind操作,在存在组播,多播等多种通信方式的情况下,也还有一些需要注意的点,这个我们在下面的章节描述 二、UDP通信的基本函数说明 在UDP,完成一个基本的通信涉及到的几个函数如下...IP信息,addr_size存放addr数据的长度,但是,在实际使用,这样调用后,我们打印addr的信息,确实一个错误的IP信息或者0.0.0.0这样的地址信息,这是什么原因呢,在那个男人的的描述...但是我们在实际的使用,通常只是某些主机对通信数据感兴趣,而不是整个局域网上的所有主机都需要这个数据,这种情况就需要组播登场了。 3.1、组播的IP地址 组播的地址是特定的,D类地址用于多播。

11K10

Linuxlinux 搭建 FTP 服务

service vsftpd restart # 关闭ftp服务 service vsftpd stop ---- 配置FTP服务 多数的VSFTPD配置项都在/etc/vsftpd.conf配置文件。...这个文件本身已经有非常良好的文档说明了,因此,在本节,我只强调一些你可能进行修改的重要选项。...使用man页面查看所有可用的选项和基本的 文档说明: man vsftpd.conf 根据文件系统层级标准,FTP共享文件默认位于/srv/ftp目录。...write_enable=YES 允许本地(系统)用户登录: 为了允许文件/etc/passwd记录的用户可以登录ftp服务,“local_enable”标记必须设置为YES。...在配置文件增加/修改下面配置开启根目录限制(Chroot Jail): chroot_list_enable=YES chroot_list_file=/etc/vsftpd.chroot_list

13.3K20

Linux的段

Linux的段 Intel 微处理器的段机制是从8086 开始提出的, 那时引入的段机制解决了从CPU 内部 16 位地址到20 位实地址的转换。...这不仅简化了Linux 内核的设计,而且为把Linux 移植到其他平台创造了 条件,因为很多RISC 处理器并不支持段机制。但是,对段机制相关知识的了解是进入Linux 内核的必经之路。...但内核也用到LDT,那只是在VM86 模式运行Wine 时, 即在Linux 上模拟运行Windows 软件或DOS 软件的程序时才使用。...linux的GDT Linux 在启动的过程设置了段寄存器的值和全局描述符表GDT 的内容,段的定义在include/asm-i386/segment.h : #define __KERNEL_CS...而在保护模式下时,由于段基址已经存入了段描述符,所以段寄存器再存放段基址是没有意义的,在段寄 存器存入的是一个叫作选择子的东西– selector。

4.5K20

理解LinuxLoad

负载均值在 uptime 或者 top 命令可以看到,它们可能会显示成这个样子:load average: 0.09, 0.05, 0.01 很多人会这样理解负载均值:三个数分别代表不同时间段的系统平均负载...如果你的服务器负载超过了 5.00 这个数字,那么你将失去你的睡眠,还得在会议说明这情况发生的原因,总之千万不要让它发生。 那么多个处理器呢?...那么在单车道 1.00 情况,说明这桥梁已经被车塞满了。而在双处理器系统,这意味着多出了一倍的 负载,也就是说还有 50% 的剩余系统资源 - 因为还有另外条车道可以通行。...这使我们有了两个新的法则: 1) 有多少核心即为有多少负荷法则:在多核处理,你的系统均值不应该高于处理器核心的总数量。...2) 核心的核心法则:核心分布在分别几个单个物理处理并不重要,其实两颗四核的处理器等于四个双核处理器等于八个单处理器。所以,它应该有八个处理器内核。

1.9K90

Linux】进程信号(

在上一个文章,关于信号的产生,还有没补充完的,所以在这篇文章补充一下 1.信号的产生 硬件异常产生信号 a/=0问题 创建mysignal.cc文件 #include using...当代码除0时,程序运行后就崩溃了,程序运行变为进程,进程运行代码时出现了非法代码,进程退出了 ---- 将内存的指令数据load到CPU 状态寄存器中有比特位表示当前计算的状态 CPU中有的寄存器保存未来的计算结果...2是 p作为nullptr,*p取的是内存的0号地址 *p=100,相当于向0号地址处写入100,但是0号地址并没有申请过, 所以就造成了野指针问题 ---- 运行可执行程序后,发生段错误 --...容我慢慢来说 ---- Linux在系统级别提供了一种能力,可以将一个进程异常的时候, 操作系统可以将该进程在异常的时候,核心代码部分进行核心转储 (将内存中进程的相关数据,全部dump到磁盘) 一般会在当前进程的运行目录下...1运行可执行程序,在终端2发送8号信号干掉进程,并出现core dump即核心转储 ---- 再次使用 ls -l 指令,发现多出来一个 core.2257的文件 即核心转储文件 ---- Term

17730
领券