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套接字)