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本身定义的发送缓冲区中,交由内核发送给用户。

相关推荐
lwprain1 小时前
springboot 2.7.6 security mysql redis jwt配置例子
spring boot·redis·mysql
vcshcn1 小时前
DBASE DBF数据库文件解析
数据库·dbase
AIGC大时代3 小时前
对比DeepSeek、ChatGPT和Kimi的学术写作撰写引言能力
数据库·论文阅读·人工智能·chatgpt·数据分析·prompt
如风暖阳3 小时前
Redis背景介绍
数据库·redis·缓存
lingllllove4 小时前
Redis脑裂问题详解及解决方案
数据库·redis·缓存
字节全栈_BjO4 小时前
mysql死锁排查_mysql 死锁问题排查
android·数据库·mysql
微光守望者4 小时前
Redis常见命令
数据库·redis·缓存
martian6655 小时前
第六篇:事务与并发控制
数据库
x-cmd7 小时前
[250202] DocumentDB 开源发布:基于 PostgreSQL 的文档数据库新选择 | Jekyll 4.4.0 发布
数据库·postgresql·开源
是小崔啊12 小时前
事务03之MVCC机制
数据库·mysql·事务·