Ошибка MappingException на производстве - PullRequest
1 голос
/ 02 февраля 2012

Я получаю эту ошибку в моей производственной среде: (из prod.log)

[2012-01-30 17:00:51] request.CRITICAL: Doctrine\ORM\Mapping\MappingException: Class Gitek\UdaBundle\Entity\Curso is not a valid entity or mapped super class. (uncaught exception) at /home/uda/shared/vendor/doctrine/lib/Doctrine/ORM/Mapping/MappingException.php line 142 [] []

Но в моей среде разработки все работает нормально.

И это моя сущность Curso:

<?php

namespace Gitek\UdaBundle\Entity;

use Doctrine\ORM\Mapping as ORM;
use Symfony\Component\Validator\Constraints as Assert;
/**
 * Gitek\UdaBundle\Entity\Curso
 *
 * @ORM\Table(name="Curso")
 * @ORM\HasLifecycleCallbacks
 * @ORM\Entity(repositoryClass="Gitek\UdaBundle\Entity\CursoRepository")
 */
class Curso
{
    /**
     * @var integer $id
     *
     * @ORM\Column(name="id", type="integer")
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="AUTO")
     */
    private $id;

    /**
     * @var string $nombre
     *
     * @ORM\Column(name="nombre", type="string", length=255)
     */
    private $nombre;

    /**
     * @var string $version
     *
     * @ORM\Column(name="version", type="string", length=255, nullable=true)
     */
    private $version;

    /**
     * @var integer $orden
     *
     * @ORM\Column(name="orden", type="integer", nullable=true, nullable=true)
     */
    private $orden;

    /**
     * @var integer $tiempo
     *
     * @ORM\Column(name="tiempo", type="integer", nullable=true, nullable=true)
     */
    private $tiempo;

    /**
     * @ORM\OneToMany(targetEntity="Detcurso", mappedBy="curso", cascade={"remove"})
     * @ORM\OrderBy({"orden" = "ASC"})
     */
    private $detcursos;

    /**
     * @ORM\OneToMany(targetEntity="Historial", mappedBy="curso", cascade={"remove"})
     */
    private $historiales;

    /**
     * @ORM\Column(type="datetime")
     */
    protected $created;

    /**
     * @ORM\Column(type="datetime")
     */
    protected $updated;


    public function __construct()
    {
        $this->detcursos = new \Doctrine\Common\Collections\ArrayCollection();
                $this->setCreated(new \DateTime());
        $this->setUpdated(new \DateTime());
    }

    public function __toString()
    {
        return $this->getNombre();
    }



    /**
     * Get id
     *
     * @return integer 
     */
    public function getId()
    {
        return $this->id;
    }

    /**
     * Set nombre
     *
     * @param string $nombre
     */
    public function setNombre($nombre)
    {
        $this->nombre = $nombre;
    }

    /**
     * Get nombre
     *
     * @return string 
     */
    public function getNombre()
    {
        return $this->nombre;
    }

    /**
     * Set version
     *
     * @param string $version
     */
    public function setVersion($version)
    {
        $this->version = $version;
    }

    /**
     * Get version
     *
     * @return string 
     */
    public function getVersion()
    {
        return $this->version;
    }

    /**
     * Set orden
     *
     * @param integer $orden
     */
    public function setOrden($orden)
    {
        $this->orden = $orden;
    }

    /**
     * Get orden
     *
     * @return integer 
     */
    public function getOrden()
    {
        return $this->orden;
    }

    /**
     * Set created
     *
     * @param datetime $created
     */
    public function setCreated($created)
    {
        $this->created = $created;
    }

    /**
     * Get created
     *
     * @return datetime 
     */
    public function getCreated()
    {
        return $this->created;
    }

    /**
     * Set updated
     *
     * @param datetime $updated
     */
    public function setUpdated($updated)
    {
        $this->updated = $updated;
    }

    /**
     * Get updated
     *
     * @return datetime 
     */
    public function getUpdated()
    {
        return $this->updated;
    }

    /**
     * Add detcursos
     *
     * @param Gitek\UdaBundle\Entity\Detcurso $detcursos
     */
    public function addDetcurso(\Gitek\UdaBundle\Entity\Detcurso $detcursos)
    {
        $this->detcursos[] = $detcursos;
    }

    /**
     * Get detcursos
     *
     * @return Doctrine\Common\Collections\Collection 
     */
    public function getDetcursos()
    {
        return $this->detcursos;
    }

    /**
     * Add historiales
     *
     * @param Gitek\UdaBundle\Entity\Historial $historiales
     */
    public function addHistorial(\Gitek\UdaBundle\Entity\Historial $historiales)
    {
        $this->historiales[] = $historiales;
    }

    /**
     * Get historiales
     *
     * @return Doctrine\Common\Collections\Collection 
     */
    public function getHistoriales()
    {
        return $this->historiales;
    }

    /**
     * Get historial
     *
     * @return Doctrine\Common\Collections\Collection 
     */
    public function getHistorial()
    {
        return $this->historial;
    }

    /**
     * Set tiempo
     *
     * @param integer $tiempo
     */
    public function setTiempo($tiempo)
    {
        $this->tiempo = $tiempo;
    }

    /**
     * Get tiempo
     *
     * @return integer 
     */
    public function getTiempo()
    {
        return $this->tiempo;
    }
}

Как я уже сказал, в app_dev работает правильно.

Ответы [ 2 ]

2 голосов
/ 02 февраля 2012

Вы можете иметь различные конфигурации кэша метаданных в зависимости от того, в какой среде вы находитесь. Например, apc может вызвать проблемы, если не обновлено правильно.

В любом случае, вам придется прогревать кеш в среде prod, например:

php app/console cache:clear --env=prod

Если это по-прежнему не работает, попробуйте изменить конфигурацию кэша доктрины:

        orm:
            auto_generate_proxy_classes:    false
            default_entity_manager:         default
            entity_managers:
                default:
                    metadata_cache_driver:          array
                    query_cache_driver:             array
                    result_cache_driver:            array

При этом будет использоваться драйвер кэша array, который обновляется один раз при каждом запросе. Вы не должны использовать это в производстве, но это может помочь вам понять, откуда возникла ваша проблема.

0 голосов
/ 17 июля 2012

В моем случае проблема была решена путем изменения кэша моего сервера с eAccelerator на APC. Очевидно, eAccelerator удаляет все комментарии из файлов, которые нарушают ваши аннотации.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...