1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
|
h2. Active Support Instrumentation
Active Support is a part of core Rails that provides Ruby language extensions, utilities and other things. One of the things it includes is an instrumentation API that can be used inside an application to measure certain actions that occur within Ruby code, such as that inside a Rails application or the framework itself. It is not limited to Rails, however. It can be used independently in other Ruby scripts if it is so desired.
In this guide, you will learn how to use the instrumentation API inside of ActiveSupport to measure events inside of Rails and other Ruby code. We cover:
* What instrumentation can provide
* The hooks inside the Rails framework for instrumentation
* Adding a subscriber to a hook
* Building a custom instrumentation implementation
endprologue.
h3. Introduction to instrumentation
The instrumentation API provided by ActiveSupport allows developers to provide hooks which other developers may hook into. There are several of these within the Rails framework, as described below in <TODO: link to section detailing each hook point>. With this API, developers can choose to be notified when certain events occur inside their application or another piece of Ruby code.
For example, there is a hook provided within Active Record that is called every time Active Record uses a SQL query on a database. This hook could be *subscribed* to, and used to track the number of queries during a certain action. There's another hook around the processing of an action of a controller. This could be used, for instance, to track how long a specific action has taken.
You are even able to create your own events inside your application which you can later subscribe to.
h3. Rails framework hooks
Within the Ruby on Rails framework, there are a number of hooks provided for common events. These are detailed below.
h4. Action Mailer
h5. receive.action_mailer
This hook is called when the +receive+ method of an +ActionMailer::Base+ class is called:
<ruby>
class Mailer < ActionMailer::Base
def receive(mail)
end
end
</ruby>
The payload for this event has the following parameters related to the incoming email:
|_.Key |_.Value|
|mailer |Name of the mailer class|
|message_id |ID of the message, generated by the Mail gem|
|subject |Subject of the mail|
|to |To address(es) of the mail|
|from |From address of the mail|
|bcc |BCC addresses of the mail|
|cc |CC addresses of the mail|
|date |Date of the mail|
|mail |The encoded form of the mail|
h5. deliver.action_mailer
This hook is called when the +deliver+ method is called on a +Mail::Message+ object. This is due to a hook inserted by Action Mailer, rather than a specific feature of the Mail gem itself.
The payload for this event has the following parameters related to the outgoing email:
|_.Key |_.Value|
|mailer |Name of the mailer class|
|message_id |ID of the message, generated by the Mail gem|
|subject |Subject of the mail|
|to |To address(es) of the mail|
|from |From address of the mail|
|bcc |BCC addresses of the mail|
|cc |CC addresses of the mail|
|date |Date of the mail|
|mail |The encoded form of the mail|
h4. Action Controller
h4. Action View
h4. Active Record
h4. Active Resource
h4. Active Support
h3. Subscribing to an event
h3. Creating custom events
|