RequestProcessor.java 1.3 KB

1234567891011121314151617181920212223242526272829303132333435
  1. /*
  2. * Copyright 2008, Yahoo! Inc.
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. package com.yahoo.zookeeper.server;
  17. /**
  18. * RequestProcessors are chained together to process transactions. Requests are
  19. * always processed in order. The standalone server, follower, and leader all
  20. * have slightly different RequestProcessors changed together.
  21. *
  22. * Requests always move forward through the chain of RequestProcessors. Requests
  23. * are passed to a RequestProcessor through processRequest(). Generally method
  24. * will always be invoked by a single thread.
  25. *
  26. * When shutdown is called, the request RequestProcessor should also shutdown
  27. * any RequestProcessors that it is connected to.
  28. */
  29. public interface RequestProcessor {
  30. void processRequest(Request request);
  31. void shutdown();
  32. }