Package org.rhq.enterprise.communications.util

Examples of org.rhq.enterprise.communications.util.ConcurrencyManager$Permit


        if (persist) {
            persistServerProperty(limitName, String.valueOf(maxConcurrency));
        }

        ConcurrencyManager concurrencyManager = getServiceContainer().getConcurrencyManager();
        Map<String, Integer> limits = concurrencyManager.getAllConfiguredNumberOfPermitsAllowed();
        limits.put(limitName, maxConcurrency);

        getServiceContainer().setConcurrencyManager(new ConcurrencyManager(limits));

        LOG.info(ServerI18NResourceKeys.NEW_CONCURRENCY_LIMIT, limitName, maxConcurrency);
    }
View Full Code Here


        ServiceContainerConfigurationUpgrade.upgradeToLatest(m_configuration.getPreferences());

        // if a concurrency manager was not provided yet, create one. if a global concurrency limit
        // was defined, add our listener that will drop commands when the limit is exceeded
        if (m_concurrencyManager == null) {
            m_concurrencyManager = new ConcurrencyManager(null);
        }

        Integer globalConcurrencyLimit = m_configuration.getGlobalConcurrencyLimit();
        if (globalConcurrencyLimit > 0) {
            // create a new concurrency manager, add our global concurrency limit and replace the existing manager
            Map<String, Integer> limits = m_concurrencyManager.getAllConfiguredNumberOfPermitsAllowed();
            limits.put(GlobalConcurrencyLimitCommandListener.CONCURRENCY_LIMIT_NAME, globalConcurrencyLimit);
            m_concurrencyManager = new ConcurrencyManager(limits);

            // add our listener that will drop commands if we reach our limit
            addCommandListener(new GlobalConcurrencyLimitCommandListener(this));
            LOG.info(CommI18NResourceKeys.GLOBAL_CONCURRENCY_LIMIT_SET, globalConcurrencyLimit);
        } else {
View Full Code Here

        ServiceContainer sc = new ServiceContainer();
        sc.start(prefs, new ClientCommandSenderConfiguration());
        Map<String, Integer> map = sc.getConcurrencyManager().getAllConfiguredNumberOfPermitsAllowed();
        map.put("limited", 10);
        sc.setConcurrencyManager(new ConcurrencyManager(map));

        Thread.sleep(5000);

        AtomicInteger counter = new AtomicInteger(0);
        CountDownLatch latch = new CountDownLatch(1);
View Full Code Here

        Permit permit = null;
        Method pojo_method = null;

        RemotePojoInvocationCommandResponse response;

        ConcurrencyManager concurrency_manager = getServiceContainer().getConcurrencyManager();

        try {
            // look up the remote POJO that has the target interface
            Object pojo = m_remotedPojos.get(target_interface_name);

            if (pojo == null) {
                throw new NoSuchMethodException(LOG.getMsgString(CommI18NResourceKeys.NO_POJO_SERVICE, command));
            }

            for (int x = 0; x < signature.length; x++) {
                class_signature[x] = ClassUtil.getClassFromTypeName(signature[x]);
            }

            // If the remote POJO interface method has limited concurrency allowed, we need to make
            // sure we have permission to invoke that method. None of these calls should throw an exception.
            Class<?> target_interface = Class.forName(target_interface_name);
            Method target_method = target_interface.getMethod(method_name, class_signature);
            LimitedConcurrency limited_concurrency = target_method.getAnnotation(LimitedConcurrency.class);
            if ((limited_concurrency != null) && (concurrency_manager != null)) {
                permit = concurrency_manager.getPermit(limited_concurrency.value());
            }

            // if a parameter is a remote stream, we have to create a sender for it to use
            // this is needed in case the remote server that is serving the stream data requires SSL - in that
            // case, our sender needs to have SSL configured properly
            for (int x = 0; x < signature.length; x++) // yes use signature, not param - avoids possible NPE
            {
                if (params[x] instanceof RemoteInputStream) {
                    prepareRemoteInputStream((RemoteInputStream) params[x]);
                } else if (params[x] instanceof RemoteOutputStream) {
                    prepareRemoteOutputStream((RemoteOutputStream) params[x]);
                }
            }

            // use reflection to make the call
            pojo_method = pojo.getClass().getMethod(method_name, class_signature);
            Object response_object = pojo_method.invoke(pojo, params);

            response = new RemotePojoInvocationCommandResponse(remote_pojo_command, response_object);
        } catch (InvocationTargetException e) {
            // we want to make sure we keep the exception as intact as possible
            // so we still want to put the invocation target exception in the response,
            // but that is a java.* exception, so we need to drill down into the cause and wrap that if need be
            Throwable response_exception;

            if (e.getCause() != null) {
                response_exception = new InvocationTargetException(getWrappedException(e.getCause(), pojo_method), e
                    .getMessage());
            } else {
                response_exception = getWrappedException(e, pojo_method);
            }

            response = new RemotePojoInvocationCommandResponse(remote_pojo_command, response_exception);
        } catch (NotPermittedException npe) {
            LOG.debug(CommI18NResourceKeys.COMMAND_NOT_PERMITTED, target_interface_name + '.' + method_name, npe
                .getSleepBeforeRetry());
            response = new RemotePojoInvocationCommandResponse(remote_pojo_command, npe);
        } catch (Exception e) {
            LOG.warn(e, CommI18NResourceKeys.REMOTE_POJO_EXECUTE_FAILURE);
            response = new RemotePojoInvocationCommandResponse(remote_pojo_command, getWrappedException(e, pojo_method));
        } finally {
            if (concurrency_manager != null) {
                concurrency_manager.releasePermit(permit);
            }
        }

        return response;
    }
View Full Code Here

        ServiceContainer sc = new ServiceContainer();
        sc.start(prefs, new ClientCommandSenderConfiguration());
        Map<String, Integer> map = sc.getConcurrencyManager().getAllConfiguredNumberOfPermitsAllowed();
        map.put("limitedTimeout", 10);
        sc.setConcurrencyManager(new ConcurrencyManager(map));
        Thread.sleep(5000);

        AtomicInteger counter = new AtomicInteger(0);
        CountDownLatch latch = new CountDownLatch(1);
        LimitedConcurrencyPojo pojoImpl = new LimitedConcurrencyPojo(counter, latch);
View Full Code Here

TOP

Related Classes of org.rhq.enterprise.communications.util.ConcurrencyManager$Permit

Copyright © 2018 www.massapicom. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.