day26网络编程

1.1.1ThreadLocal

#很类似于类中的调用私有方法

全局变量local_school就是一个ThreadLocal对象,每个Thread对它都可以读写student属性,但互不影响。你可以把local_school看成全局变量,但每个属性如local_school.student都是线程的局部变量,可以任意读写而互不干扰,也不用管理锁的问题,ThreadLocal内部会处理。


1.1.2异步

1.1.3     GIL

在python的原始解释器CPython中存在着GIL(Global Interpreter Lock,全局解释器锁),因此在解释执行python代码时,会产生互斥锁来限制线程对共享资源的访问,直到解释器遇到I/O操作或者操作次数达到一定数目时才会释放GIL。所以,虽然CPython的线程库直接封装了系统的原生线程,但CPython整体作为一个进程,同一时间只会有一个获得GIL的线程在跑,其他线程则处于等待状态。这就造成了即使在多核CPU中,多线程也只是做着分时切换而已。 不过muiltprocessing的出现,已经可以让多进程的python代码编写简化到了类似多线程的程度了。

推荐网站:

http://developer.51cto.com/art/200910/156804.htm

解决GIL:

1、能用进程不用线程。

2、高效的代码使用c,c++来编写

说明:

        单核的cup一个死循环线程或者进程,会占满这个cpu

        双核的cpu两个死循环线程,占据两个cpu都在50%左右,并不会占满,这样降低了运行效率。

        双核的cpu两个死循环进程,占满两个cpu的100%一个进程一个cpu,线程在进程里面,进程里面    可以有多个线程。


网络编程

UDP

·使用网络能够把多方链接在一起,然后可以进行数据传递

·所谓的网络编程就是,让在不同的电脑上的软件能够进行数据传递,即进程之间的通信

UDP可以随时发送,没有接收者也可以发送。

1、tcp/ip简介

作为新时代标杆的我们,已经离不开手机、离不开网络,对于互联网大家可能耳熟能详,但是计算机网络的出现比互联网要早很多

2、TCP/IP协议(族)

早期的计算机网络,都是由各厂商自己规定一套协议,IBM、Apple和Microsoft都有各自的网络协议,互不兼容

为了把全世界的所有不同类型的计算机都连接起来,就必须规定一套全球通用的协议,为了实现互联网这个目标,互联网协议簇(Internet Protocol Suite)就是通用协议标准。

因为互联网协议包含了上百种协议标准,但是最重要的两个协议是TCP和IP协议,所以,大家把互联网的协议简称TCP/IP协议

说明:

网际层也称为:网络层

网络接口层也称为:链路层

3、端口

如果一个进程需要收发网络数据,那么就需要有这样的端口

在linux系统中,端口可以有65536(2的16次方)个之多!

4、端口号

端口是通过端口号来标记的,端口号只有整数,范围是从0到65535

端口号不是随意使用的,而是按照一定的规定进行分配。

5、知名端口(Well Known Ports)

知名端口是众所周知的端口号,范围从0到1023,  系统已经占用的端口号

eg:

80端口分配给HTTP服务

21端口分配给FTP服务

6、动态端口(Dynamic Ports)

动态端口的范围是          从1024到65535

之所以称为动态端口,是因为它一般不固定分配某种服务,而是动态分配。

动态分配是指当一个系统进程或应用程序进程需要网络通信时,它向主机申请一个端口,主机从可用的端口号中分配一个供它使用。

当这个进程关闭时,同时也就释放了所占用的端口号。

7、怎样查看端口 ?

用“netstat-ano” “ps -aux”查看端口状态

8、小总结

端口有什么用呢 ? 我们知道,一台拥有IP地址的主机可以提供许多服务,比如HTTP(万维网服务)、FTP(文件传输)、SMTP(电子邮件)等,这些服务完全可以通过1个IP地址来实现。那么,主机是怎样区分不同的网络服务呢?显然不能只靠IP地址,因为IP地址与网络服务的关系是一对多的关系。实际上是通过“IP地址+端口号”来区分不同的服务的。 需要注意的是,端口并不是一一对应的。比如你的电脑作为客户机访问一台WWW服务器时,WWW服务器使用“80”端口与你的电脑通信,但你的电脑则可能使用“3457”这样的端口。

9、ip地址

1.什么是地址

ip地址:用来在网络中标记一台电脑的一串数字,比如192.168.1.1;在本地局域网上是唯一的。

2.ip地址的分类

每一个IP地址包括两部分:网络地址和主机地址

1.1.1socket简介  (套接字)

1、网络中进程之间如何通信

首要解决的问题是如何唯一标识一个进程,否则通信无从谈起!

在本地可以通过进程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套接字)

udp既可以当做发送,又可以当做接受,还可以设置端口号,由发送者设置。    

格式:对象.bind(assress,端口号)

你可能感兴趣的:(day26网络编程)