Socket初识
基础概念
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编程应用
- C# - 网络编程 之 Socket; C# - 网络编程 之 TcpClient与TcpListener;
- Java - 网络编程 之 ;
Socket初识的更多相关文章
- python ---socket初识
python网络编程(初识) 一些概念 套接字: 套接字(socket)也叫通信端点,最初用于计算机内部进程之间的通信,而随着网络的发展,套接字被用于计算机之间的通信.举个例子,你(是一台计算机)要打 ...
- Python自动化之socket初识
1. os.popen() os.system(cmd)会直接输出命令的结果到屏幕上,返回一个状态码0或1. os.popen(cmd)会返回一个<open file 'dir', mode ' ...
- python学习之路网络编程篇(第一篇)socket初识
什么是socket 网络上的两个程序通过一个双向的通信连接实现数据的交换,这个连接的一端称为socket.socket通常也称为“套接字”,是一个通信链的句柄,可以用来实现不同虚拟机或不同计算机之间的 ...
- Socket 初识 用Socket建立一个简易Web服务器
摘自<Asp.Net 本质论>作者:郝冠军 //在.Net中.system.Net命名空间提供了网络编程的大多数数据据类型以及常用操作,其中常用的类型如下: /* IPAddress 类表 ...
- Socket初识2
一.Socket一些概念 sk = socket.socket(socket.AF_INET,socket.SOCK_STREAM,0) 1.1 参数1:Socket Families(地址簇) / ...
- TCP/IP,HTTP,Socket初识
在大学时候学过网络通信这一块,奈何已经还给老师,苍天饶过谁,该拾起来看看学学的还是要学,先简单了解了下这方面的知识,后续会继续通过看书来充实这方面的知识. 手机能够联网是手机底层实现了TCP/IP协议 ...
- python学习之路---day25( 网络编程基础和初识socket)
基本网络知识和初识socket一:基本知识 网线:传输电信号 集线器:将所有连接到集线器的网络设备连通起来 交换机: 升级版的集线器 网卡:接受电信号 MAC地址:物理地址: 8C-88-4B-88- ...
- socket编程相关阐述
一.socket初识 ①服务端 import socket server = socket.socket() server.bind(('127.0.0.1', 8080)) server.liste ...
- 老男孩Python全栈第2期+课件笔记【高清完整92天整套视频教程】
点击了解更多Python课程>>> 老男孩Python全栈第2期+课件笔记[高清完整92天整套视频教程] 课程目录 ├─day01-python 全栈开发-基础篇 │ 01 pyth ...
随机推荐
- Drawable实战解析:Android XML shape 标签使用详解(apk瘦身,减少内存好帮手)
Android XML shape 标签使用详解 一个android开发者肯定懂得使用 xml 定义一个 Drawable,比如定义一个 rect 或者 circle 作为一个 View 的背景. ...
- 企业做数据缓存是使用Memcached还是选Redis?
企业是使用Memcached还是选Redis? 在构建一款现代且由数据库驱动的Web应用程序并希望使其拥有更为出色的性能表现时,这个问题总会时不时出现.并给每一位开发人员带来困扰.在考虑对应用程序的性 ...
- A/B Testing的简要知识
A/B testing主要用来检测网站或者APP的两个版本中哪一个更好,它的中心思想是把流量一分为二,一份用作experiment group,访问新的版本,另一份用作control group,访问 ...
- Zookeeper常用命令
http://www.cnblogs.com/chengxin1982/p/3997706.html
- ucos实时操作系统学习笔记——任务间通信(队列)
ucos操作系统中的queue机制同样使用了event机制来实现,其实和前面的sem,mutex实现类似,所不同的是对sem而言,任务想获得信号量,对mutex而言,任务想获得的是互斥锁.任务间通信的 ...
- Microsoft Azure Web Sites应用与实践【4】—— Microsoft Azure网站的“后门”
Microsoft Azure Web Sites应用与实践 系列: [1]—— 打造你的第一个Microsoft Azure Website [2]—— 通过本地IIS 远程管理Microsoft ...
- 写自己的Socket框架(三)
在通信写完了以后,应用层接收到Socket抛上来的byte[],这个时候对于实际的写逻辑的开发者来说,这样的数据并不友好,我们就需要在应用层统一一个包的规则(应用层协议),处理完以后,然后再传给实际的 ...
- Hadoop2.2.0安装过程记录
1 安装环境1.1 客户端1.2 服务端1.3 安装准备 2 操作系统安装2.1.1 BIOS打开虚拟化支持2.1.2 关闭防火墙2.1.3 安装 ...
- 《Entity Framework 6 Recipes》中文翻译系列 目录篇 -持续更新
为了方便大家的阅读和学习,也是响应网友的建议,在这里为这个系列做一个目录.在目录开始这前,我先来回答之前遇到的几个问题. 1.为什么要学习EF? 这个问题很简单,项目需要.这不像学校,没人强迫你学习! ...
- jquery库和cityselect插 件的省市 级联
/*$(function(){ $("#select_provice").citySelect({ prov:"北京", nodata:"none&q ...