亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? cmsmemorymonitor.java

?? cms是開源的框架
?? JAVA
?? 第 1 頁 / 共 3 頁
字號:
        } catch (Throwable t) {
            // catch all other exceptions otherwise the whole monitor will stop working
            if (LOG.isDebugEnabled()) {
                LOG.debug(Messages.get().getBundle().key(Messages.LOG_CAUGHT_THROWABLE_1, t.getMessage()));
            }
        }

        return totalSize;
    }

    /**
     * Returns the value sizes of value objects within the monitored object.<p>
     * obj must be of type map
     * 
     * @param obj the object 
     * @return the value sizes of value objects or "-"-fields
     */
    private long getValueSize(Object obj) {

        if (obj instanceof CmsLruCache) {
            return ((CmsLruCache)obj).size();
        }

        if (obj instanceof Map) {
            return getValueSize((Map)obj, 1);
        }

        if (obj instanceof List) {
            return getValueSize((List)obj, 1);
        }

        try {
            return getMemorySize(obj);
        } catch (Exception exc) {
            return 0;
        }
    }

    /**
     * Sends a warning or status email with OpenCms Memory information.<p>
     * 
     * @param warning if true, send a memory warning email 
     */
    private void monitorSendEmail(boolean warning) {

        if ((m_configuration.getEmailSender() == null) || (m_configuration.getEmailReceiver() == null)) {
            // send no mails if not fully configured
            return;
        } else if (warning
            && (m_warningSendSinceLastStatus && !((m_intervalEmail <= 0) && (System.currentTimeMillis() < (m_lastEmailWarning + m_intervalWarning))))) {
            // send no warning email if no status email has been send since the last warning
            // if status is disabled, send no warn email if warn interval has not passed
            return;
        } else if ((!warning) && (m_intervalEmail <= 0)) {
            // if email iterval is <= 0 status email is disabled
            return;
        }
        String date = CmsDateUtil.getDateTimeShort(System.currentTimeMillis());
        String subject;
        String content = "";
        if (warning) {
            m_warningSendSinceLastStatus = true;
            m_lastEmailWarning = System.currentTimeMillis();
            subject = "OpenCms Memory W A R N I N G ["
                + OpenCms.getSystemInfo().getServerName().toUpperCase()
                + "/"
                + date
                + "]";
            content += "W A R N I N G !\nOpenCms memory consumption on server "
                + OpenCms.getSystemInfo().getServerName().toUpperCase()
                + " has reached a critical level !\n\n"
                + "The configured limit is "
                + m_maxUsagePercent
                + "%\n\n";
        } else {
            m_warningSendSinceLastStatus = false;
            m_lastEmailStatus = System.currentTimeMillis();
            subject = "OpenCms Memory Status ["
                + OpenCms.getSystemInfo().getServerName().toUpperCase()
                + "/"
                + date
                + "]";
        }

        content += "Memory usage report of OpenCms server "
            + OpenCms.getSystemInfo().getServerName().toUpperCase()
            + " at "
            + date
            + "\n\n"
            + "Memory maximum heap size: "
            + m_memoryCurrent.getMaxMemory()
            + " mb\n"
            + "Memory current heap size: "
            + m_memoryCurrent.getTotalMemory()
            + " mb\n\n"
            + "Memory currently used   : "
            + m_memoryCurrent.getUsedMemory()
            + " mb ("
            + m_memoryCurrent.getUsage()
            + "%)\n"
            + "Memory currently unused : "
            + m_memoryCurrent.getFreeMemory()
            + " mb\n\n\n";

        if (warning) {
            content += "*** Please take action NOW to ensure that no OutOfMemoryException occurs.\n\n\n";
        }

        CmsSessionManager sm = OpenCms.getSessionManager();

        if (sm != null) {
            content += "Current status of the sessions:\n\n";
            content += "Logged in users          : " + sm.getSessionCountAuthenticated() + "\n";
            content += "Currently active sessions: " + sm.getSessionCountCurrent() + "\n";
            content += "Total created sessions   : " + sm.getSessionCountTotal() + "\n\n\n";
        }

        sm = null;

        content += "Current status of the caches:\n\n";
        List keyList = Arrays.asList(m_monitoredObjects.keySet().toArray());
        Collections.sort(keyList);
        long totalSize = 0;
        for (Iterator keys = keyList.iterator(); keys.hasNext();) {
            String key = (String)keys.next();
            String[] shortKeys = key.split("\\.");
            String shortKey = shortKeys[shortKeys.length - 2] + '.' + shortKeys[shortKeys.length - 1];
            PrintfFormat form = new PrintfFormat("%9s");
            Object obj = m_monitoredObjects.get(key);

            long size = getKeySize(obj) + getValueSize(obj) + getCosts(obj);
            totalSize += size;

            content += new PrintfFormat("%-42.42s").sprintf(shortKey)
                + "  "
                + "Entries: "
                + form.sprintf(getItems(obj))
                + "   "
                + "Limit: "
                + form.sprintf(getLimit(obj))
                + "   "
                + "Size: "
                + form.sprintf(Long.toString(size))
                + "\n";
        }
        content += "\nTotal size of cache memory monitored: " + totalSize + " (" + totalSize / 1048576 + ")\n\n";

        String from = m_configuration.getEmailSender();
        List receivers = new ArrayList();
        List receiverEmails = m_configuration.getEmailReceiver();
        try {
            if (from != null && receiverEmails != null && !receiverEmails.isEmpty()) {
                Iterator i = receiverEmails.iterator();
                while (i.hasNext()) {
                    receivers.add(new InternetAddress((String)i.next()));
                }
                CmsSimpleMail email = new CmsSimpleMail();
                email.setFrom(from);
                email.setTo(receivers);
                email.setSubject(subject);
                email.setMsg(content);
                new CmsMailTransport(email).send();
            }
            if (LOG.isInfoEnabled()) {
                if (warning) {
                    LOG.info(Messages.get().getBundle().key(Messages.LOG_MM_WARNING_EMAIL_SENT_0));
                } else {
                    LOG.info(Messages.get().getBundle().key(Messages.LOG_MM_STATUS_EMAIL_SENT_0));
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    /**
     * Write a warning or status log entry with OpenCms Memory information.<p>
     * 
     * @param warning if true, write a memory warning log entry 
     */
    private void monitorWriteLog(boolean warning) {

        if (!LOG.isWarnEnabled()) {
            // we need at last warn level for this output
            return;
        } else if ((!warning) && (!LOG.isInfoEnabled())) {
            // if not warning we need info level
            return;
        } else if (warning
            && (m_warningLoggedSinceLastStatus && !(((m_intervalLog <= 0) && (System.currentTimeMillis() < (m_lastLogWarning + m_intervalWarning)))))) {
            // write no warning log if no status log has been written since the last warning
            // if status is disabled, log no warn entry if warn interval has not passed
            return;
        } else if ((!warning) && (m_intervalLog <= 0)) {
            // if log iterval is <= 0 status log is disabled
            return;
        }

        if (warning) {
            m_lastLogWarning = System.currentTimeMillis();
            m_warningLoggedSinceLastStatus = true;
            LOG.warn(Messages.get().getBundle().key(
                Messages.LOG_MM_WARNING_MEM_CONSUME_2,
                new Long(m_memoryCurrent.getUsage()),
                new Integer(m_maxUsagePercent)));
        } else {
            m_warningLoggedSinceLastStatus = false;
            m_lastLogStatus = System.currentTimeMillis();
        }

        if (warning) {
            LOG.warn(Messages.get().getBundle().key(
                Messages.LOG_MM_WARNING_MEM_STATUS_6,
                new Object[] {
                    new Long(m_memoryCurrent.getMaxMemory()),
                    new Long(m_memoryCurrent.getTotalMemory()),
                    new Long(m_memoryCurrent.getFreeMemory()),
                    new Long(m_memoryCurrent.getUsedMemory()),
                    new Long(m_memoryCurrent.getUsage()),
                    new Integer(m_maxUsagePercent)}));
        } else {

            m_logCount++;
            LOG.info(Messages.get().getBundle().key(
                Messages.LOG_MM_LOG_INFO_2,
                OpenCms.getSystemInfo().getServerName().toUpperCase(),
                String.valueOf(m_logCount)));

            List keyList = Arrays.asList(m_monitoredObjects.keySet().toArray());
            Collections.sort(keyList);
            long totalSize = 0;
            for (Iterator keys = keyList.iterator(); keys.hasNext();) {

                String key = (String)keys.next();
                Object obj = m_monitoredObjects.get(key);

                long size = getKeySize(obj) + getValueSize(obj) + getCosts(obj);
                totalSize += size;

                PrintfFormat name1 = new PrintfFormat("%-80s");
                PrintfFormat name2 = new PrintfFormat("%-50s");
                PrintfFormat form = new PrintfFormat("%9s");
                LOG.info(Messages.get().getBundle().key(
                    Messages.LOG_MM_NOWARN_STATUS_5,
                    new Object[] {
                        name1.sprintf(key),
                        name2.sprintf(obj.getClass().getName()),
                        form.sprintf(getItems(obj)),
                        form.sprintf(getLimit(obj)),
                        form.sprintf(Long.toString(size))}));
            }

            LOG.info(Messages.get().getBundle().key(
                Messages.LOG_MM_WARNING_MEM_STATUS_6,
                new Object[] {
                    new Long(m_memoryCurrent.getMaxMemory()),
                    new Long(m_memoryCurrent.getTotalMemory()),
                    new Long(m_memoryCurrent.getFreeMemory()),
                    new Long(m_memoryCurrent.getUsedMemory()),
                    new Long(m_memoryCurrent.getUsage()),
                    new Integer(m_maxUsagePercent),
                    new Long(totalSize),
                    new Long(totalSize / 1048576)})

            );
            LOG.info(Messages.get().getBundle().key(
                Messages.LOG_MM_WARNING_MEM_STATUS_AVG_6,
                new Object[] {
                    new Long(m_memoryAverage.getMaxMemory()),
                    new Long(m_memoryAverage.getTotalMemory()),
                    new Long(m_memoryAverage.getFreeMemory()),
                    new Long(m_memoryAverage.getUsedMemory()),
                    new Long(m_memoryAverage.getUsage()),
                    new Integer(m_memoryAverage.getCount())}));

            CmsSessionManager sm = OpenCms.getSessionManager();

            if (sm != null) {
                LOG.info(Messages.get().getBundle().key(
                    Messages.LOG_MM_SESSION_STAT_3,
                    String.valueOf(sm.getSessionCountAuthenticated()),
                    String.valueOf(sm.getSessionCountCurrent()),
                    String.valueOf(sm.getSessionCountTotal())));
            }
            sm = null;

            for (Iterator i = OpenCms.getSqlManager().getDbPoolNames().iterator(); i.hasNext();) {
                String poolname = (String)i.next();
                try {
                    LOG.info(Messages.get().getBundle().key(
                        Messages.LOG_MM_CONNECTIONS_3,
                        poolname,
                        Integer.toString(OpenCms.getSqlManager().getActiveConnections(poolname)),
                        Integer.toString(OpenCms.getSqlManager().getIdleConnections(poolname))));
                } catch (Exception exc) {
                    LOG.info(Messages.get().getBundle().key(
                        Messages.LOG_MM_CONNECTIONS_3,
                        poolname,
                        Integer.toString(-1),
                        Integer.toString(-1)));
                }
            }

            LOG.info(Messages.get().getBundle().key(
                Messages.LOG_MM_STARTUP_TIME_2,
                CmsDateUtil.getDateTimeShort(OpenCms.getSystemInfo().getStartupTime()),
                CmsStringUtil.formatRuntime(OpenCms.getSystemInfo().getRuntime())));
        }
    }

    /**
     * Updatres the memory information of the memory monitor.<p> 
     */
    private void updateStatus() {

        m_memoryCurrent.update();
        m_memoryAverage.calculateAverage(m_memoryCurrent);
    }
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美精品在线观看播放| 成人一级片网址| 制服.丝袜.亚洲.中文.综合| 亚洲最新视频在线播放| 在线亚洲免费视频| 亚洲一区在线观看网站| 88在线观看91蜜桃国自产| 免费在线一区观看| 久久中文娱乐网| 不卡区在线中文字幕| 亚洲老妇xxxxxx| 91精品国产一区二区人妖| 麻豆91精品视频| 中文字幕免费一区| 91福利在线播放| 日韩精品一二区| 国产欧美一区二区精品性色| 色综合欧美在线| 看电影不卡的网站| 中文一区在线播放| 欧美精选在线播放| 国产一区二区三区免费| 最近日韩中文字幕| 欧美一区二区精品| 成人精品视频一区二区三区尤物| 亚洲嫩草精品久久| 9191国产精品| 不卡视频免费播放| 麻豆精品在线看| 中文字幕亚洲视频| 日韩欧美成人激情| 色婷婷久久久亚洲一区二区三区| 日本在线不卡一区| 亚洲欧美影音先锋| 精品少妇一区二区三区在线播放| av成人免费在线观看| 人妖欧美一区二区| 亚洲欧美日韩国产手机在线| 欧美mv和日韩mv国产网站| 色综合久久久久综合99| 捆绑变态av一区二区三区| 一区二区三区在线观看动漫| 久久久久国产精品厨房| 欧美无砖砖区免费| aaa亚洲精品一二三区| 美女一区二区久久| 亚洲午夜电影在线| 国产精品久久久久久久久免费丝袜| 精品视频一区三区九区| 99久久99久久精品国产片果冻| 亚洲va在线va天堂| 亚洲欧美日韩国产综合在线| 久久精品综合网| 日韩一区二区在线看| 欧美性淫爽ww久久久久无| 国产福利91精品| 青青草国产成人99久久| 一区二区三区成人| 亚洲国产精品激情在线观看| 精品国产制服丝袜高跟| 欧美久久一二区| 欧美性色黄大片手机版| 91免费国产视频网站| 粉嫩av一区二区三区在线播放 | 丝袜亚洲精品中文字幕一区| 国产精品乱人伦| 国产亚洲一本大道中文在线| 日韩三级伦理片妻子的秘密按摩| 在线亚洲高清视频| 色av成人天堂桃色av| 99re视频精品| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 午夜视频一区二区| 伊人开心综合网| 亚洲欧美激情一区二区| 国产精品的网站| 中文字幕一区二区三区四区不卡| 精品裸体舞一区二区三区| 日韩精品影音先锋| 欧美成人官网二区| 精品免费一区二区三区| 欧美va在线播放| 久久精品在线观看| 国产精品人人做人人爽人人添| 国产精品网曝门| 久久嫩草精品久久久精品| 国产清纯白嫩初高生在线观看91| 中文字幕第一区综合| 中文字幕乱码亚洲精品一区| 最新国产精品久久精品| 亚洲精品乱码久久久久久久久 | 国产精品污www在线观看| 国产精品丝袜黑色高跟| 一区二区三区日韩欧美精品| 亚洲一区欧美一区| 免费观看91视频大全| 精品一区二区三区免费毛片爱| 国产在线视频精品一区| va亚洲va日韩不卡在线观看| 色八戒一区二区三区| 欧美一区二区三区系列电影| 日韩免费观看2025年上映的电影| 欧美精品一区二区精品网| 国产婷婷色一区二区三区四区 | 偷拍与自拍一区| 麻豆精品国产91久久久久久| 国产精品亚洲成人| 在线观看日韩电影| 欧美一区午夜视频在线观看| 久久精品人人做人人综合| 国产精品久久午夜| 日韩高清不卡一区| 国产东北露脸精品视频| 欧美撒尿777hd撒尿| 久久色在线观看| 一区二区三区中文字幕精品精品| 日韩不卡手机在线v区| 国产成a人亚洲精| 欧洲一区二区av| 久久久久一区二区三区四区| 一个色综合av| 国产在线一区二区| 在线视频综合导航| 久久蜜桃一区二区| 亚洲h在线观看| 成人午夜电影久久影院| 91精品国产欧美日韩| 国产精品美女久久久久久久网站| 日本vs亚洲vs韩国一区三区二区| caoporn国产一区二区| 欧美一级视频精品观看| 亚洲人成精品久久久久| 国产在线观看一区二区| 欧美日本在线播放| 自拍偷拍国产精品| 国产一区二区精品久久91| 在线视频国产一区| 亚洲国产精华液网站w| 精品在线一区二区| 欧美日韩成人在线| 亚洲精品午夜久久久| 成人小视频免费在线观看| 欧美一区二区三区影视| 亚洲成人黄色小说| 日本韩国欧美一区| 国产精品国产三级国产a| 国内精品免费**视频| 91精品免费在线| 亚洲大片在线观看| 日本韩国一区二区| 亚洲免费av高清| 91免费版在线| 亚洲欧洲精品一区二区三区不卡| 激情成人午夜视频| 欧美电影免费观看高清完整版在| 秋霞午夜鲁丝一区二区老狼| 色嗨嗨av一区二区三区| 国产精品久久久久aaaa| 高清不卡在线观看av| 久久久亚洲精品一区二区三区| 欧美aaaaa成人免费观看视频| 在线观看免费视频综合| 一区二区三区四区在线免费观看| 9l国产精品久久久久麻豆| 亚洲国产精品成人久久综合一区| 国产成人av在线影院| 久久精品综合网| 成人av在线资源网| 国产精品美女久久久久久久久久久| 国产91精品一区二区麻豆亚洲| 精品国产三级电影在线观看| 国产一区在线看| 国产亚洲欧美色| 不卡大黄网站免费看| 中文字幕一区二区三区在线观看| 波多野结衣亚洲| 最近中文字幕一区二区三区| 欧洲精品在线观看| 午夜欧美一区二区三区在线播放| 欧美美女激情18p| 日本美女一区二区| 久久久久国产精品厨房| av亚洲精华国产精华| 亚洲成人一二三| 欧美成人bangbros| 国产 欧美在线| **性色生活片久久毛片| 欧美视频一区在线| 日本亚洲免费观看| 久久久久久一二三区| 99久久国产免费看| 日韩综合在线视频| 久久久久88色偷偷免费| 色妞www精品视频| 五月婷婷另类国产| 久久久久国产精品麻豆ai换脸| a美女胸又www黄视频久久| 性久久久久久久| 国产女人水真多18毛片18精品视频 | 欧美大胆人体bbbb|