单进程-单线程-非阻塞-长链接;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语句

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

关系型数据库产品

大型: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

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,384评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,845评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,148评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,640评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,731评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,712评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,703评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,473评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,915评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,227评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,384评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,063评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,706评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,302评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,531评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,321评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,248评论 2 352

推荐阅读更多精彩内容