草庐IT

PHP MySQL 连接持久性

coder 2023-10-02 原文

我已经阅读了大量有关 PHP 和 MySQL 之间的持久数据库连接的文章(mysql_connect 与 mysql_pconnect)。与 PDO 和 MySQLi 相同。这绝对是我对这一点缺乏了解,但是网页之间的数据库连接如何持久?在这段代码中:

$conn = mysql_pconnect( $server , $user, $pass );
mysql_select_db( $dbname );

如果两个用户同时加载此页面,使用两个不同的 $dbname 变量,PHP 是否只会建立一个或两个数据库连接?我相当确定

$conn = mysql_connect( $server , $user, $pass );

将建立两个连接。

如果 pconnect 重用第一个用户打开的连接,mysql_select_db 调用是否对第二个用户有效?

理想情况下,我正在寻找一种减少数据库连接但仍然能够在每个 PHP 脚本中设置默认数据库的方法。我的客户都使用相同的 PHP 脚本,但数据存储在他们自己的客户端数据库中(因此,$dbname 总是不同的,但 MySQL 连接参数是相同的 - 相同的 mysql ip 地址、用户和密码)。

希望这是有道理的。我们可以使用 MySQL、MySQLi 或 PDO,只需要知道如何以最好的方式实现这一点,而不会出现客户端不小心将数据写入其他人的数据库的可能性!提前致谢。

最佳答案

持久性是由嵌入在网络服务器中的 PHP 副本完成的。通常你是对的 - 如果 PHP 在 CGI 模式下运行,就不可能有持久连接,因为当请求完成并且 PHP 关闭时,没有任何东西可以保持。

但是,由于网络服务器中嵌入了一个 PHP 副本,并且网络服务器本身在请求之间保持运行,因此可以在该“永久”PHP 中维护一个持久连接池。

但是,请注意,在 Apache 多 worker 类型服务器模型上,连接池是按每个 child 维护的。如果将池限制设置为 10,则每个 Apache 子节点将有 10 个连接。 20 个 child = 200 个连接。

持久连接还会导致死锁和其他难以调试的问题的长期问题。请记住 - 不能保证用户的 HTTP 请求将由相同的 apache 子/mysql 连接提供服务。如果脚本在数据库事务中途终止,该事务将不会回滚,因为 MySQL 看不到事物的 HTTP 端 - 它看到的只是 mysql<->apache 连接仍然开放并假设一切都很好。

下一个点击特定 apache/mysql 子/连接组合的用户现在将神奇地结束在该事务的中间,而不知道该事务是打开的。基本上,它在 Web 上相当于一个未冲水的马桶 - 之前用户的所有“垃圾”仍然存在。

使用非持久连接,保证每次连接时都有一个“干净”的环境。

关于PHP MySQL 连接持久性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11763929/

有关PHP MySQL 连接持久性的更多相关文章

  1. ruby - 续集在添加关联时访问many_to_many连接表 - 2

    我正在使用Sequel构建一个愿望list系统。我有一个wishlists和itemstable和一个items_wishlists连接表(该名称是续集选择的名称)。items_wishlists表还有一个用于facebookid的额外列(因此我可以存储opengraph操作),这是一个NOTNULL列。我还有Wishlist和Item具有续集many_to_many关联的模型已建立。Wishlist类也有:selectmany_to_many关联的选项设置为select:[:items.*,:items_wishlists__facebook_action_id].有没有一种方法可以

  2. ruby - 无法在 60 秒内获得稳定的 Firefox 连接 (127.0.0.1 :7055) - 2

    我使用的是Firefox版本36.0.1和Selenium-Webdrivergem版本2.45.0。我能够创建Firefox实例,但无法使用脚本继续进行进一步的操作无法在60秒内获得稳定的Firefox连接(127.0.0.1:7055)错误。有人能帮帮我吗? 最佳答案 我遇到了同样的问题。降级到firefoxv33后一切正常。您可以找到旧版本here 关于ruby-无法在60秒内获得稳定的Firefox连接(127.0.0.1:7055),我们在StackOverflow上找到一个类

  3. ruby-on-rails - Rails 模型——非持久类成员或属性? - 2

    对于Rails模型,是否可以/建议让一个类的成员不持久保存到数据库中?我想将用户最后选择的类型存储在session变量中。由于我无法从我的模型中设置session变量,我想将值存储在一个“虚拟”类成员中,该成员只是将值传递回Controller。你能有这样的类(class)成员吗? 最佳答案 将非持久属性添加到Rails模型就像任何其他Ruby类一样:classUser扩展解释:在Ruby中,所有实例变量都是私有(private)的,不需要在赋值前定义。attr_accessor创建一个setter和getter方法:classUs

  4. ruby - 我的 Ruby IRC 机器人没有连接到 IRC 服务器。我究竟做错了什么? - 2

    require"socket"server="irc.rizon.net"port="6667"nick="RubyIRCBot"channel="#0x40"s=TCPSocket.open(server,port)s.print("USERTesting",0)s.print("NICK#{nick}",0)s.print("JOIN#{channel}",0)这个IRC机器人没有连接到IRC服务器,我做错了什么? 最佳答案 失败并显示此消息::irc.shakeababy.net461*USER:Notenoughparame

  5. ruby-on-rails - 连接字符串时如何在 <%=%> block 内输出 html_safe? - 2

    考虑一下:现在这些情况:#output:http://domain.com/?foo=1&bar=2#output:http://domain.com/?foo=1&bar=2#output:http://domain.com/?foo=1&bar=2#output:http://domain.com/?foo=1&bar=2我需要用其他字符串输出URL。我如何保证&符号不会被转义?由于我无法控制的原因,我无法发送&。求助!把我的头发拉到这里:\编辑:为了澄清,我实际上有一个像这样的数组:@images=[{:id=>"fooid",:url=>"http://

  6. ruby - Faye WebSocket,关闭处理程序被触发后重新连接到套接字 - 2

    我有一个super简单的脚本,它几乎包含了FayeWebSocketGitHub页面上用于处理关闭连接的内容:ws=Faye::WebSocket::Client.new(url,nil,:headers=>headers)ws.on:opendo|event|p[:open]#sendpingcommand#sendtestcommand#ws.send({command:'test'}.to_json)endws.on:messagedo|event|#hereistheentrypointfordatacomingfromtheserver.pJSON.parse(event.d

  7. ruby-on-rails - 什么会导致与 APNS 的连接间歇性断开连接? - 2

    我有一个ruby​​脚本可以打开与Apple推送服务器的连接并发送所有待处理的通知。我看不出任何原因,但当Apple断开我的脚本时,我遇到了管道损坏错误。我已经编写了我的脚本来适应这种情况,但我宁愿只是找出它发生的原因,这样我就可以在第一时间避免它。它不会始终根据特定通知断开连接。它不会以特定的字节传输大小断开连接。一切似乎都是零星的。您可以在单个连接上发送的数据传输或有效负载计数是否有某些限制?看到人们的解决方案始终保持一个连接打开,我认为这不是问题所在。我看到连接在3次通知后断开,我看到它在14次通知后断开。我从未见过它能超过14点。有没有人遇到过这种类型的问题?如何处理?

  8. ruby - 如何断开现有的 ruby​​ 续集与数据库的连接? - 2

    我的意思是之前建立的那个DB=Sequel.sqlite('my_blog.db')或DB=Sequel.connect('postgres://user:password@localhost/my_db')或DB=Sequel.postgres('my_db',:user=>'user',:password=>'password',:host=>'localhost')等等。Sequel::Database类没有名为“disconnect”的公共(public)实例方法,尽管它有一个“connect”。也许有人已经遇到过这个问题。我将不胜感激。 最佳答案

  9. ruby-on-rails - 遗留数据库的 ActiveRecord 连接表 - 2

    我有一个遗留数据库,我正在努力让ActiveRecord使用它。我遇到了连接表的问题。我有以下内容:classTvShow然后我有一个名为tvshowlinkepisode的表,它有2个字段:idShow、idEpisode所以我有2个表和它们之间的连接(多对多关系),但是连接使用非标准外键。我的第一个想法是创建一个名为TvShowEpisodeLink的模型,但没有主键。我的想法是,由于外键是非标准的,我可以使用set_foreign_key并进行一些控制。最后,我想说一些类似TvShow.find(:last).episodes或Episode.find(:last).tv_sho

  10. ruby - rails 3.2.2(或 3.2.1)+ Postgresql 9.1.3 + Ubuntu 11.10 连接错误 - 2

    我正在使用PostgreSQL9.1.3(x86_64-pc-linux-gnu上的PostgreSQL9.1.3,由gcc-4.6.real(Ubuntu/Linaro4.6.1-9ubuntu3)4.6.1,64位编译)和在ubuntu11.10上运行3.2.2或3.2.1。现在,我可以使用以下命令连接PostgreSQLsupostgres输入密码我可以看到postgres=#我将以下详细信息放在我的config/database.yml中并执行“railsdb”,它工作正常。开发:adapter:postgresqlencoding:utf8reconnect:falsedat

随机推荐