forked from cloudfoundry/docs-bosh
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvm-monit.html.md.erb
105 lines (75 loc) · 4.69 KB
/
vm-monit.html.md.erb
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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
---
title: Process monitoring with Monit
---
The Agent on each deployment job VM is responsible for managing lifecycle of each enabled release job. It starts, monitors, restarts and stops release jobs' processes. These tasks are done with the help of the [Monit](http://mmonit.com/monit/). The Agent communicates with the Monit daemon through Monit HTTP APIs to add, remove, start, stop, monitor and unmonitor release jobs' processes.
---
## <a id="check-status"></a> Check Status
Assuming you have a deployment, run `bosh instances` to see aggregate status for each deployment job VM:
<pre class="terminal">
$ bosh instances
Deployment `my-deployment'
Director task 10326
Task 10326 done
+----------------+---------+---------------+-------------+
| Instance | State | Resource Pool | IPs |
+----------------+---------+---------------+-------------+
| redis-master/0 | running | redis-servers | 10.10.30.71 |
| redis-slave/0 | running | redis-servers | 10.10.30.72 |
| redis-slave/1 | failing | redis-servers | 10.10.30.73 |
+----------------+---------+---------------+-------------+
</pre>
There are 3 possible state values:
- `running`: the Director received response from the Agent and the Agent reported its aggregate status as successful. Running state indicates that all release jobs' processes are successfully running at that moment.
- `failing`: the Director received response from the Agent and the Agent reported its aggregate status as not successful. Failing state indicatates _one_ of the release jobs' processes is not successfully running (could be failing to start, or exiting after some time, etc.).
- `unresponsive`: the Director did not receive any response from the Agent
To determine what the problem is with a specific VM, you can ssh into the VM and look at the logs and/or Monit directly.
---
## <a id="using-monit"></a> Using Monit on the VM
On any BOSH managed VM, you can access Monit status for release jobs' processes via Monit CLI. Before you can run the command you have to switch to become a `root` user (via `sudo su`) since Monit executable is only available to root users.
Each enabled release job has its own directory in `/var/vcap/jobs/` directory. Each release job directory contains a monit file (e.g. `/var/vcap/jobs/redis-server/monit`) with final monit configuration for that release job. This is how you can tell which processes belong to which release job. Most release job only start a single process.
<p class="note">Note: Monit configuration file in release job directory is just a copy of the actual Monit configuration. Changing it will not affect running Monit configuration.</p>
To view status for all processes Monit is managing you can run `monit summary`:
<pre class="terminal">
$ monit summary
The Monit daemon 5.2.4 uptime: 1d 22h 7m
Process 'nats' running
Process 'redis' running
Process 'postgres' running
Process 'powerdns' running
Process 'blobstore_nginx' running
Process 'director' running
Process 'worker_1' running
Process 'worker_2' running
Process 'worker_3' running
Process 'director_scheduler' running
Process 'director_nginx' running
Process 'registry' running
Process 'health_monitor' running
System 'system_bm-24638eb6-55b9-4670-bb1a-23c9e3f77d91' running
</pre>
<p class="note">Note: You can use standard <code>watch</code> utility with the summary command to track process status over time.</p>
You can also get more detailed information about individual processes via `monit status`:
<pre class="terminal">
$ monit status
The Monit daemon 5.2.4 uptime: 1d 22h 8m
Process 'nats'
status running
monitoring status monitored
pid 2951
parent pid 1
uptime 1d 22h 8m
children 0
memory kilobytes 24420
memory kilobytes total 24420
memory percent 0.6%
memory percent total 0.6%
cpu percent 0.0%
cpu percent total 0.0%
data collected Thu Dec 4 22:44:36 2014
...
</pre>
While debugging why certain process is failing it is usually useful to tell Monit to stop restarting the failing process. You can do so via `monit stop <process-name>` command. To start it back up use `monit start <process-name>` command.
See [Monit manual](http://mmonit.com/monit/documentation/monit.html) to learn more about Monit.
---
Next: [Manual repair with Cloud Check](cck.html)
Previous: [Monitoring](monitoring.html)