你心中最高大上最牛逼的技术到底是什么大声告诉我
借用一句话,
西北玄天一片云,乌鸦落进凤凰群
满网都是英雄汉,谁是君来谁是臣
下面就是要告诉你所谓的牛逼技术到底是什么回事!!!
我们测试一下数据库,java,python,go,c/c++,php,redis,docker进行测试【测完你会发现点东西】
然后你再看图比较好,免得大家天天为了这个框架,那个框架,这个语言,哪个语言在b乎,快手,抖音,b站吵的跟少妇一样[只是吐槽一下]
^_^
- 先测试数据库接收数据时是不是用了Linux网络 socket API
好启动了,没有什么可说的,ELF文件启动。
.ibd是创建数据表时生成的文件,没啥可说的,DBA专业都知道
我画线的地方调用了ACCEPT SOCKET API函数
调用了SENDTO,RECVFROM SOCKET API 函数
调用了系统其它API函数库,我们看一下accept,sendto,recvfrom,setsockopt,getsockopt read,write,epoll相关函数
- redis 数据库
启动redis
测试
**epoll_wait 得到就绪的文件描述符读事件返回,然后调用read,其实跟RECVFROM功能一样
它的数据是:3\r\n$3\r\nset\r\n4\r\nbfzs\r\n5\r\n10000\r\n
这一堆数据被各种大佬称为 redis的二进制通信请求协议!!!返回是+OK\r\n**
它们的数据来回传输大部分用read,write函数来实现
- docker
dockerd服务ELF文件调用的linux api相关函数库
启动docker服务,跟mysql一样默认启动一堆进程和线程
相关命令运行【对不起,我不喜欢背东西,你要是面试我时,问我docker有哪些命令选项,对不起我回家种地放牛了】
来用下测试
运行过程
都在调用connect,socket,getpeerame,setsockopt,getsockopt,accept,sendto等LINUX SOCKET API函数
docker调用的LINUX API 函数库
- go语言写个网络程序
我直接复制粘粘给你运行对不起我背不了函数,要用就直接复制粘粘就好了
go ELF 文件
来运行那个大家认为的源码文件
先运行哪个函数,你自己看着办哦
重点
熟悉的一批,socket 创建socket文件描述符,然后命名【把ip,端口绑定到此文件上】,然后监听,并阻塞在accept函数上
好了,go就这样子,它封装的比较骚,go elf编译器封装的牛逼,语法换了一套就称为编译型语言了。
- python语言也写个网络程序测试下
py的语法就是好,随便一撸就可以了,简直是粗暴又骚,语法嘛就这样,长得跟少妇一样
来先认识一下python elf文件 毕竟好多爬虫大佬可能没有见过
.php .py .go .java里的东西只是个文本内容,你们嘛叫源码,我没有文化,只能叫ascii text ^_^
启动测试
有没有发现,熟悉的一批
好了,到这里够意思了。
这么简单的语言,你去学语法就行了,简单又粗暴谁不喜欢呢。我都喜欢。 ^_^
- java 语言网络程序测试
看一下java elf文件,我相信java大佬肯定知道我就不费话了
编译一下
我没有学过java,但是看一下报错就知道了,对不对,这么明显的提示,我phper都晓得 ^_^
编译ok
编译好是啥文件
启动java程序开始测试
有没有发现,熟悉的一批
好了,就这么多就行了,没有必要再截图了。
看接下,我们撸c[c++一样]
你们应该看出点熟悉的地方了 int main(int argc,char *argv[]) { if(argc=0); ret = bind(listenfd,(struct sockaddr*)&address,sizeof(address)); assert(ret!=-1); ret = listen(listenfd,5); assert(ret!=-1); bzero(&address,sizeof(address)); address.sin_family = AF_INET; inet_pton(AF_INET,ip,&address.sin_addr); address.sin_port = htons(port); int udpfd = socket(PF_INET,SOCK_DGRAM,0); assert(udpfd>=0); ret = bind(udpfd,(struct sockaddr*)&address,sizeof(address)); assert(ret!=-1); struct epoll_event events[MAX_EVENT_NUMBER]; int epollfd = epoll_create(5); assert(epollfd!=-1); addfd(epollfd,listenfd); addfd(epollfd,udpfd); while(1){ int number = epoll_wait(epollfd,events,MAX_EVENT_NUMBER,-1); if(number<0){ printf("epoll failre\n"); break; } for(int i=0;i0){ sendto(udpfd,buf,UDP_BUFFER_SIZE-1,0,(struct sockaddr*)&client_address,client_addrlength); } } else if(events[i].events & EPOLLIN){ char buf[TCP_BUFFER_SIZE]; while(1){ memset(buf,0,TCP_BUFFER_SIZE); ret = recv(sockfd,buf,TCP_BUFFER_SIZE-1,0); if(ret<0){ if((errno==EAGAIN)||(errno=EWOULDBLOCK)){ break; } close(sockfd); break; } else if(ret==0){ close(sockfd); } else{ send(sockfd,buf,ret,0); } } }else{ printf("something else happened\n"); } } } close(listenfd); return 0; }
然后编译,编译好就这样
测试
好了,都不用我废话了,接下来还是测试下php吧,我觉得,虽然有的朋友觉得php咋样咋样,拍黄片嘛,在打黄打非的压力之下当然没啥好名声了。不过我就是色批,就是撸php了怎么了嘛。
- php 网络程序测试
看下php elf文件
启动并测试跟踪
好了,不用我废话,大家也知道是怎么回事了。
这些api函数怎么用呢?
man socket
下面是堆废话【慎看^_^】
如果你是个注重核心技术的朋友,可以关注我的资料 https://edu.51cto.com/sd/75a3d ,同时愿你成为大佬!
因为你学哪门语言都一样。如果你觉得你想又简单又能快速的进入到socket api编程那么此资料就非常适合你。
linux socket api 是所有语言,数据库等应用的核心低层技术知识,你框架掌握的再6,没有多少意义,语言掌握得再6也只是工具,你要掌握的是数据来回传输靠的TCP/IP协议,而这些协议的相关API 就是LINUX SOCKET API,做为一名码农我觉得你有必要学这套!!!没有这套SOCKET API 或是你没有掌握,那只能受制于人!天天为表面的语法,框架,语言争吵。
分布式,集群,高大上的技术都要TCP/IP支持,而它的实现就是网络编程,各语言写法不同,但是核心基础知识没有变化,正所谓天下大事必作于细天下难事必作于易,一上来撸c/c++,java如果不合适你,那么上来就撸PHP掌握了共通的知识再换语言又何妨呢?
有疑问加站长微信联系(非本文作者)