mysql epoll_单进程-单线程-非阻塞-长链接;epoll实现http服务器;epoll的原理,MySQL(数据库)基础知识;关系型数据库yu非关系型数据库;连接认证;...

单进程-单线程-非阻塞-长链接

import socket

import re

def service_client(new_socket):

# '''为这个客户端返回数据'''

# 1.接收浏览器发送出来的请求,即HTTP请求

# GET/HTTP/1.1

#

request_lines = request.splotlines()

print ('')

print ('>>>' *30)

print (request_lines)

ret = re.match(r'[^/]+(/[^ ]*)', request_lines[0])#正则提取

file_name =''

if ret:

file_name = ret.group(1)

print ('*' *50, file_name)# !!!!!!!!网页名字

if file_name ='/index.html'

# 2.返回HTTP格式的数据给浏览器

try:

f =open('.../Desktop/项目/项目.html', 'rb')

# f = open('.../Desktop/项目/项目.html' +file_name,'rb')

except:

response ='HTTP/1.1 404 NOT FOUND\r\n'

response +='\r\n'

response +='--FILE NOT FOUND---'

new_socket.send(response.encode('utf-8'))

else:

html_content = f.read()

f.close()

# 2.1 准备发送给浏览器的Header

response_header ='HTTP/1.1 200 OK\r\n'

response_header +='\r\n'

response_header ='Content-Length : %d\r\n'%len(response_body)

response_header +='\r\n'

response = response_header.encode('utf-8')+ response_body

#将 Response发送给浏览器

new_socket.send(response)

def main():

""" 用来完成整提的控制"""

# 1.创建套接字

tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

tcp_server_socket.setsockopt(socket.SOCK_STREAM, socket.SO_REUSEADDR,1)

# 2.绑定

tcp_server_socket.bind(('', 7890))

# 3.变为监听套接字(最大链接书128)

tcp_server_socket.listen(128)

while True:

# 4.等待新客户端的链接

try:

new_socket, client_addr = tcp_server_socket.accept()

# 局部变量

except Exception as ret:

pass

else:

new_socket.setblocking(False)

client_socket_list.append(new_socket)

for client_socketin client_socket_list:

try:

recv_data = client_socket.recv(1024).dacode('utf-8')

except Exception as ret:

pass

else:

if recv_data:

# 5.为这个客户端服务

service_client(client_socket,recv_data)

else:

client_socket.close()

client_socket_list.remove(client_socket)

# 6.关闭监听套接字

tcp_server_socket.close()

if __name__ =='__main__':

main()

epoll实现http服务器

import socket

import re

import select

def service_client(new_socket):

# '''为这个客户端返回数据'''

# 1.接收浏览器发送出来的请求,即HTTP请求

# GET/HTTP/1.1

#

request_lines = request.splotlines()

print ('')

print ('>>>' *30)

print (request_lines)

ret = re.match(r'[^/]+(/[^ ]*)', request_lines[0])#正则提取

file_name =''

if ret:

file_name = ret.group(1)

print ('*' *50, file_name)# !!!!!!!!网页名字

if file_name ='/index.html'

# 2.返回HTTP格式的数据给浏览器

try:

f =open('.../Desktop/项目/项目.html', 'rb')

# f = open('.../Desktop/项目/项目.html' +file_name,'rb')

except:

response ='HTTP/1.1 404 NOT FOUND\r\n'

response +='\r\n'

response +='--FILE NOT FOUND---'

new_socket.send(response.encode('utf-8'))

else:

html_content = f.read()

f.close()

# 2.1 准备发送给浏览器的Header

response_header ='HTTP/1.1 200 OK\r\n'

response_header +='\r\n'

response_header ='Content-Length : %d\r\n'%len(response_body)

response_header +='\r\n'

response = response_header.encode('utf-8')+ response_body

#将 Response发送给浏览器

new_socket.send(response)

def main():

""" 用来完成整提的控制"""

# 1.创建套接字

tcp_server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

tcp_server_socket.setsockopt(socket.SOCK_STREAM, socket.SO_REUSEADDR,1)

# 2.绑定

tcp_server_socket.bind(('', 7890))

# 3.变为监听套接字(最大链接书128)

tcp_server_socket.listen(128)

tcp_server_socket.setblocking(False)#将套接字变为非阻塞

#创建一个epoll对象

epl = select.epoll()

#将监听套接字对应的FD注册到epoll中

epl.register(tcp_server_socket.fileno(),select.EPOLLIN)

client_socket_list =list()

while True:

fd_event_list = epl.poll()#默认会阻塞,直到os检测到数据到来,

# 通过事件通知的方式告诉程序,此时才会解阻塞

# [(fd ,event),(...)]

#参数fd:套接字对应的文件描述符

#参数event:这个fd是什么事件,例如可以调用recv 接收等

for fd,eventin fd_event_list:

# 4.等待新客户端的链接

if fd == tcp_server_socket.fileno():

new_socket,client_addr = tcp_server_socket.accept()

epl.register(new_socket.fileno(),select.EPOLLIN)

elif event == select.EPOLLIN:

#判断已经连接的客户端是否有数据发送过来

recv_data = client_socket.recv(1024).decode('utf-8')

if recv_data:

#为这个客户端服务

service_client(fd_event_dict[fd],recv_data)

else:

fd_event_list[fd].close()

epl.unregister(fd)

del fd_event_dict[fd]

# 6.关闭监听套接字

tcp_server_socket.close()

if __name__ =='__main__':

main()

epoll的原理

使用了内存映射技术 mmap

epoll采用基于事件的就绪通知方式

什么是数据库?

数据库(Database):存储数据的仓库

高效地存储和处理数据的介质(介质主要是两种:磁盘和内存)

数据库系统:DBS(Database System):是一种虚拟系统,将多种内容关联起来的称呼

DBS = DBMS + DB

DBMS:Database Management System,数据库管理系统,专门管理数据库

DBA:Database Administrator,数据库管理员

行/记录:row/record

列/字段:column/field

数据库的分类

基于存储介质的不同:分为关系型数据库(SQL)和非关系型数据库(NoSQL:Not Only SQL)

关系型数据库yu非关系型数据库

什么是关系型数据库?

是一种建立在关系模型(数学模型)上的数据库

关系模型:一种所谓建立在关系上的模型

关系模型包含三个方面:

数据结构:用于解决数据存储的问题,二维表(有行和列)

操作指令集合:所有SQL语句

完整性约束:表内数据约束(字段与字段)、表与表之间约束(外键)

c6838ca92ff5

关系型数据库产品

大型:Oracle、DB2

中型:SQL Server(window的操作系统)、MySQL

小型:Access、SQLite等

非关系型数据库产品:Memcached(运行在内存)、MongoDB(内存)、Redis(磁盘)

关系型数据库yu非关系型数据库区别:

关系型数据库:安全(保存磁盘,基本不可能丢失),容易理解,比较浪费空间(二维表)

非关系型数据库:效率高,不安全(断电丢失)

操作指令集合

SQL:(Structured Query Language,结构化查询语言)

SQL分为三个部分:

DDL:(Data Definition Language,数据定义语言)用来维护存储数据的结构(数据库、表),代表指令:create(创建,增加(数据库,表,函数,等))、drop

(删除)、alter(修改)等

DML:(Data Manipulation Language,数据操作语言)用来对数据进行操作(数据表中的内容),代表指令:insert、delete、update等。其中DML内部又单独进行了一个分类:DQL(Data Query Language,数据查询语言(最主要的操作))如select

DCL:(Data Control Language,数据控制语言)主要是负责权限管理(用户),代表指令:grant(分配权限)、revoke(回收权限)等

连接认证

客户端与服务端的交互方式

1、客户端连接认证:连接服务器、认证身份(mysql.exe -hPup)-h--找到主机地址  -P端口(默认3306)-u指定的登录用户名  -p回车输入密码

2、客户端发送SQL指令

3、服务器接收SQL指令,并处理SQL指令,返回操作结果

4、客户端接收结果,并显示结果

5、断开连接  exit(退出)或quit 或 \q--弹出Bye

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值