/* * 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.ArrayList; import java.util.HashMap; import java.util.List; 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.TextProxy; import scouter.client.model.XLogData; import scouter.client.threads.ObjectSelectManager; import scouter.client.util.ExUtil; import scouter.util.DateUtil; import scouter.util.LongEnumer; import scouter.util.LongKeyLinkedMap; import scouter.util.TopN; import scouter.util.TopN.DIRECTION; public class XLogSummaryUserAgentDialog extends XLogSummaryAbstractDialog{ public XLogSummaryUserAgentDialog(Display display, LongKeyLinkedMap<XLogData> dataMap) { super(display, dataMap); } protected void calcAsync() { ExUtil.asyncRun(new Runnable() { public void run() { Map<Integer, UserAgentSummary> summaryMap = new HashMap<Integer, UserAgentSummary>(); Map<Integer, List<Integer>> loadTextMap = new HashMap<Integer, List<Integer>>(); 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)) { UserAgentSummary summary = summaryMap.get(d.p.userAgent); if (summary == null) { summary = new UserAgentSummary(d.p.userAgent); summaryMap.put(d.p.userAgent, summary); List<Integer> loadTextList = loadTextMap.get(d.serverId); if (loadTextList == null) { loadTextList = new ArrayList<Integer>(); loadTextMap.put(d.serverId, loadTextList); } loadTextList.add(d.p.userAgent); } 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; } } for (Integer serverId : loadTextMap.keySet()) { TextProxy.userAgent.load(DateUtil.yyyymmdd(etime), loadTextMap.get(serverId), serverId); } final TopN<UserAgentSummary> stn = new TopN<UserAgentSummary>(10000, DIRECTION.DESC); for (UserAgentSummary 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 UserAgentSummary extends SummaryObject implements Comparable<UserAgentSummary>{ int hash; UserAgentSummary(int hash) { this.hash = hash; } public int compareTo(UserAgentSummary o) { return this.count - o.count; } } public String getTitle() { return "User-Agent Summary"; } protected void createMainColumn() { TableViewerColumn c = createTableViewerColumn("User-Agent", 200, SWT.LEFT, false); ColumnLabelProvider labelProvider = new ColumnLabelProvider() { public String getText(Object element) { if (element instanceof UserAgentSummary) { return TextProxy.userAgent.getText(((UserAgentSummary) element).hash); } return null; } }; c.setLabelProvider(labelProvider); } }