基础概念

Socket套接字,本质是网络编程接口、提供网络通信的能力,实现不同虚拟机或不同计算机之间的通信。面向客户/服务(C/S)模型,socket是应用层和传输层之间的中间软件抽象层:

  • 顶上三层处理具体网络应用的所有细节、但对通信细节了解很少,底下四层对具体网络应用了解不多、但处理所有的通信细节(发送数据、等待确认、计算并校正校验等);
  • 顶上三层通常构成所谓的用户进程,底下四层通常提供作为操作系统内核的一部分,用户进程操作的是应用层,内核操作的是传输层及传输层一下的协议;

在网络中进程通信无处不在,socket通信的前提是唯一表示网络中的一个进程:

  • 本地进程唯一表示:ProcessID
  • 网络进程唯一表示:IP地址+协议+端口号(三元组)
    • IP地址(IP层):唯一表示主机;
    • 协议和端口号(TCP层):唯一表示主机中的一个进程;

网络通信连接至少要一对socket,socket之间的通信过程可以分为三个步骤:

  • 服务器监听;
  • 客户端请求;
  • 连接确认;

“一切皆Socket”(Socket起源于Unix,Unix/Linux基本哲学之一就是“一切皆文件”),Socket是"打开—读/写—关闭"模式的实现。

Socket是对TCP/IP协议的封装,Socket本身并不是协议,而是一个调用接口(API),通过Socket、我们才能使用TCP/IP协议。

  • TCP:传输层协议、基于网络层的IP协议,解决数据如何在网络中传输;
  • HTTP:应用层协议、基于传输层的TCP协议,解决如何包装数据;

HTTP是轿车,提供封装或显示数据的具体形式;Socket是发动机,提供网络通信的能力。

在Socket编程中,经常会遇到同步、异步、阻塞和非阻塞,具体概念参见:谈I/O模型 - sqh

参考

TCP编程

TCP编程流程图如下(三次握手 + 四次挥手

服务端

(1)编程步骤

  • 创建一个监听Socket,绑定到一个IP地址和一个端口;
  • 新建一个监听线程,(通过一个无限循环)开始监听等待连接请求;
  • 监听到并接受连接请求,再创建一个该连接上的新的接收Socket;
  • 为该连接新建一个工作线程,接收Socket(通过一个无限循环)与客户端Socket进行通信;
  • 返回,监听等待其他的客户端连接请求;
  • 关闭Socket;

(2)池管理

  • Buffer池:集中管控Socket缓冲区,防止内存碎片
  • SAEA池:集中管控Socket,重复利用Socket
  • Thread池:集中管控和调度工作线程
  • SQL池:分离网络服务层与数据访问层(SQL的执行效率远:低于网络层执行效率)

(3)同步Socket使用场景:同步Socket+Thread

  • 客户端数量比较少(<50);
  • 客户端数量较多但都是短连接:客户端的连接在处理完一次收发之后就断开;

客户端

(1)编程步骤

  • 创建Socket;
  • 向服务器发出连接请求;
  • 和服务器端进行通信;
  • 关闭Socket;

UDP编程

服务端

  • 创建socket;
  • 将socket绑定到一个本地地址和端口上;
  • 等待接收数据;
  • 关闭socket;

客户端

  • 创建socket;
  • 向服务器发送数据;
  • 关闭socket;

HTTP编程


Socket编程应用

Socket初识的更多相关文章

  1. python ---socket初识

    python网络编程(初识) 一些概念 套接字: 套接字(socket)也叫通信端点,最初用于计算机内部进程之间的通信,而随着网络的发展,套接字被用于计算机之间的通信.举个例子,你(是一台计算机)要打 ...

  2. Python自动化之socket初识

    1. os.popen() os.system(cmd)会直接输出命令的结果到屏幕上,返回一个状态码0或1. os.popen(cmd)会返回一个<open file 'dir', mode ' ...

  3. python学习之路网络编程篇(第一篇)socket初识

    什么是socket 网络上的两个程序通过一个双向的通信连接实现数据的交换,这个连接的一端称为socket.socket通常也称为“套接字”,是一个通信链的句柄,可以用来实现不同虚拟机或不同计算机之间的 ...

  4. Socket 初识 用Socket建立一个简易Web服务器

    摘自<Asp.Net 本质论>作者:郝冠军 //在.Net中.system.Net命名空间提供了网络编程的大多数数据据类型以及常用操作,其中常用的类型如下: /* IPAddress 类表 ...

  5. Socket初识2

    一.Socket一些概念 sk = socket.socket(socket.AF_INET,socket.SOCK_STREAM,0) 1.1 参数1:Socket Families(地址簇) / ...

  6. TCP/IP,HTTP,Socket初识

    在大学时候学过网络通信这一块,奈何已经还给老师,苍天饶过谁,该拾起来看看学学的还是要学,先简单了解了下这方面的知识,后续会继续通过看书来充实这方面的知识. 手机能够联网是手机底层实现了TCP/IP协议 ...

  7. python学习之路---day25( 网络编程基础和初识socket)

    基本网络知识和初识socket一:基本知识 网线:传输电信号 集线器:将所有连接到集线器的网络设备连通起来 交换机: 升级版的集线器 网卡:接受电信号 MAC地址:物理地址: 8C-88-4B-88- ...

  8. socket编程相关阐述

    一.socket初识 ①服务端 import socket server = socket.socket() server.bind(('127.0.0.1', 8080)) server.liste ...

  9. 老男孩Python全栈第2期+课件笔记【高清完整92天整套视频教程】

    点击了解更多Python课程>>> 老男孩Python全栈第2期+课件笔记[高清完整92天整套视频教程] 课程目录 ├─day01-python 全栈开发-基础篇 │ 01 pyth ...

随机推荐

  1. SQL Server2016升级前几点自检

    SQL Server2016已经出来一段时间了,而且最新的SP1包也于2016年11月18日正式发布,各种新的特性推出让我们跃跃欲试.那么对于我们真实的业务环境,特别是生产环境要不要"跟风& ...

  2. 似懂非懂的localStorage和sessionStorage

    一.区别 相信很多人都见过这两个关于HTML5的新名词!HTML5种的web storage包含两种存储方式:localStorage和sessionStorage,这两种方式存储的数据不会自动发给服 ...

  3. 编译器开发系列--Ocelot语言5.表达式的有效性检查

    本篇将对"1=3""&5"这样无法求值的不正确的表达式进行检查. 将检查如下这些问题.●为无法赋值的表达式赋值(例:1 = 2 + 2)●使用非法的函数 ...

  4. mac好用的markdown编辑器

    在刚开始接触markdown的时候,就被吸引了.此后一直在找贴心的好用的markdown编辑器.印象笔记和马克飞象配合着用也是挺好的,唯一的缺点就是比较封闭,发个笔记的链接给同学,还得注册才能看,导致 ...

  5. Microsoft Visual Studio 2017 for Mac Preview 下载+安装+案例Demo

    目录: 0. 前言 1. 在线安装器 2. 安装VS 3. HelloWorld 4. ASP.NET MVC 5. 软件下载 6. 结尾 0. 前言: 工作原因,上下班背着我的雷神,一个月瘦了10斤 ...

  6. 【一起学OpenFoam】01 OpenFoam的优势

    CFD技术发展到今天,已经超过了大半个世纪了,已经涌现出非常多的CFD软件可供人们使用.通用商业CFD软件譬如Fluent.CFX.Star CCM+等在工业上得到了广泛的应用,另外一些专用的软件(如 ...

  7. 将MPM雪模拟移植到Maya

    同事实现了一个迪士尼的MPM雪模拟论文,我将其移植到Maya中 论文题目是 A material point method for snow simulation 代码在这里: https://git ...

  8. AOP之Castle DynamicProxy 动态代理

    这里主要介绍使用castle这个动态代理,在.net一些开源的框架里可以找到它的影子,就连微软的rchard也是使用这个进行方法拦截等可以基于这个进行方法拦截,在这个方面PostSharp算是比较好用 ...

  9. 使用Hystrix提高系统可用性

    今天稍微复杂点的互联网应用,服务端基本都是分布式的,大量的服务支撑起整个系统,服务之间也难免有大量的依赖关系,依赖都是通过网络连接起来. (图片来源:https://github.com/Netfli ...

  10. .net正则表达式大全(.net 的 System.Text.RegularExpressions.Regex.Match()方法使用)

    正则表达式的本质是使用一系列特殊字符模式,来表示某一类字符串.正则表达式无疑是处理文本最有力的工具,而.NET的System.dll类库提供的System.Text.RegularExpression ...