jms 序列化程序性能问题

2022-08-30 18:37:41

我正在使用 JMS 序列化程序。我发现当我使用大数据时,性能真的很差。我将以下对象结构显示为数组:

$jsonData = array(
    'message' => 'this is a nice message', 
    'data' => array(
        0 => array(
          'firstname' => 'achim',
          'lastname' => 'menzel' 
        )
    )
);

以下是我序列化数据的方式:

$serializer = $this->get('serializer');
$encodedJson = $serializer->serialize($jsonData, 'json');

$response = new Response($encodedJson);
$response->headers->set('Content-Type', 'application/json');

数据可以是 till 对象的列表。当我在数据中有超过500个对象时,性能非常非常慢(超过5秒)。当我直接使用时,它花费的时间不超过1秒。1njson_encode()

如何提高 JMS 序列化程序的使用率?我不认为jms序列化程序不能处理大数据。

这是将用于序列化的主类:

class JsonData {

  public $success = false;
  public $message = '';
  public $data;
  public $responseCode = 200;
  public $contentType = 'application/json';
}

目前这个对象在里面:$data

class GuestDTO {

  private $userid;
  private $firstname;
  private $lastname;
  private $birthday;
  private $picturemedium;
  private $picturelarge;
  private $gender;
  private $modifydate;
  private $entries = array(); 
}

并且是此类中的对象列表:$entries

class GuestlistentryDTO extends AbstractGuestDTO{

  private $guestlistentryid;
  private $guestlistid;
  private $arrivedat;
  private $bouncername;
  private $rejectionreason;
  private $companioncount;
  private $companioncountcheckin;    
  private $winner;
  private $vip;  
}

没有任何注释,因为我准备了我的dto,以便根据需要使用数据。


答案 1

不幸的是,这个库本质上是相当慢的。那里有很多递归。

但是,您可以做的几件事是使用Redis或Memcache查询缓存所有内容。你也可以聪明地处理你的SQL查询,试着削减脂肪。仅向序列化程序提供所需的重要数据,以便它不会搜索大量无论如何都不会被使用的数据。


答案 2

是否使用了部分响应?你的问题实际上似乎很明显。在我看来,您的客户应该要求有限数量的物品,并在必要时要求更多......


推荐