我在我们的一个网站上遇到了这个非常奇怪的错误。该网站已经正常工作了大约一年,但是昨天突然它开始抛出“ramdom”500错误,statig例如$这不是一个对象,或者包含随机失败(任何一个都没有失败)情况)。
代码示例:
//class Enviroment
219 public function run()
220 {
221 //vložit prostředí
222 if (class_exists('CONFIG')) {
223 $this->dir_basic = Config::$DirBasic;
224 }
225 include_once($this->dir_basic . 'web/libsf/enviroment/types/' . ($this->mode == 'dev' ? 'dev' : 'prod') . '.php');
226
227 //vytvořit třídu prostředí
228 $enviroment_class = 'Enviroment' . $this->mode;
229 $this->enviroment = new $enviroment_class($this);
230 $this->enviroment->pre_libs();
231
232 //načíst knihovny
233 $this->load_libs();
234
235 //zavolat inicializační metody po načtení knihoven
236 $this->enviroment->post_libs();
237
238 $this->init_vars();
239 }
这个类是正确启动的,通过这个(这个EXACT代码适用于我们的许多网站,只是这个突然停止工作):
$aplication = Enviroment::get_aplication('prod');
$aplication->run();
这会引发以下错误(请注意行号):
Notice: Trying to get property of non-object in /var/www/vhosts/e/example.cz/data/www/web/libsf/enviroment/enviroment.php on line 225
Notice: Trying to get property of non-object in /var/www/vhosts/e/example.cz/data/www/web/libsf/enviroment/enviroment.php on line 228
Notice: Trying to get property of non-object in /var/www/vhosts/e/example.cz/data/www/web/libsf/enviroment/enviroment.php on line 230
Fatal error: Call to a member function pre_libs() on a non-object in /var/www/vhosts/e/example.cz/data/www/web/libsf/enviroment/enviroment.php on line 230
(我认为第225行的包含失败是因为$这是“不是对象”......)。 我在CentOS 5.5上运行PHP5.3.3。 当我重新启动apache时,一切似乎都可以正常工作一段时间(五分钟,两小时,七秒......)然后它又开始抛出这些错误。
任何帮助表示感谢。
修改 环境类构造函数:
private function __construct($mode)
{
$this->mode = $mode;
//vygenerovat unikátní hash
mt_srand((double) microtime() * 1000000);
$this->hash = md5(uniqid(mt_rand(), TRUE)) . rand(0, 99999999);
}
Get_application方法:
public static function get_aplication($mode = 'auto')
{
if ($mode == 'auto') {
//nastavit produkční mod
$mode = 'prod';
//rozpoznat typ developerského módu
if ($_SERVER['SERVER_ADDR'] == '127.0.0.1' || preg_match('/^localhost/', $_SERVER['HTTP_HOST']) || $_GET['env_mode'] == 'developer') {
$mode = 'dev';
}
}
return self::$enviroment_obj = new Enviroment($mode);
}