Commit 89bbc2c3 authored by Ge Jun's avatar Ge Jun

Simplify interface of ConcurrencyLimiter

parent 5e1cabb1
...@@ -24,15 +24,15 @@ ...@@ -24,15 +24,15 @@
namespace brpc { namespace brpc {
class ConcurrencyLimiter : public Destroyable { class ConcurrencyLimiter {
public: public:
ConcurrencyLimiter() : _max_concurrency(0) {} virtual ~ConcurrencyLimiter() {}
// This method should be called each time a request comes in. It returns // This method should be called each time a request comes in. It returns
// false when the concurrency reaches the upper limit, otherwise it // false when the concurrency reaches the upper limit, otherwise it
// returns true. Normally, when OnRequested returns false, you should // returns true. Normally, when OnRequested returns false, you should
// return an ELIMIT error directly. // return an ELIMIT error directly.
virtual bool OnRequested() = 0; virtual bool OnRequested(int current_concurrency) = 0;
// Each request should call this method before responding. // Each request should call this method before responding.
// `error_code' : Error code obtained from the controller, 0 means success. // `error_code' : Error code obtained from the controller, 0 means success.
...@@ -41,29 +41,13 @@ public: ...@@ -41,29 +41,13 @@ public:
// still need to call OnResponded. // still need to call OnResponded.
virtual void OnResponded(int error_code, int64_t latency_us) = 0; virtual void OnResponded(int error_code, int64_t latency_us) = 0;
// Returns the current maximum concurrency. Note that the maximum // Returns the latest max_concurrency.
// concurrency of some ConcurrencyLimiters(eg: `auto', `gradient') // The return value is only for logging.
// is dynamically changing. virtual int MaxConcurrency() = 0;
int max_concurrency() { return _max_concurrency; };
// Expose internal vars. NOT thread-safe.
// Return 0 on success, -1 otherwise.
virtual int Expose(const butil::StringPiece& prefix) = 0;
// Create/destroy an instance.
// Caller is responsible for Destroy() the instance after usage.
virtual ConcurrencyLimiter* New() const = 0;
virtual ~ConcurrencyLimiter() {}
// Create ConcurrencyLimiter* and coredump if it fails.
// Caller is responsible for Destroy() the instance after usage.
static ConcurrencyLimiter* CreateConcurrencyLimiterOrDie(
const AdaptiveMaxConcurrency& max_concurrency);
protected: // Create an instance from the amc
// Assume int32_t is atomic in x86 // Caller is responsible for delete the instance after usage.
int32_t _max_concurrency; virtual ConcurrencyLimiter* New(const AdaptiveMaxConcurrency& amc) const = 0;
}; };
inline Extension<const ConcurrencyLimiter>* ConcurrencyLimiterExtension() { inline Extension<const ConcurrencyLimiter>* ConcurrencyLimiterExtension() {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment