All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.red5.server.stream.ITokenBucket Maven / Gradle / Ivy

/*
 * RED5 Open Source Media Server - https://github.com/Red5/
 * 
 * Copyright 2006-2016 by respective authors (see below). All rights reserved.
 * 
 * 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 org.red5.server.stream;

/**
 * Basically token bucket is used to control the bandwidth used by a stream or a connection or a client. There's a background thread that distributes tokens to the buckets in the system according to the configuration of the bucket. The configuration includes how fast the tokens are distributed. When a stream, for example, needs to send out a packet, the packet's byte count is calculated and each byte corresponds to a
 * token in the bucket. The stream is assigned a bucket and the tokens in the bucket are acquired before the packet can be sent out. So if the speed(or bandwidth) in configuration is low, the stream can't send out packets fast.
 * 
 * @author The Red5 Project
 * @author Steven Gong ([email protected])
 */
public interface ITokenBucket {
    /**
     * Acquire tokens amount of tokenCount waiting wait milliseconds if token not available.
     * 
     * @param tokenCount
     *            The count of tokens to acquire.
     * @param wait
     *            Milliseconds to wait. 0 means no wait and any value below zero means wait forever.
     * @return true if successfully acquired or false if not acquired.
     */
    boolean acquireToken(long tokenCount, long wait);

    /**
     * Nonblockingly acquire token. If the token is not available and task is not null, the callback will be executed when the token is available. The tokens are not consumed automatically before callback, so it's recommended to acquire token again in callback function.
     * 
     * @param tokenCount
     *            Number of tokens
     * @param callback
     *            Callback
     * @return true if successfully acquired or false if not acquired.
     */
    boolean acquireTokenNonblocking(long tokenCount, ITokenBucketCallback callback);

    /**
     * Nonblockingly acquire token. The upper limit is specified. If not enough tokens are left in bucket, all remaining will be returned.
     * 
     * @param upperLimitCount
     *            Upper limit of aquisition
     * @return Remaining tokens from bucket
     */
    long acquireTokenBestEffort(long upperLimitCount);

    /**
     * Get the capacity of this bucket in Byte.
     * 
     * @return Capacity of this bucket in bytes
     */
    long getCapacity();

    /**
     * The amount of tokens increased per millisecond.
     * 
     * @return Amount of tokens increased per millisecond.
     */
    double getSpeed();

    /**
     * Reset this token bucket. All pending threads are woken up with false returned for acquiring token and callback is removed without calling back.
     */
    void reset();

    /**
     * Callback for tocket bucket
     */
    public interface ITokenBucketCallback {
        /**
         * Being called when the tokens requested are available.
         * 
         * @param bucket
         *            Bucket
         * @param tokenCount
         *            Number of tokens
         */
        void available(ITokenBucket bucket, long tokenCount);

        /**
         * Resets tokens in bucket
         * 
         * @param bucket
         *            Bucket
         * @param tokenCount
         *            Number of tokens
         */
        void reset(ITokenBucket bucket, long tokenCount);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy