一、网络简介
网络是由节点和连线构成,表示诸多对象及其相互联系。
一个人玩:
两个人玩:
多个人玩:
说明
- 网络就是一种辅助双方或者多方能够连接在一起的工具
- 如果没有网络可想
单机
的世界是多么的孤单
使用网络的目的
- 就是为了联通多方然后进行通信用的,即把数据从一方传递给另外一方
- 前面的学习编写的程序都是单机的,即不能和其他电脑上的程序进行通信
- 为了让在不同的电脑上运行的软件,之间能够互相传递数据,就需要借助网络的功能
- 所谓的网络编程就是,让在不同的电脑上的软件能够进行数据传递,即进程之间的通信
二、tcp/ip简介
1. 什么是协议
有的说英语,有的说中文,有的说德语,说同一种语言的人可以交流,不同的语言之间就不行了
为了解决不同种族人之间的语言沟通障碍,现规定国际通用语言是英语,这就是一个规定,这就是协议
2. 计算机网络沟通用什么
现在的生活中,不同的计算机只需要能够联网(有线无线都可以)那么就可以相互进行传递数据,那么不同种类之间的计算机到底是怎么进行数据传递的呢?就像说不同语言的人沟通一样,只要有一种大家都认可都遵守的协议即可,那么这个计算机都遵守的网络通信协议叫做TCP/IP协议
3. TCP/IP协议(族)
早期的计算机网络,都是由各厂商自己规定一套协议,IBM、Apple和Microsoft都有各自的网络协议,互不兼容
为了把全世界的所有不同类型的计算机都连接起来,就必须规定一套全球通用的协议,为了实现互联网这个目标,互联网协议簇(Internet Protocol Suite)就是通用协议标准。
因为互联网协议包含了上百种协议标准,但是最重要的两个协议是TCP和IP协议,所以,大家把互联网的协议简称TCP/IP协议
常用的网络协议如下图所示:
说明:
网际层也称为:网络层
网络接口层也称为:链路层
三、端口简介
那么TCP/IP协议中的端口指的是什么呢?端口就好一个房子的门,是出入这间房子的必经之路。
如果一个进程需要收发网络数据,那么就需要有这样的端口
在linux系统中,端口可以有65536(2的16次方)个之多!
既然有这么多,操作系统为了统一管理,所以进行了编号,这就是端口号
2. 端口号
端口是通过端口号来标记的,端口号只有整数,范围是从0到65535
3. 端口是怎样分配的
- 端口号不是随意使用的,而是按照一定的规定进行分配。
- 端口的分类标准有好几种,我们这里不做详细讲解,只介绍一下知名端口和动态端口
4.知名端口(Well Known Ports)
知名端口是众所周知的端口号,范围从0到1023
80端口分配给HTTP服务
21端口分配给FTP服务
可以理解为,一些常用的功能使用的号码好比:电话号码110、10086、10010一样
一般情况下,如果一个程序需要使用知名端口的需要有root权限
5.动态端口(Dynamic Ports)
- 动态端口的范围是从1024到65535
- 之所以称为动态端口,是因为它一般不固定分配某种服务,而是动态分配。
- 动态分配是指当一个系统进程或应用程序进程需要网络通信时,它向主机申请一个端口,主机从可用的端口号中分配一个供它使用。
- 当这个进程关闭时,同时也就释放了所占用的端口号。
- 用“netstat -an”查看端口状态
6、端口总结
端口有什么用呢 ? 我们知道,一台拥有IP地址的主机可以提供许多服务,比如HTTP(万维网服务)、FTP(文件传输)、SMTP(电子邮件)等,这些服务完全可以通过1个IP地址来实现。那么,主机是怎样区分不同的网络服务呢?显然不能只靠IP地址,因为IP地址与网络服务的关系是一对多的关系。实际上是通过“IP地址+端口号”来区分不同的服务的。 需要注意的是,端口并不是一一对应的。比如你的电脑作为客户机访问一台WWW服务器时,WWW服务器使用“80”端口与你的电脑通信,但你的电脑则可能使用“3457”这样的端口。
四、IP地址简介
IP地址就像是我们的家庭住址一样,如果你要写信给一个人,你就要知道他(她)的地址,这样邮递员才能把信送到。计算机发送信息就好比是邮递员,它必须知道唯一的“家庭地址”才能不至于把信送错人家。只不过我们的地址使用文字来表示的,计算机的地址用二进制数字表示。
IP地址是一个32位的二进制数,通常被分割为4个“8位二进制数”(也就是4个字节)。IP地址通常用“点分十进制”表示成(a.b.c.d)的形式,其中,a,b,c,d都是0~255之间的十进制整数。例:点分十进IP地址(100.4.5.6),实际上是32位二进制数(01100100.00000100.00000101.00000110)。
ip地址的分类
A类IP地址
- 一个A类IP地址由1字节的网络地址和3字节主机地址组成,网络地址的最高位必须是“0”,
- 地址范围1.0.0.1-126.255.255.254
- 二进制表示为:00000001 00000000 00000000 00000001 - 01111110 11111111 11111111 11111110
- 可用的A类网络有126个,每个网络能容纳1677214个主机
B类IP地址
- 一个B类IP地址由2个字节的网络地址和2个字节的主机地址组成,网络地址的最高位必须是“10”,
- 地址范围128.1.0.1-191.255.255.254
- 二进制表示为:10000000 00000001 00000000 00000001 - 10111111 11111111 11111111 11111110
- 可用的B类网络有16384个,每个网络能容纳65534主机
C类IP地址
- 一个C类IP地址由3字节的网络地址和1字节的主机地址组成,网络地址的最高位必须是“110”
- 范围192.0.1.1-223.255.255.254
- 二进制表示为: 11000000 00000000 00000001 00000001 - 11011111 11111111 11111110 11111110
- C类网络可达2097152个,每个网络能容纳254个主机
D类地址用于多点广播
- D类IP地址第一个字节以“1110”开始,它是一个专门保留的地址。
- 它并不指向特定的网络,目前这一类地址被用在多点广播(Multicast)中
- 多点广播地址用来一次寻址一组计算机
- 地址范围224.0.0.1-239.255.255.254
E类IP地址
- 以“1111”开始,为将来使用保留
- E类地址保留,仅作实验和开发用
私有ip
- 在这么多网络IP中,国际规定有一部分IP地址是用于我们的局域网使用,也就
- 是属于私网IP,不在公网中使用的,它们的范围是:
10.0.0.0~10.255.255.255
172.16.0.0~172.31.255.255
192.168.0.0~192.168.255.255
- IP地址127.0.0.1~127.255.255.255用于回路测试,
- 如:127.0.0.1可以代表本机IP地址,用
http://127.0.0.1
就可以测试本机中配置的Web服务器。
五、子网掩码简介
要想理解什么是子网掩码,就不能不了解IP地址的构成。互联网是由许多小型网络构成的,每个网络上都有许多主机,这样便构成了一个有层次的结构。IP地址在设计时就考虑到地址分配的层次特点,将每个IP地址都分割成网络号和主机号两部分,以便于IP地址的寻址操作。
IP地址的网络号和主机号各是多少位呢?
如果不指定,就不知道哪些位是网络号、哪些是主机号,这就需要通过子网掩码来实现。
子网掩码不能单独存在,它必须结合IP地址一起使用。
子网掩码只有一个作用,就是将某个IP地址划分成网络地址和主机地址两部分子网掩码的设定必须遵循一定的规则。
与IP地址相同,子网掩码的长度也是32位,
- 左边是网络位,用二进制数字“1”表示;
- 右边是主机位,用二进制数字“0”表示。
假设IP地址为“192.168.1.1”子网掩码为“255.255.255.0”,子网掩码装换二进制位:11111111 11111111 11111111 00000000
其中,“1”有24个,代表与此相对应的IP地址左边24位是网络号;
“0”有8个,代表与此相对应的IP地址右边8位是主机号。
这样,子网掩码就确定了一个IP地址的32位二进制数字中哪些是网络号、哪些是主机号。
这对于采用TCP/IP协议的网络来说非常重要,只有通过子网掩码,才能表明一台主机所在的子网与其他子网的关系,使网络正常工作。
最常用的子网掩码是“255.255.255.0”的网络:
- 最后面一个数字可以在0~255范围内任意变化,因此可以提供256个IP地址。
但是实际可用的IP地址数量是256-2,即254个,因为主机号不能全是“0”或全是“1”。
- 主机号全为0,表示网络号
- 主机号全为1,表示网络广播
六、socket简介
1.本地的进程间通信(IPC)有很多种方式,例如
- 队列
- 同步(互斥锁、条件变量等)
以上通信方式都是在一台机器上不同进程之间的通信方式,那么问题来了,网络中进程之间如何通信?
2. 网络中进程之间如何通信
- 首要解决的问题是如何唯一标识一个进程,否则通信无从谈起!
- 在本地可以通过进程PID来唯一标识一个进程,但是在网络中这是行不通的。
- 其实TCP/IP协议族已经帮我们解决了这个问题,网络层的“ip地址”可以唯一标识网络中的主机,而传输层的“协议+端口”可以唯一标识主机中的应用程序(进程)。
- 这样利用
ip地址,协议,端口
就可以标识网络的进程了,网络中的进程通信就可以利用这个标志与其它进程进行交互
3. 什么是socket
- socket(简称
套接字
) 是进程间通信的一种方式,它与其他进程间通信的一个主要不同是: - 它能实现不同主机间的进程间通信,我们网络上各种各样的服务大多都是基于 Socket 来完成通信的
- 例如我们每天浏览网页、QQ 聊天、收发 email 等等
4. 创建socket
在 Python 中 使用socket 模块的函数 socket 就可以完成:
socket.socket(AddressFamily, Type)
说明:
函数 socket.socket 创建一个 socket,返回该 socket 的描述符,该函数带有两个参数:
- Address Family:可以选择 AF_INET(用于 Internet 进程间通信) 或者 AF_UNIX(用于同一台机器进程间通信),实际工作中常用AF_INET
- Type:套接字类型,可以是 SOCK_STREAM(流式套接字,主要用于 TCP 协议)或者 SOCK_DGRAM(数据报套接字,主要用于 UDP 协议)
创建一个tcp socket(tcp套接字)
import sockets = socket.socket(socket.AF_INET, SOCK_STREAM)print 'Socket Created'
创建一个udp socket(udp套接字)
import sockets = socket.socket(socket.AF_INET, SOCK_DGRAM)print 'Socket Created'