我目前正在用php-activerecord替换自制的hack-y MVC方法的模型组件。我有一个单独的页面,显示数据库服务器关闭的情况,该页面用于显示具有访客头像,名称和角色的用户徽章。代码如下:在没有数据库连接的情况下实例化ActiveRecord模型
if (Auth::$signed_in)
echo Auth::$user->getAvatarWrap();
else echo (new \App\Models\User([
'name' => 'Guest',
'role' => 'guest',
'avatar_url' => GUEST_AVATAR
]))->getAvatarWrap();
Auth::$signed_in
设为true
当用户已登录,其中 - 在DB中断的情况下 - 是不可能的,所以else
分支与所述预定义的数据执行。
Pre-ActiveRecord这将简单地将属性添加到对象,并且调用getAvatarWrap
方法将执行没有任何问题。现在,模型由ActiveRecord控制,无论出于何种原因,都会发生一系列额外的调用。这可能是因为该模型已定义关系,但我不确定。
ActiveRecord\DatabaseException: PDOException: SQLSTATE[08006] [7] could not connect to server: Connection refused
Is the server running on host "localhost" (127.0.0.1) and accepting
TCP/IP connections on port 5432? in /var/www/vendor/php-activerecord/php-activerecord/lib/Connection.php:260
Stack trace:
#0 /var/www/vendor/php-activerecord/php-activerecord/lib/Connection.php(260): PDO->__construct('pgsql:host=loca...', '<username>', '<password>', Array)
#1 /var/www/vendor/php-activerecord/php-activerecord/lib/Connection.php(122): ActiveRecord\Connection->__construct(Object(stdClass))
#2 /var/www/vendor/php-activerecord/php-activerecord/lib/ConnectionManager.php(33): ActiveRecord\Connection::instance('pgsql://databas...')
#3 /var/www/vendor/php-activerecord/php-activerecord/lib/Table.php(114): ActiveRecord\ConnectionManager::get_connection('pgsql')
#4 /var/www/vendor/php-activerecord/php-activerecord/lib/Table.php(90): ActiveRecord\Table->reestablish_connection(false)
#5 /var/www/vendor/php-activerecord/php-activerecord/lib/Table.php(71): ActiveRecord\Table->__construct('App\\Models\\User')
#6 /var/www/vendor/php-activerecord/php-activerecord/lib/Model.php(765): ActiveRecord\Table::load('App\\Models\\User')
#7 /var/www/vendor/php-activerecord/php-activerecord/lib/Model.php(271): ActiveRecord\Model::table()
#8 /var/www/includes/views/_sidebar.php(20): ActiveRecord\Model->__construct(Array)
#9 /var/www/includes/views/_layout.php(148): include('/var/www...')
#10 /var/www/includes/views/fatalerr.php(46): require('/var/www...')
#11 /var/www/includes/init.php(32): require('/var/www...')
#12 /var/www/includes/do.php(3): require('/var/www...')
#13 /var/www/public/index.php(1): require('/var/www...')
#14 {main} in /var/www/vendor/php-activerecord/php-activerecord/lib/Connection.php on line 262
我如何告诉ActiveRecord的停止寻找连接时,我知道一个事实,即它不会找到一个,那它应该是内容与我喂养它的数据?在停电期间,我是否必须挥手告别使用我的任何模型?
你可以修改配置以使用sqlite:memory连接吗? – colburton
我完全控制了代码和运行的服务器。 – SeinopSys
然后这可能是一个解决方案。每个查询都会失败,但是无论如何都会发生。 – colburton