gpt4 book ai didi

php - jQuery 自动完成菜单正在阻塞服务器

转载 作者:行者123 更新时间:2023-11-29 04:23:42 27 4
gpt4 key购买 nike

我使用 jQuery 创建了一个 DropDown 自动完成菜单。主要思想是,一旦将键插入文本框(最少 3 个字符),该函数就会使用 GET 方法向不同的页面(比如:search.php?q=iron man 3)和页面(search.php)发送请求。 php) 使用 MySQL 和 PHP 5 创建结果并显示它们。

到这里似乎没问题,但由于我的网站上有很多用户(每天大约 10,000 名用户),每次他们按下一个键都需要查询,这会在服务器上造成大量过载。这会减慢服务器速度。

是否有更智能的方法来制作下拉自动完成菜单?

谢谢。

最佳答案

简化查询

我假设您已经规范化并简化了您正在查询的表。最好只查询一个表,该表有一个名称字段,一些分数(例如流行度)用于排名结果(如果适用),可能是一个 movie_id 将您链接到实际电影数据或您正在查询的任何内容,也许还有一个数据类型( Actor 、电影等)的标识符。

您不必对所有内容进行规范化,只需将此数据移动到单独的表中,然后在每次您想查看名称时运行连接。这可能只是数据的额外副本。您甚至可以使用您通常不会使用的存储引擎,例如内存或 MyISAM(请参阅下面的文本搜索)来提高性能。

减少查询流量

添加是在运行查询时添加一些条件。在他们停止输入一小段时间(0.5+ 秒左右,默认为 0.3 秒)之前不要运行查询。这将是提高服务器稳定性的最简单和最快捷的方法,但会以响应速度为代价,因为它们必须停止更长时间。您也可以尝试避免客户端运行多个同时查询,这对读者来说是一个练习,但如果有适当的延迟,这可能是无用的。如果您从 Google 来到这里,您可以在 http://docs.jquery.com/UI/API/1.8/Autocomplete 查看相应的 jquery 自动完成文档。 .

$( ".selector" ).autocomplete({
minLength: 3, // already set
delay: 500
});

使用文本搜索引擎

另一个改进是使用文本搜索引擎。 MySQL 使用 MyISAM 和 InnoDB(5.6 中的新功能)引擎进行了一些全文搜索,但 MyISAM 有一些折衷,InnoDB 全文可能无法提供生产就绪的结果(as shown here)。幸运的是,在 MySQL 中切换表类型相当容易,并且拥有一个只有名称副本的小表应该可以缓解任何问题。对于更复杂的 DBA 操作,一些数据库让您自己重建所有内容。

如果您的站点变得足够繁忙,专用搜索引擎可能是个好主意,例如 Lucene/CLucene (一个 C++ 端口),Solr (Lucene 子项目),SphinxXapian仅举几例。

替代方法

关于我看到的唯一真正的替代方法是将整个数据集推送给每个访问者,并让客户端在 javascript 中自行处理查询和结果。对于 HTML5 应用程序,这可能有一些用处,但要确保数据被缓存。

关于php - jQuery 自动完成菜单正在阻塞服务器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16402437/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com