gpt4 book ai didi

php - SELECT/UPDATE 和 SELECT/INSERT 杀死 MySQL 服务器

转载 作者:可可西里 更新时间:2023-11-01 08:01:02 25 4
gpt4 key购买 nike

我运行的服务器因来 self 们的一款 iPhone 游戏的用于存储分数的请求数量而被杀死。我的意思是服务器变得无响应。

我真的只知道足够的 MySQL/PHP 来应付,所以我正在努力解决这个问题。我确信这是一个可以优化的问题,因为我们有专用服务器。我们每分钟只处理 300 个请求。

基本上,我们检查某人从他们的 iPhone 游戏中发布的分数(使用 SELECT)以查看他们是否有现有分数。如果他们这样做了,并且他们的新分数更好,我们会进行更新,否则我们会进行插入。语句如下所示:

$sql = "SELECT id,score,level FROM $table WHERE board='$board' AND name='$name' AND udid = '$udid' AND fbuid = '$fbuid'"

UPDATE 和 INSERT 语句如下所示:

$sql = "UPDATE $table SET score='$score', level='$level', country='$country', date=CURRENT_TIMESTAMP WHERE board='$board' AND name='$name' AND udid = '$udid' AND fbuid = '$fbuid'"

$sql = "INSERT INTO $table(board, udid, fbuid, name, score, level, country) VALUES ('$board', '$udid', '$fbuid', '$name', '$score', '$level', $country')"

为了完整起见,这里是表格的定义:

CREATE TABLE $table (
id int(11) NOT NULL auto_increment,
board tinyint(4) NOT NULL,
udid varchar(45) default NULL,
fbuid bigint(20) unsigned default NULL,
name varchar(25) default NULL,
country tinyint(4) default NULL,
level tinyint(4) default NULL,
score decimal(10,0) default NULL,
date timestamp NOT NULL default CURRENT_TIMESTAMP,
PRIMARY KEY (id),
KEY scoreidx (score),
KEY udididx (udid),
KEY fbuididx (fbuid),
KEY boardidx (board),
KEY levelidx (level),
KEY countryidx (country)
) ENGINE=MyISAM DEFAULT CHARSET=latin1

我目前使用以下方法从 PHP 连接到 MySQL 服务器:

$conn = mysql_pconnect(DB_HOST,DB_USER,DB_PASSWORD,MYSQL_CLIENT_INTERACTIVE);

但以前使用过 msql_connect,但没有注意到它的改进。

任何关于我如何优化它的指示,或任何描述我应该做什么的网页的链接都将不胜感激。

最佳答案

MyISAM 有表锁而不是 InnoDB 行锁。您可以创建表的副本,将引擎更改为 InnoDB,并(在测试服务器上)使用 mysqlslap 或类似的压力测试工具测试负载。

此外,非常重要:

ALTER TABLE tablename ADD INDEX(board,name,udid,fbuid)

MySQL 一次只能使用 1 个索引,因此当总是查询此特定组合时,您的几个“松散”索引并没有太大用处。

关于php - SELECT/UPDATE 和 SELECT/INSERT 杀死 MySQL 服务器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3294619/

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