OSI七层模型与TCP四层模型

OSI七层模型与TCP四层模型

BS和CS服务器架构

(1)CS架构介绍(client server,客户端服务器架构)
(2)BS架构介绍(broswer server,浏览器服务器架构)

TCP协议

(1)建立连接需要三次握手
(2)建立连接的条件:服务器listen时客户端主动发起connect
(3)关闭连接需要四次握手
(4)服务器或者客户端都可以主动发起关闭

注:这些握手协议已经封装在TCP协议内部,socket编程接口平时不用管

TCP如何保证可靠传输
(1)TCP在传输有效信息前要求通信双方必须先握手,建立连接才能通信
(2)TCP的接收方收到数据包后会ack给发送方,若发送方未收到ack会丢包重传
(3)TCP的有效数据内容会附带校验,以防止内容在传递过程中损坏
(4)TCP会根据网络带宽来自动调节适配速率滑动窗口技术
(5)发送方会给各分割报文编号,接收方会校验编号,一旦顺序错误即会重传。

基于socket编程

1、建立连接
(1)socket。socket函数类似于open,用来打开一个网络连接,如果成功则返回一个网络文件描述符(int类型),之后我们操作这个网络连接都通过这个网络文件描述符。
(2)bind
(3)listen
(4)connect
2、发送和接收
(1)send和write
(2)recv和read
3、辅助性函数
(1)inet_aton、inet_addr、inet_ntoa
(2)inet_ntop、inet_pton
4、表示IP地址相关数据结构
(1)都定义在 netinet/in.h
(2)struct sockaddr,这个结构体是网络编程接口中用来表示一个IP地址的,注意这个IP地址是不区分IPv4和IPv6的(或者说是兼容IPv4和IPv6的)
(3)typedef uint32_t in_addr_t; 网络内部用来表示IP地址的类型
(4)

struct in_addr
{
in_addr_t s_addr;
};
()struct sockaddr_in
{
__SOCKADDR_COMMON (sin_);
in_port_t sin_port; /* Port number. */
struct in_addr sin_addr; /* Internet address. */ /* Pad to size of `struct sockaddr'. */
unsigned char sin_zero[sizeof (struct sockaddr) -
__SOCKADDR_COMMON_SIZE -
sizeof (in_port_t) -
sizeof (struct in_addr)];
};

(6)struct sockaddr 这个结构体是linux的网络编程接口中用来表示IP地址的标准结构体,bind、connect等函数中都需要这个结构体,这个结构体是兼容IPV4和IPV6的。在实际编程中这个结构体会被一个struct sockaddr_in或者一个struct sockaddr_in6所填充。

客户端流程

服务器流程

htons函数为将主机序转为网络序
网络字节顺序NBO(Network Byte Order): 按从高到低的顺序存储,在网络上使用统一的网络字节顺序,可以避免兼容性问题。(大端模式) 主机字节顺序(HBO,Host Byte Order): 不同的机器HBO不相同,与CPU设计有关,数据的顺序是由cpu决定的,而与操作系统无关。

客户端与服务器代码

#include <stdio.h>
#include <sys/socket.h>
#include <sys/types.h> /* See NOTES */
#include <arpa/inet.h>
#include <string.h> #define SERVER_IP "192.168.149.137"
#define SERVER_PORT 5005
#define BACKLOG 100
#define DEBUF(X) printf(X) typedef struct commu
{
char name[];
int age;
}info; int main()
{
int sock_fd = -;//socket 描述符
int server_fd = -;//连接描述符
struct sockaddr_in server_addr;
struct sockaddr_in client_addr;//客户地址
socklen_t len = ;//接收长度
int ret = -;
char send_buf[];
char recv_buf[];
//1,打开socket
sock_fd = socket(AF_INET,SOCK_STREAM,);
if(- == sock_fd)
{
perror("socket");
return -;
}
printf("sock_fd = %d.\n",sock_fd);
//2、connect 连接服务器
server_addr.sin_family = AF_INET;//IPV4
server_addr.sin_port = htons(SERVER_PORT);//设置端口模式
server_addr.sin_addr.s_addr = inet_addr(SERVER_IP);//设置IP
ret = connect(sock_fd,(struct sockaddr *)&server_addr,sizeof(server_addr));
if(- == ret)
{
perror("connect");
return -;
}
DEBUF("成功简历连接\n");
info st1;
while()
{
printf("请输入学生姓名\n");
scanf("%s",st1.name);
printf("请输入学生年龄\n");
scanf("%d",&st1.age);
//1.发送
ret = send(sock_fd,&st1,sizeof(info),);
memset(send_buf,,strlen(send_buf));
printf("发送了一个学生信息\n");
//2.等待回复
recv(sock_fd,recv_buf,sizeof(recv_buf),);
printf("%s\n",recv_buf);
memset(recv_buf,,sizeof(recv_buf));
//3.信息处理
}
return ;
}
//服务器
#include <stdio.h>
#include <sys/socket.h>
#include <sys/types.h> /* See NOTES */
#include <arpa/inet.h>
#include <string.h>
#define MY_IP "192.168.149.137"
#define MY_PORT 5005
#define BACKLOG 100
#define DEBUF(X) printf(X) typedef struct commu
{
char name[];
int age;
int cmd;
}info; int main()
{
int sock_fd = -;//监听描述符
int client_fd = -;//连接fd
struct sockaddr_in server_addr;
struct sockaddr_in client_addr;//客户地址
socklen_t len = ;//接收长度
int ret = -;
char recv_buf[];
char send_buf[];
//1,打开socket
sock_fd = socket(AF_INET,SOCK_STREAM,);
if(- == sock_fd)
{
perror("socket");
return -;
}
printf("sock_fd = %d.\n",sock_fd);
//2.bind绑定socket 和本机IP 端口
server_addr.sin_family = AF_INET;//IPV4
server_addr.sin_port = htons(MY_PORT);//设置端口模式
server_addr.sin_addr.s_addr = inet_addr(MY_IP);//设置IP
ret = bind(sock_fd,(struct sockaddr *)&server_addr,sizeof(server_addr));
if(- == ret)
{
perror("bind");
return -;
}
DEBUF("bind ok\n");
//3.listen 设 置监听端口
ret = listen(sock_fd, BACKLOG);//BACKLOG为排队处理
if(- == ret)
{
perror("listen");
return -;
}
DEBUF("listen ok\n");
//4.阻塞等待连接
client_fd = accept(sock_fd, (struct sockaddr *)&client_addr, &len);
if(- == client_fd)
{
perror("listen");
return -;
}
DEBUF("成功简历连接\n");
//简历完成后可以通信
memset(recv_buf,,sizeof(recv_buf));
info st1;
while()
{
//1、 服务器收
recv(client_fd,&st1,sizeof(st1),);
printf("学生名字为:%s\n",st1.name);
printf("学生年龄为:%d\n",st1.age);
memset(recv_buf,,sizeof(recv_buf));
//2、 服务器处理数据
//3、 回复客户端
send(client_fd,"OK",,);
}
return ;
}

linux网络编程框架的更多相关文章

  1. Linux网络编程&内核学习

    c语言: 基础篇 1.<写给大家看的C语言书(第2版)> 原书名: Absolute Beginner's Guide to C (2nd Edition) 原出版社: Sams 作者: ...

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

    1.前言 我从事Linux系统下网络开发将近4年了,经常还是遇到一些问题,只是知其然而不知其所以然,有时候和其他人交流,搞得非常尴尬.如今计算机都是多核了,网络编程框架也逐步丰富多了,我所知道的有多进 ...

  3. Java网络编程和NIO详解9:基于NIO的网络编程框架Netty

    Java网络编程和NIO详解9:基于NIO的网络编程框架Netty 转自https://sylvanassun.github.io/2017/11/30/2017-11-30-netty_introd ...

  4. Linux 网络编程的5种IO模型:多路复用(select/poll/epoll)

    Linux 网络编程的5种IO模型:多路复用(select/poll/epoll) 背景 我们在上一讲 Linux 网络编程的5种IO模型:阻塞IO与非阻塞IO中,对于其中的 阻塞/非阻塞IO 进行了 ...

  5. 【深入浅出Linux网络编程】 "开篇 -- 知其然,知其所以然"

    [深入浅出Linux网络编程]是一个连载博客,内容源于本人的工作经验,旨在给读者提供靠谱高效的学习途径,不必在零散的互联网资源中浪费精力,快速的掌握Linux网络编程. 连载包含4篇,会陆续编写发出, ...

  6. 【linux草鞋应用编程系列】_5_ Linux网络编程

    一.网络通信简介   第一部分内容,暂时没法描述,内容实在太多,待后续专门的系列文章.   二.linux网络通信     在linux中继承了Unix下“一切皆文件”的思想, 在linux中要实现网 ...

  7. Linux 网络编程(IO模型)

    针对linux 操作系统的5类IO模型,阻塞式.非阻塞式.多路复用.信号驱动和异步IO进行整理,参考<linux网络编程>及相关网络资料. 阻塞模式 在socket编程(如下图)中调用如下 ...

  8. linux网络编程 no route to host 解决方案

    linux网络编程 no route to host 解决方案 [整合资料] (2013-05-13 21:38:12) 转载▼ 标签: net iptables it 分类: Linux 参考资料h ...

  9. linux网络编程-(socket套接字编程UDP传输)

    今天我们来介绍一下在linux网络环境下使用socket套接字实现两个进程下文件的上传,下载,和退出操作! 在socket套接字编程中,我们当然可以基于TCP的传输协议来进行传输,但是在文件的传输中, ...

随机推荐

  1. 福州大学软工1816 K 班助教总结

    春节时期总有各种诱惑因素(例如路人超能第二季),拖到现在才发布十分抱歉orz. 一.感谢 首先对柯老师和软工助教指导团队这一学期以来的支持和指导表示感谢.第一次做助教,有时候会提出一些不大成熟的想法, ...

  2. 团队作业8——测试与发布(Beta阶段)之展示博客

    展示博客 1. 团队成员的简介和个人博客地址,团队的源码仓库地址. a.陈福鹏 擅长技术:java.web等网站方面技术: 博客:http://www.cnblogs.com/royalchen/b. ...

  3. Head First Java & final

  4. 11th 单元测试工具JUnit的学习

    1.写好一个简易的四则运算的程序 UnitTest类文件: public class UnitTest { int a; int b; int answer;//正确答案 public int plu ...

  5. 简单 dp

    1.摆花问题 题目描述小明的花店新开张,为了吸引顾客,他想在花店的门口摆上一排花,共m盆.通过调查顾客的喜好,小明列出了顾客最喜欢的n种花,从1到n标号.为了在门口展出更多种花,规定第i种花不能超过a ...

  6. koa中接收前台传递的各种数据类型的方式

    标签(空格分隔): koa 数据类型接收 主要介绍三种会用到的中间件,其实都是自己在开发的过程中踩过的坑 首先介绍koa-body [详情介绍 https://github.com/dlau/koa- ...

  7. 通过cmd命令安装、卸载、启动和停止Windows Service(InstallUtil.exe)

    步骤: 1.运行--〉cmd:打开cmd命令框 2.在命令行里定位到InstallUtil.exe所在的位置 InstallUtil.exe 默认的安装位置是在C:/Windows/Microsoft ...

  8. 一个Flume 异常(Put queue for MemoryTransaction of capacity 100 full)的排查和解决思路

    最近在做一个分布式调用链跟踪系统, 在两个地方采用了flume (我使用的flume版本是1.5.0-cdh5.4.4),一个是宿主系统 ,用flume agent进行日志搜集. 一个是从kafka拉 ...

  9. day1 学习历程

    day1 我是一个在校大三学生,一个依然迷茫不知前景的大学混子= =,可以这么说吧 大学混子 真正开始决定好好学习大概在去年的12月份 那时经老师的提醒 开始正式接触软件开发 于是 从头开始学习语言 ...

  10. 队列java实现

    队列是一种线性数据结构,是一种运算受限的线性表,只允许在队尾插入,在队头删除.运算规则是先进先出.恰好和栈相反.栈是先进后出.因为栈只在栈顶做删除和插入. 队列按照存储结构可以分为顺序队列和链式队列. ...