hadooprpc.btm 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. # Licensed to the Apache Software Foundation (ASF) under one or more
  2. # contributor license agreements. See the NOTICE file distributed with
  3. # this work for additional information regarding copyright ownership.
  4. # The ASF licenses this file to You under the Apache License, Version 2.0
  5. # (the "License"); you may not use this file except in compliance with
  6. # the License. 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. # This script instruments hadoop rpc layer to print out all the request/response messages to the standard output.
  17. #
  18. RULE Hadoop RPC request
  19. INTERFACE ^com.google.protobuf.BlockingService
  20. METHOD callBlockingMethod
  21. IF true
  22. DO traceln("--> RPC message request: " + $3.getClass().getSimpleName() + " from " + linked(Thread.currentThread(), "source"));
  23. traceln($3.toString())
  24. ENDRULE
  25. RULE Hadoop RPC response
  26. INTERFACE ^com.google.protobuf.BlockingService
  27. METHOD callBlockingMethod
  28. AT EXIT
  29. IF true
  30. DO traceln("--> RPC message response: " + $3.getClass().getSimpleName() + " to " + unlink(Thread.currentThread(), "source"));
  31. traceln($!.toString())
  32. ENDRULE
  33. RULE Hadoop RPC source IP
  34. CLASS org.apache.hadoop.ipc.Server$RpcCall
  35. METHOD run
  36. IF true
  37. DO link(Thread.currentThread(), "source", $0.connection.toString())
  38. ENDRULE