/* * Copyright 2015 the original author or authors. * @https://github.com/scouter-project/scouter * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * */ package scouter.client.xlog.dialog; import java.util.HashMap; import java.util.Map; import org.eclipse.jface.viewers.ColumnLabelProvider; import org.eclipse.jface.viewers.TableViewerColumn; import org.eclipse.swt.SWT; import org.eclipse.swt.widgets.Display; import scouter.client.model.XLogData; import scouter.client.threads.ObjectSelectManager; import scouter.client.util.ExUtil; import scouter.util.CastUtil; import scouter.util.DateUtil; import scouter.util.LongEnumer; import scouter.util.LongKeyLinkedMap; import scouter.util.TopN; import scouter.util.TopN.DIRECTION; public class XLogSummaryUserDialog extends XLogSummaryAbstractDialog{ public XLogSummaryUserDialog(Display display, LongKeyLinkedMap<XLogData> dataMap) { super(display, dataMap); } protected void calcAsync() { ExUtil.asyncRun(new Runnable() { public void run() { Map<Long, UserSummary> summaryMap = new HashMap<Long, UserSummary>(); LongEnumer longEnumer = dataMap.keys(); while (longEnumer.hasMoreElements()) { XLogData d = dataMap.get(longEnumer.nextLong()); long time = d.p.endTime; if (d.filter_ok && time >= stime && time <= etime && !ObjectSelectManager.getInstance().isUnselectedObject(d.p.objHash)) { UserSummary summary = summaryMap.get(d.p.userid); if (summary == null) { summary = new UserSummary(); summary.id = d.p.userid; summaryMap.put(d.p.userid, summary); } summary.count++; summary.sumTime += d.p.elapsed; if (d.p.elapsed > summary.maxTime) { summary.maxTime = d.p.elapsed; } if (d.p.error != 0) { summary.error++; } summary.cpu += d.p.cpu; summary.memory += d.p.kbytes; summary.sqltime += d.p.sqlTime; summary.apicalltime += d.p.apicallTime; } } final TopN<UserSummary> stn = new TopN<UserSummary>(10000, DIRECTION.DESC); for (UserSummary so : summaryMap.values()) { stn.add(so); } ExUtil.exec(viewer.getTable(), new Runnable() { public void run() { rangeLabel.setText(DateUtil.format(stime, "yyyy-MM-dd HH:mm:ss") + " ~ " + DateUtil.format(etime, "HH:mm:ss") + " (" + stn.size() +")"); viewer.setInput(stn.getList()); } }); } }); } private static class UserSummary extends SummaryObject implements Comparable<UserSummary>{ long id; public int compareTo(UserSummary o) { return this.count - o.count; } } public String getTitle() { return "User Summary"; } protected void createMainColumn() { TableViewerColumn c = createTableViewerColumn("User ID", 100, SWT.LEFT, true); ColumnLabelProvider labelProvider = new ColumnLabelProvider() { public String getText(Object element) { if (element instanceof UserSummary) { return CastUtil.cString(((UserSummary) element).id); } return null; } }; c.setLabelProvider(labelProvider); } }