Как следить за пассажиром nginx с помощью монитора - PullRequest
4 голосов
/ 05 ноября 2010

У меня есть несколько приложений rails, развернутых nginx passenger.Я хочу, чтобы эти приложения отслеживались с помощью monit.Как я могу контролировать эти приложения, используя monit?Должен ли я контролировать nginx?

Ответы [ 3 ]

3 голосов
/ 28 апреля 2011

Вот как я это решил. Сначала я добавил в application.rb:


# Monit support
if defined?(PhusionPassenger)
  require 'pidfile_manager'
  PhusionPassenger.on_event(:starting_worker_process) do |forked|
    if forked
      # We're in smart spawning mode.
      PidfileManager.write_pid_file
    else
      # We're in conservative spawning mode. We don't need to do anything.
    end
  end

  PhusionPassenger.on_event(:stopping_worker_process) do
    PidfileManager.remove_pid_file
  end
end

и затем я реализовал PidfileManager:


module PidfileManager
  extend self

  BASENAME = '/var/tmp/rack.*.pid'

  def write_pid_file
    pid = Process.pid
    count = 1
    pidfile = nil
    go_over_pid_files do |file, saved_pid|
      file_id = file[/(\d+)/,1].to_i
      # Increase counter only if we met the same file id
      count += 1 if file_id == count
      # We're already there
      return if saved_pid == pid
      # Check if the process is alive
      res = begin
        Process.kill(0, saved_pid)
      rescue Errno::ESRCH
        nil
      end
      # It's dead, reuse
      unless res
        pidfile = file
        break
      end
    end
    pidfile ||= BASENAME.sub('*', count.to_s)
    File.open(pidfile, 'w') {|f| f.write(pid.to_s)}
  end

  def remove_pid_file
    pid = Process.pid
    go_over_pid_files do |file, saved_pid|
      if pid == saved_pid
        File.unlink(file)
        break
      end
    end
  end

  private
  def go_over_pid_files
    Dir[BASENAME].each do |file|
      saved_pid = File.read(file).to_i
      yield file, saved_pid
    end
  end

end

А затем вы просто указываете monit отслеживать каждый экземпляр, используя /var/tmp/rack.X.pid в качестве pid-файла.

2 голосов
/ 24 июня 2015

Не уверен, что уже слишком поздно публиковать это, но вот как я использую monit (5.14), чтобы остановить приложения пассажирских рельсов, занимающие слишком много памяти:

монит:

check program ourapp_live with path     "/usr/local/bin/check_passenger_mem_usage ourapp 500" as "ourappuser"
 if status != 0 then alert
 if status != 0 then restart
 start program = "/bin/touch /var/www/vhosts/ourapp/railsapp/current/tmp/restart.txt"
 stop program = "/bin/true"

Сценарий отслеживания вызовов оболочки (check_passenger_mem_usage):

#!/bin/bash
#
#
USER=$1
TRIGGER=$2

if [ -z $USER ] || [ -z $TRIGGER ]
then
    echo "missing args"
    echo "usage:"
    echo "         check_passenger_mem_usage username alert_threshold"
    echo
    echo "(alert_threshold is in mb)"
    echo
    exit 1
fi

MAX=`/usr/local/rvm/gems/ruby-1.8.7-p357/wrappers/passenger-memory-stats | grep $USER | awk '{print $2}' | sort -n | tail -1|cut -d. -f1`

if [ "$MAX" -gt $TRIGGER ]
then
    echo
    echo "${USER}: We got a runaway! Gobbling ${MAX} mb"
    echo
    exit 1
else
    echo
    echo "Max is ${MAX}"
    exit 0
fi

Возможно, это не лучшее решение, поскольку оно перезапускает все приложение rails, но, по крайней мере, оно предотвращает использование рельсами огромных объемов памяти, если приложение время от времени занимает мало памяти.

0 голосов
/ 18 апреля 2011

Если вы хотите, чтобы они работали и перезагружались при возникновении ошибки, возможно, вам лучше взглянуть на supervisord . Вместо того, чтобы опросить, запущен ли процесс, supervisord фактически запускает сам процесс. Демонам, которые он запускает, нужно запустить передний план, чтобы он работал, но он очень эффективен и будет запускать сервисы гораздо быстрее, чем monit (monit обычно опрашивает каждую минуту, в то время как supervisord видит процесс завершенным и перезапускает его немедленно). 1003 *

Мы используем supervisord в производственном процессе, запустив все наши демоны (nginx, beanstalkd, memcached, различные службы python и т. Д.), А затем используем monit для мониторинга supervisord в качестве дополнительной резервной копии.

...