https://0voice.com/uiwebsite/html/courses/v13.7.html
首先看看这个学习计划
- 网络、网络编程、网络原理
- 基础组件,20个。
- 中间件 Redis ,MySQL,Kafka,RPC,Nginx
- 开源框架(解决方案)业务开发(工程师开发,写代码)
- Docker/K8S,产品角度
- 开源代码,写的闭源的。
火焰图,bpf/ebpf - 分布式,分布式DB,分布式fs。etcd
- 项目能与公司业务场景(dkvsstore,图床)
samba配置可以看这个链接
#include<stdio.h>
#include<string.h>
#include<errno.h>
#include<unistd.h>
#include<sys/socket.h>
#include<netinet/in.h>
int main() {
//open
int sockfd = socket(AF_INET, SOCK_STREAM, 0);//io
struct sockaddr_in servaddr;
memset(&servaddr, 0, sizeof(struct sockaddr_in));//192.168.2.123
servaddr.sin_family = AF_INET;
servaddr.sin_addr.s_addr = htonl(INADDR_ANY);//0.0.0.0
servaddr.sin_port = htons(9999);
if (-1 == bind(sockfd, (struct sockaddr*)&servaddr, sizeof(struct sockaddr))) {
printf("bind failed:%s",strerror(errno));
return -1;
}
listen(sockfd, 10);
getchar();
}
然后我们运行:
gcc -o multi-io multi-io.c
./multi-io
然后他会阻塞住:
然后我们进入一个可视化工具也是可以看的。
这时候我们已经收到了数据,但是还没有处理。我们上面写的代码就好比一个酒店的服务员。他是可以进去的,但是没有处理。这时候我们要给这个客户端分配一个服务员。
#include<stdio.h>
#include<string.h>
#include<errno.h>
#include<unistd.h>
#include<sys/socket.h>
#include<netinet/in.h>
int main() {
//open
int sockfd = socket(AF_INET, SOCK_STREAM, 0);//io
struct sockaddr_in servaddr;
memset(&servaddr, 0, sizeof(struct sockaddr_in));//192.168.2.123
servaddr.sin_family = AF_INET;
servaddr.sin_addr.s_addr = htonl(INADDR_ANY);//0.0.0.0
servaddr.sin_port = htons(9999);
if (-1 == bind(sockfd, (struct sockaddr*)&servaddr, sizeof(struct sockaddr))) {
printf("bind failed:%s",strerror(errno));
return -1;
}
listen(sockfd, 10);
#if 1
struct sockaddr_in clientaddr;
socklen_t len = sizeof(clientaddr);
int clientfd = accept(sockfd, (struct sockaddr*)&clientaddr, &len);
#endif
getchar();//block
}
一开始的代码阻塞在getchar(),我们一敲回车他就会退出,但是现在代码阻塞在客户端接收这部分了。
然后这时候我们在这个工具中一点击链接他就退出了。也就是有客户端连接他就往下走了。
然后这就引出一个概念,阻塞型IO和非阻塞型IO,阻塞型IO就是等待连接,没有连接就是一直等待着,等待条件满足了之后才往下走。
下面是非阻塞IO:
#include<stdio.h>
#include<string.h>
#include<errno.h>
#include<unistd.h>
#include<sys/socket.h>
#include<netinet/in.h>
#include<fcntl.h>
int main() {
//open
int sockfd = socket(AF_INET, SOCK_STREAM, 0);//io
struct sockaddr_in servaddr;
memset(&servaddr, 0, sizeof(struct sockaddr_in));//192.168.2.123
servaddr.sin_family = AF_INET;
servaddr.sin_addr.s_addr = htonl(INADDR_ANY);//0.0.0.0
servaddr.sin_port = htons(9999);
if (-1 == bind(sockfd, (struct sockaddr*)&servaddr, sizeof(struct sockaddr))) {
printf("bind failed:%s",strerror(errno));
return -1;
}
listen(sockfd, 10);
sleep(10);
#if 1
int flags = fcntl(sockfd, F_GETFL, 0);
flags |= O_NONBLOCK;
fcntl(sockfd, F_SETFL, flags);
struct sockaddr_in clientaddr;
socklen_t len = sizeof(clientaddr);
int clientfd = accept(sockfd, (struct sockaddr*)&clientaddr, &len);
printf("clientfd:%d", clientfd);
#endif
getchar();//block
}