MySQL-CGI-响应报文

账号密码涉及到:

与数据库已记录下来的进行校验。

如果也是来一个新建一个连接,必然效率低。

可以做一个数据库连接池,预生成数据库连接。

如何生成数据库连接?下面的流程做很多次。

然后放在链表中,(池))维护三个变量 最大连接数 可用连接数 当前已用连接数 (要上锁)

1.使用mysql_init()初始化

2.使用real_connect()建立连接

3.使用query()查询

4.使用store_result(mysql)获取结果集

5.使用num_fields(result)获取查询的列 同理行

6.使用fetch_row不断获取下一行,循环输出

7.free可以释放

8.close可以关闭

CGI校验(通用网关接口):

输密码--POST--query()--同步线程校验

而CGI是一个服务器上的程序(.cgi)

项目中有个sign.cpp就是CGI程序

把用户名和密码保存在txt文件中--->

把数据库的用户名和密码存在map中用于校验-->

主程序有命令语句来执行CGI校验,不直接返回响应

HTTP响应报文

若目标文件存在、对所有用户可读且不是目录时,则使用mmap将其映射到内存地址m_file_address处,并告诉调用者获取文件成功FILE_REQUEST。

接下来要做的就是根据读取结果对用户做出响应了,也就是到了process_write(read_ret);这一步,该函数根据process_read()的返回结果来判断应该返回给用户什么响应,假设用户请求的文件存在,而且已经被mmap到m_file_address这里了,那么我们就将做如下写操作,将响应写到这个connfd的写缓存m_write_buf中去:

首先将状态行写入写缓存,响应头也是要写进connfd的写缓存(HTTP类自己定义的,与socket无关)中的,对于请求的文件,我们已经直接将其映射到m_file_address里面,然后将该connfd文件描述符上修改为EPOLLOUT(可写)事件,然后epoll_Wait监测到这一事件后,使用writev来将响应信息和请求文件聚集写到TCP Socket本身定义的发送缓冲区中,交由内核发送给用户。

相关推荐
敲代码的嘎仔13 分钟前
力扣高频SQL基础50题详解
开发语言·数据库·笔记·sql·算法·leetcode·后端开发
jran-21 分钟前
MySQL多表操作 查询&子查询&外键约束
数据库·mysql
橙子圆12323 分钟前
Redis知识6之事务
数据库·redis·缓存
不会摸鱼的小鱼26 分钟前
WSL 安装 Ubuntu 22.04 到指定磁盘
数据库·postgresql·php
m0_7020365334 分钟前
mysql如何导出特定条件的查询数据_使用mysqldump加where参数
jvm·数据库·python
正在走向自律35 分钟前
标量子查询消除:数据库优化器的一场“等价变戏法”
数据库·sql 优化·金仓数据库·数据库性能调优·标量子查询·数据库优化器
逻极35 分钟前
SQLite 从入门到精通:深入理解嵌入式数据库的艺术与科学
数据库·sqlite·记忆·sqlite从入门到精通
看到代码头都是大的1 小时前
CentoOS7安装mysql 8.0.46
mysql
未来之窗软件服务1 小时前
数据库优化(九)随机抽选系统数据表 ——东方仙盟
大数据·数据库·数据库优化·仙盟创梦ide·东方仙盟
爱喝水的鱼丶1 小时前
SAP-ABAP:新手入门篇——从0到1写出你的第一个ABAP Hello World程序并完成调试运行
运维·服务器·数据库·学习·sap·abap