一、解决粘包问题
1.1、tcp的特点
面向字节流特点,会造成可能数据与数据发送到一块,成为粘包,数据之间不区分
1.2、拆包
因为缓冲区的大小,一次性发送的数据会进行拆分(大小不符合的时候)
就和水一样一次拆一次沾到一块,不好对数据进行拆分
字节流就是像水一样,一个接着一个往过流,字节流,紧挨着,
多次发的东西一次性接受
在底层下面,socket 会在发送数据会等一下,时间到了就一次性发送
1.3、解决粘包问题
原因:
tcp 流式套接字
数据与数据之间没有边界
导致
可能多次的数据粘到一起
解决:
1、规定一些数据与数据之间的 间隔符
eg、”\aa"\r\n"
2、可以指定要发送的数据的长度
3、自己将数据打包
eg、
struct msg
{
int size;
char data[100]
}
相当于自己把自己打成一个包,和其他人不是一个,没有办法融合
2、加延时,让先把东西发过去,间隔一下,相当于就是跑出去了,被拉了一下,两人错开了
1.4、程序过程中遇到的问题
因为是文件IO,标准IO的问题,读写问题,因为fgets,先去底层取数据,我们把东西拿走了,而等文件IO,去取数据的时候东西已经没有了。
signal(SIGCHLD,handler);
char buf1[1024] = "3.c";
write(fd,buf1,strlen(buf1)+1);
//sleep(1);
int file = open(buf1,O_RDONLY);
write(fd,"\r\n",2);
解决办法
在网络里面有专门的读写操作
fgets()后面的参数需要一个流指针,后面是一个流指针,遇到\n结束,并且将\n读到
这样我们就可以将文件描述符,转换成字符流指针,通过fgets来获取这些信息,再设置一个标志符,来进行区分所发送的信息。
send()发数据
ssize_t send(int sockfd, const void *buf, size_t len, int flags);
recv()
ssize_t recv(int sockfd, void *buf, size_t len, int flags);
flag是指可以指定在网络中接收的方式
前面三个参数和read参数一致
二、常用网络测试工具
ifconfig //查看主机上,网卡网络信息
ping //测试 两台主机之间是否连通
telnet //远程登录工具
ssh //硬件(开发板)
netstat //查看当前主机上,活动的网络进程的相关的状态信息
arp //(ipc找mac)
2.1、# ubuntu开启telnet服务
sudo apt-get install openbsd-inetd
sudo apt-get install telnetd
sudo /etc/init.d/openbsd-inetd restart
注意:
安装之前,确保ubuntu能上网
ping www.baidu.com
# 查看 telnet服务是否开启
sudo netstat -a | grep telnet
开启telnet结果图
2.2、ssh安装
-
- /ssh登录 ubuntu 需要安装以下的服务
sudo apt-get install openssh-server openssh-client
- /ssh登录 ubuntu 需要安装以下的服务
2.3、 抓包安装
- sudo apt install wireshark
- sudo wireshark(启动)
2.4、wireshark过滤使用
过滤规则:
- 1、根据ip地址过滤
- ip.srC = x.X.X.X
- ip.dst =- x.x.x.x
- 根据端口过滤:tcp.srcportXX;二
- tcp.dstportXX;二三
- udp.srcportZ-XX;
- udp.dstportXX:
- 根据协议类型过滤:
- tcp udp icmptelnet
- 任意组合以上条件抓包:
- 如果与的关系:and
- ip.src == 192.168.1.100 and tcp.dstport == 9999
- 如果或关系:Or
- ip.src == 192.168.1.100 or ip.dst == 192.168.1.102
- tcp host 192.168.1.100
2.5、netstat 测试查看网络端口使用情况
- //正在活动的 常看tcp的//用的最多的
- netstat -anp
- -a //a] ]
- 直接显示 ip port 的数字形式-n ll
- -p //显示 进程的 程序名 和 pid
- netstat-n =-->列出当前所有网络端口使用情况
- -tnetstat-n =-->列出所有TCP通信的端口信息
- netstat-n-U =-->列出所有UDP通信的端口信息
- netstat -n -i =-->列出默认网络接口(网卡)上的通信信息
- netstat -lnp | grep 8888 i===>查看指定端口上的通信详情