多进程
#导入进程包
import multiprocessing
# 创建进程对象
multiprocessing.Process(start=任务名)
group:指定进程组,目前只能使用None
target:执行的目标任务名
name:进程名字
args:以元组方式给执行任务传参
kwargs:以字典方式给执行任务传参
# Process创建的实例对象的常用方法
start():启动子进程
join():等待子进程执行结束
terminate():不管任务是否完成,立即终止子进程
# 设置守护主进程方式:
子进程对象.daemon = True
获取进程编码
import os
# 获取当前进程编号
os.getpid()
# 获取父进程编号
os.getppid()
多线程
# 导入线程模块
import threading
# 创建线程对象
threading.Thread(target=任务名)
group:线程组,目前只能使用None
target:执行的目标任务名
args:医院组的方式给执行任务传参
kwargs:以字典的方式给执行任务传参
name:线程名,一般不用设置
# Thread创建的实例对象常用的方法
start():启动线程
join():等待子线程任务执行结束
# 设置守护主线程有两种方式:
threading.Thread(target=任务名, daemon=True)
线程对象.setDaemon(True)
互斥锁
# 创建锁
mutex = threading.Lock()
# 上锁
mutex.acquire()
...这里编写代码能保证同一时刻只能有一个线程去操作, 对共享数据进行锁定...
# 释放锁
mutex.release()
TCP客户端开发
步骤说明:
- 创建客户端套接字对象 ( socket() )
- 和服务端套接字建立连接 ( connect() )
- 发送数据 ( send() )
- 接收数据 ( recv() )
- 关闭客户端套接字 ( close() )
TCP服务端开发
开发 TCP 服务端程序开发步骤回顾
- 创建服务端端套接字对象 ( socket() )
- 绑定端口号 ( bin() )
- 设置监听 ( listen() )
- 等待接受客户端的连接请求 ( accept() )
- 接收数据 ( recv() )
- 发送数据 ( send() )
- 关闭套接字 ( close() )
# 设置端口号复用TCP服务端端口号立即释放,否则需要等三次握手之后才能释放
severs_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, True)
# reuse 使用 addr:地址
HTTP请求报文
HTTP最常见的请求报文有两种:
- GET 方式的请求报文
- POST 方式的请求报文
说明:
- GET: 获取web服务器数据
- POST: 向web服务器提交数据
GET 请求报文说明:
---- 请求行 ----
GET / HTTP/1.1 # GET请求方式 请求资源路径 HTTP协议版本
---- 请求头 -----
Host: www.itcast.cn # 服务器的主机地址和端口号,默认是80
Connection: keep-alive # 和服务端保持长连接
Upgrade-Insecure-Requests: 1 # 让浏览器升级不安全请求,使用https请求
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36 # 用户代理,也就是客户端的名称
Accept:text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8 # 可接受的数据类型
Accept-Encoding: gzip, deflate # 可接受的压缩格式
Accept-Language: zh-CN,zh;q=0.9 #可接受的语言
Cookie: pgv_pvi=1246921728; # 登录用户的身份标识
---- 空行 ----
POST 请求报文说明:
---- 请求行 ----
POST /xmweb?host=mail.itcast.cn&_t=1542884567319 HTTP/1.1 # POST请求方式 请求资源路径 HTTP协议版本
---- 请求头 ----
Host: mail.itcast.cn # 服务器的主机地址和端口号,默认是80
Connection: keep-alive # 和服务端保持长连接
Content-Type: application/x-www-form-urlencoded # 告诉服务端请求的数据类型
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36 # 客户端的名称
---- 空行 ----
---- 请求体 ----
username=hello&pass=hello # 请求参数
HTTP响应报文
响应报文说明:
--- 响应行/状态行 ---
HTTP/1.1 200 OK # HTTP协议版本 状态码 状态描述
--- 响应头 ---
Server: Tengine # 服务器名称
Content-Type: text/html; charset=UTF-8 # 内容类型
Transfer-Encoding: chunked # 发送给客户端内容不确定内容长度,发送结束的标记是0\r\n, Content-Length表示服务端确定发送给客户端的内容大小,但是二者只能用其一。
Connection: keep-alive # 和客户端保持长连接
Date: Fri, 23 Nov 2018 02:01:05 GMT # 服务端的响应时间
--- 空行 ---
--- 响应体 ---
<!DOCTYPE html><html lang=“en”> …</html> # 响应给客户端的数据
HTTP请求方法
HTTP GET 方式请求报文
请求行 GET+资源地址+HTTP协议版本
请求头 \r\n
空行\r\n
HTTP POST 方式请求报文
请求行 GET+资源地址+HTTP协议版本
请求头 \r\n
空行\r\n
请求体 form data (可以没有请求体)
HTTP响应报文
响应行 协议版本+状态码+状态描述\r\n
响应头 服务器名称\r\n
空行\r\n
响应体 响应给客户端的数据\r\n
响应状态码
1xx 提示请求已被成功接收,继续处理
2xx 成功 表示请求已被成功接收
3xx 重定向 要完成请求必须进行更进一步的处理
4xx 客户端错误 请求有语法错误或请求无法实现
5xx 服务端错误 服务器未能实现合法请求z