Как показать несколько таблиц в зависимости от ключа на карте, используя JSTL?

У меня есть карта строк и список объектов, который содержит каждый центр обработки данных и его машину. И в настоящее время я передаю этот объект в JSP из моего контроллера, а затем перебираю его на странице JSP, чтобы показать данные.

Если размер карты один, то я могу показать данные на странице JSP, и она отлично работает.

Теперь предположим, что если размер карты равен двум, то я хотел бы показать две таблицы по одной для каждого ключа на карте. Это то, что я не могу заставить работать. Максимальный размер карты может быть 3 для моего случая использования.

Ниже мой класс, который содержит данные -

public class DatacenterMachineMapping {

    private Map<String, List<MachineMetrics>> datacenterMachines;

    // getters and setters
}

public class MachineMetrics {

    private String machineName;
    private String t2_95;
    private String t2_99;
    private String syncs;
    private String syncsBehind;
    private String average;

    // getters and setters
}

И ниже мой метод в моем контроллере, из которого мне нужно передать объект в JSP и затем итерировать этот объект в JSP, чтобы показать данные в таблице -

@RequestMapping(value = "testOperation", method = RequestMethod.GET)
public Map<String, String> testData() {

    final Map<String, String> model = new LinkedHashMap<String, String>();

    // for datacenter 1
    MachineMetrics metrics1 = new MachineMetrics();
    metrics1.setAvg("10");
    metrics1.setT2_95("100");
    metrics1.setT2_99("200");
    metrics1.setMachineName("machineA");
    metrics1.setSyncs("100");
    metrics1.setSyncsBehind("1000");

    MachineMetrics metrics2 = new MachineMetrics();
    metrics2.setAvg("20");
    metrics2.setT2_95("200");
    metrics2.setT2_99("300");
    metrics2.setMachineName("machineB");
    metrics2.setSyncs("200");
    metrics2.setSyncsBehind("2000");

    List<MachineMetrics> metricsA = new LinkedList<MachineMetrics>();
    metricsA.add(metrics1);
    metricsA.add(metrics2);

    // for datacenter 2
    MachineMetrics metrics3= new MachineMetrics();
    metrics3.setAvg("30");
    metrics3.setT2_95("300");
    metrics3.setT2_99("300");
    metrics3.setMachineName("machineC");
    metrics3.setSyncs("300");
    metrics3.setSyncsBehind("3000");

    MachineMetrics metrics4 = new MachineMetrics();
    metrics4.setAvg("40");
    metrics4.setT2_95("400");
    metrics4.setT2_99("400");
    metrics4.setMachineName("machineD");
    metrics4.setSyncs("400");
    metrics4.setSyncsBehind("4000");

    List<MachineMetrics> metricsB = new LinkedList<MachineMetrics>();
    metricsB.add(metrics3);
    metricsB.add(metrics4);     

    DatacenterMachineMapping mappings = new DatacenterMachineMapping();
    Map<String, List<MachineMetrics>> holder = new LinkedHashMap<String, List<MachineMetrics>>();
    holder.put("dc1", metricsA);
    holder.put("dc2", metricsB);

    mappings.setDatacenterMachines(holder);     

    model.put("testing", mappings); // passing this object to jsp

    return model;   
}

Постановка задачи:-

Как видно из приведенного выше кода, у меня есть два ключа, так как у меня есть два центра обработки данных, один из которыхdc1 и другоеdc2, Поэтому я хотел бы показать две таблицы - одну дляdc1 и его машины и второй стол дляdc2 и его машины, как показано ниже.

Так что мои данные должны выглядеть так после итерацииtesting object-

For DC1

Machine Name    T2_95   T2_99   Syncs   Syncs Behind    Average

machineA        100     200     100     1000            10
machineB        200     300     200     2000            20

For DC2

Machine Name    T2_95   T2_99   Syncs   Syncs Behind    Average

machineC        300     300     300     3000            30
machineD        400     400     400     4000            40

И ниже моя страница JSP, которая отлично работает только для размера карты, равного единице. И я не уверен, как повторить вышеmappings объект на странице JSP таким образом, чтобы я мог показать две таблицы для моего варианта использования по одному для каждого ключа, как показано выше. Возможно ли это сделать?

<body>
    <table>
        <thead>
            <tr>
                <th>Machine Name</th>
                <th>T2_95</th>
                <th>T2_99</th>
                <th>Syncs</th>
                <th>Syncs Behind</th>
                <th>Average</th>
            </tr>
        </thead>
        <tbody>

        <c:set var="entry" value="${testing.datacenterMachines}"></c:set>
        <c:forEach var="m" items="${entry.value}">
           <tr>
              <td>${m.machineName}</td>
              <td>${m.t2_95}</td>
              <td>${m.t2_99}</td>
              <td>${m.syncs}</td>
              <td>${m.syncsBehind}</td>
              <td>${m.average}</td>
           </tr>
        </c:forEach>

        </tbody>
    </table>
</body>

Любая идея, как я могу сделать мой универсальный JSP здесь? Как это возможно, у меня может быть три центра обработки данных, как в настоящее время у меня есть два.

Я продолжаю свой предыдущий вопросВот который помогает мне перебрать карту размера один, но не уверен, как бы у меня было две отдельные таблицы по одной для каждого ключа

ОБНОВИТЬ:-

Это то, что я пытался, и это не работает для меня -

<c:forEach var="e" items="${testing}">
  <h3>For <c:out value="${e.key}"/></h3>
    <table>
      <thead>
            <tr>
                <th>Machine Name</th>
                <th>T2_95</th>
                <th>T2_99</th>
                <th>Syncs</th>
                <th>Syncs Behind</th>
                <th>Average</th>
            </tr>
        </thead>
        <tbody>
          <c:forEach var="m" items="${e.value}">
            <tr>
              <td>${m.machineName}</td>
              <td>${m.t2_95}</td>
              <td>${m.t2_99}</td>
              <td>${m.syncs}</td>
              <td>${m.syncsBehind}</td>
              <td>${m.average}</td>
             </tr>
           </c:ForEach>
        </tbody>
    </table>
</c:forEach>

И я получаю ниже исключения, и я не уверен, что я не так делаю здесь? -

Don't know how to iterate over supplied "items" in &lt;forEach&gt;

Ответы на вопрос(1)

Ваш ответ на вопрос