1. Список говнокодов пользователя munin

    Всего: 55

  2. Perl / Говнокод #22383

    −98

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    11. 11
    12. 12
    13. 13
    14. 14
    15. 15
    16. 16
    17. 17
    18. 18
    19. 19
    20. 20
    21. 21
    22. 22
    23. 23
    24. 24
    25. 25
    26. 26
    27. 27
    28. 28
    29. 29
    30. 30
    31. 31
    32. 32
    33. 33
    34. 34
    35. 35
    36. 36
    37. 37
    38. 38
    39. 39
    40. 40
    41. 41
    42. 42
    43. 43
    44. 44
    45. 45
    46. 46
    47. 47
    48. 48
    49. 49
    50. 50
    51. 51
    52. 52
    53. 53
    54. 54
    55. 55
    56. 56
    57. 57
    58. 58
    59. 59
    60. 60
    61. 61
    62. 62
    63. 63
    64. 64
    65. 65
    66. 66
    67. 67
    68. 68
    69. 69
    70. 70
    71. 71
    #!/usr/bin/env perl
    
    # Parameters supported:
    #
    # config
    # autoconf
    #
    # Magic markers:
    #%# family=auto
    #%# capabilities=autoconf
    
    use strict;
    use warnings;
    use LWP;
    use JSON qw/decode_json/;
    
    =head1 NAME
    elasticsearch_jvm_memory - A munin plugin that collects JVM memory stats from the JVM of your elasticsearch instances
    =head1 APPLICABLE SYSTEMS
    Elasticsearch
    =head1 CONFIGURATION
    None
    =head1 BUGS
    None known so far. If you find any, let me know.
    =head1 AUTHOR
    Tomas Doran (t0m) - c<< <[email protected]> >>
    Kentaro Yoshida - https://github.com/y-ken
    =cut
    
    my $host = exists $ENV{'host'} ? $ENV{'host'} : 'localhost';
    my $port = exists $ENV{'port'} ? $ENV{'port'} : 9200;
    
    my $ua = LWP::UserAgent->new;
    $ua->timeout(10);
    
    sub get_json_from_url {
        my $uri = shift;
        my $res = $ua->get($uri, 'Content-Type' => 'application/json' );
        Carp::confess($res->code . " for " . $uri) unless $res->is_success;
        my $data = do { local $@; eval { decode_json($res->content) } };
        die("Could not decode JSON from: " . $res->content) unless $data;
        return $data;
    }
    
    my $data = get_json_from_url("http://$host:$port/_nodes/_local/stats/jvm");
    my %out = (heap_max => 0, heap_committed => 0, heap_used => 0, non_heap_committed => 0, non_heap_used => 0);
    
    foreach my $full_node_name (keys %{$data->{nodes}}) {
        next unless $data->{nodes}{$full_node_name};
        foreach my $name (grep { /_in_bytes$/ } keys %{ $data->{nodes}{$full_node_name}{jvm}{mem} }) {
            my ($dname) = $name =~ m/(.+)_in_bytes$/;
            $out{$dname} += $data->{nodes}{$full_node_name}{jvm}{mem}{$name};
        }
    }
    if ($ARGV[0] and $ARGV[0] eq 'config') {
        print "graph_args --base 1024\n";
        print "graph_title Elasticsearch JVM memory usage\n";
        print "graph_category elasticsearch\n";
        print "graph_vlabel Bytes\n";
    
        foreach my $name (keys %out) {
            print "$name.label $name\n"."$name.type GAUGE\n";
        }
    }
    elsif (!$ARGV[0] || $ARGV[0] eq 'autoconf') {
        foreach my $name (keys %out) {
            print "$name.value " . $out{$name} . "\n";
        }
    }
    
    exit(0);

    munin, 19 Февраля 2017

    Комментарии (0)
  3. Perl / Говнокод #22382

    −98

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    11. 11
    12. 12
    13. 13
    14. 14
    15. 15
    16. 16
    17. 17
    18. 18
    19. 19
    20. 20
    21. 21
    22. 22
    23. 23
    24. 24
    25. 25
    26. 26
    27. 27
    28. 28
    29. 29
    30. 30
    31. 31
    32. 32
    33. 33
    34. 34
    35. 35
    36. 36
    37. 37
    38. 38
    39. 39
    40. 40
    41. 41
    42. 42
    43. 43
    44. 44
    45. 45
    46. 46
    47. 47
    48. 48
    49. 49
    50. 50
    51. 51
    52. 52
    53. 53
    54. 54
    55. 55
    56. 56
    57. 57
    58. 58
    59. 59
    60. 60
    61. 61
    62. 62
    63. 63
    64. 64
    65. 65
    66. 66
    67. 67
    68. 68
    69. 69
    70. 70
    71. 71
    72. 72
    73. 73
    74. 74
    75. 75
    76. 76
    77. 77
    78. 78
    79. 79
    80. 80
    81. 81
    82. 82
    83. 83
    84. 84
    85. 85
    86. 86
    87. 87
    88. 88
    89. 89
    #!/usr/bin/env perl
    
    # Parameters supported:
    #
    # config
    # autoconf
    #
    # Magic markers:
    #%# family=auto
    #%# capabilities=autoconf
    
    use strict;
    use warnings;
    use LWP;
    use JSON qw/decode_json/;
    
    =head1 NAME
    elasticsearch_index_total - A munin plugin that collects stats about the index totals
    =head1 APPLICABLE SYSTEMS
    Elasticsearch
    =head1 CONFIGURATION
    None
    =head1 BUGS
    None known so far. If you find any, let me know.
    =head1 AUTHOR
    Kentaro Yoshida - https://github.com/y-ken
    =cut
    
    my $host = exists $ENV{'host'} ? $ENV{'host'} : 'localhost';
    my $port = exists $ENV{'port'} ? $ENV{'port'} : 9200;
    
    my $ua = LWP::UserAgent->new;
    $ua->timeout(10);
    
    sub get_json_from_url {
        my $uri = shift;
        my $res = $ua->get($uri, 'Content-Type' => 'application/json' );
        Carp::confess($res->code . " for " . $uri) unless $res->is_success;
        my $data = do { local $@; eval { decode_json($res->content) } };
        die("Could not decode JSON from: " . $res->content) unless $data;
        return $data;
    }
    
    my $data = get_json_from_url("http://$host:$port/_nodes");
    my $t_data = get_json_from_url("http://$host:$port/_nodes/stats");
    my %out;
    
    foreach my $full_node_name (keys %{$data->{nodes}}) {
        next unless $t_data->{nodes}{$full_node_name};
        $out{index} += $t_data->{nodes}{$full_node_name}{indices}{indexing}{index_total};
        $out{get} += $t_data->{nodes}{$full_node_name}{indices}{get}{total};
        $out{search} += $t_data->{nodes}{$full_node_name}{indices}{search}{query_total};
        $out{delete} += $t_data->{nodes}{$full_node_name}{indices}{indexing}{delete_total};
    }
    if ($ARGV[0] and $ARGV[0] eq 'config') {
        print "graph_title Elasticsearch index operations\n";
        print "graph_category elasticsearch\n";
        print "graph_args --base 1000 -l 0\n";
        print "graph_vlabel Operations per second\n";
    
        print "graph_order index get search delete\n";
        print "index.label index\n";
        print "index.type DERIVE\n";
        print "index.min 0\n";
        print "index.draw LINE2\n";
    
        print "get.label get\n";
        print "get.type DERIVE\n";
        print "get.min 0\n";
        print "get.draw LINE2\n";
    
        print "search.label search\n";
        print "search.type DERIVE\n";
        print "search.min 0\n";
        print "search.draw LINE2\n";
    
        print "delete.label delete\n";
        print "delete.type DERIVE\n";
        print "delete.min 0\n";
        print "delete.draw LINE2\n";
    
    }
    elsif (!$ARGV[0] || $ARGV[0] eq 'autoconf') {
        foreach my $name (keys %out) {
            print "$name.value " . $out{$name} . "\n";
        }
    }
    
    exit(0);

    munin, 19 Февраля 2017

    Комментарии (0)
  4. Perl / Говнокод #22381

    −99

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    11. 11
    12. 12
    13. 13
    14. 14
    15. 15
    16. 16
    17. 17
    18. 18
    19. 19
    20. 20
    21. 21
    22. 22
    23. 23
    24. 24
    25. 25
    26. 26
    27. 27
    28. 28
    29. 29
    30. 30
    31. 31
    32. 32
    33. 33
    34. 34
    35. 35
    36. 36
    37. 37
    38. 38
    39. 39
    40. 40
    41. 41
    42. 42
    43. 43
    44. 44
    45. 45
    46. 46
    47. 47
    48. 48
    49. 49
    50. 50
    51. 51
    52. 52
    53. 53
    54. 54
    55. 55
    56. 56
    57. 57
    58. 58
    59. 59
    60. 60
    61. 61
    62. 62
    63. 63
    64. 64
    65. 65
    66. 66
    67. 67
    68. 68
    69. 69
    #!/usr/bin/env perl
    
    # Parameters supported:
    #
    # config
    # autoconf
    #
    # Magic markers:
    #%# family=auto
    #%# capabilities=autoconf
    
    use strict;
    use warnings;
    use LWP;
    use JSON qw/decode_json/;
    
    =head1 NAME
    elasticsearch_index_size - A munin plugin that collects index size of your elasticsearch instances
    =head1 APPLICABLE SYSTEMS
    Elasticsearch
    =head1 CONFIGURATION
    None
    =head1 BUGS
    None known so far. If you find any, let me know.
    =head1 AUTHOR
    Tomas Doran (t0m) - c<< <[email protected]> >>
    Kentaro Yoshida - https://github.com/y-ken
    =cut
    
    my $host = exists $ENV{'host'} ? $ENV{'host'} : 'localhost';
    my $port = exists $ENV{'port'} ? $ENV{'port'} : 9200;
    
    my $ua = LWP::UserAgent->new;
    $ua->timeout(10);
    
    sub get_json_from_url {
        my $uri = shift;
        my $res = $ua->get($uri, 'Content-Type' => 'application/json' );
        Carp::confess($res->code . " for " . $uri) unless $res->is_success;
        my $data = do { local $@; eval { decode_json($res->content) } };
        die("Could not decode JSON from: " . $res->content) unless $data;
        return $data;
    }
    
    my $data = get_json_from_url("http://$host:$port/_nodes");
    my $t_data = get_json_from_url("http://$host:$port/_nodes/stats");
    my %out = (index_size => 0);
    
    foreach my $full_node_name (keys %{$data->{nodes}}) {
        next unless $t_data->{nodes}{$full_node_name};
        $out{index_size} += $t_data->{nodes}{$full_node_name}{indices}{store}{size_in_bytes};
    }
    if ($ARGV[0] and $ARGV[0] eq 'config') {
        print "graph_args --base 1024\n";
        print "graph_title Elasticsearch indexes\n";
        print "graph_category elasticsearch\n";
        print "graph_vlabel Bytes\n";
    
        foreach my $name (keys %out) {
            print "$name.label $name\n"."$name.type GAUGE\n";
        }
    }
    elsif (!$ARGV[0] || $ARGV[0] eq 'autoconf') {
        foreach my $name (keys %out) {
            print "$name.value " . $out{$name} . "\n";
        }
    }
    
    exit(0);

    munin, 19 Февраля 2017

    Комментарии (4)
  5. Perl / Говнокод #22380

    −98

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    11. 11
    12. 12
    13. 13
    14. 14
    15. 15
    16. 16
    17. 17
    18. 18
    19. 19
    20. 20
    21. 21
    22. 22
    23. 23
    24. 24
    25. 25
    26. 26
    27. 27
    28. 28
    29. 29
    30. 30
    31. 31
    32. 32
    33. 33
    34. 34
    35. 35
    36. 36
    37. 37
    38. 38
    39. 39
    40. 40
    41. 41
    42. 42
    43. 43
    44. 44
    45. 45
    46. 46
    47. 47
    48. 48
    49. 49
    50. 50
    51. 51
    52. 52
    53. 53
    54. 54
    55. 55
    56. 56
    57. 57
    58. 58
    59. 59
    60. 60
    61. 61
    62. 62
    63. 63
    64. 64
    65. 65
    66. 66
    67. 67
    68. 68
    69. 69
    70. 70
    71. 71
    72. 72
    #!/usr/bin/env perl
    
    # Parameters supported:
    #
    # config
    # autoconf
    #
    # Magic markers:
    #%# family=auto
    #%# capabilities=autoconf
    
    use strict;
    use warnings;
    use LWP;
    use JSON qw/decode_json/;
    
    =head1 NAME
    elasticsearch_gc_time - A munin plugin that collects garbage collection time stats of your elasticsearch instances
    =head1 APPLICABLE SYSTEMS
    Elasticsearch
    =head1 CONFIGURATION
    None
    =head1 BUGS
    None known so far. If you find any, let me know.
    =head1 AUTHOR
    Timothy Messier (t0m) - c<< <[email protected]> >>
    Kentaro Yoshida - https://github.com/y-ken
    =cut
    
    my $host = exists $ENV{'host'} ? $ENV{'host'} : 'localhost';
    my $port = exists $ENV{'port'} ? $ENV{'port'} : 9200;
    
    my $ua = LWP::UserAgent->new;
    $ua->timeout(10);
    
    sub get_json_from_url {
        my $uri = shift;
        my $res = $ua->get($uri, 'Content-Type' => 'application/json' );
        Carp::confess($res->code . " for " . $uri) unless $res->is_success;
        my $data = do { local $@; eval { decode_json($res->content) } };
        die("Could not decode JSON from: " . $res->content) unless $data;
        return $data;
    }
    
    my $data = get_json_from_url("http://$host:$port/_nodes/_local/stats/jvm");
    my %out = (young => 0, old => 0);
    
    foreach my $full_node_name (keys %{$data->{nodes}}) {
        next unless $data->{nodes}{$full_node_name};
        if (defined($data->{nodes}{$full_node_name}{jvm}{gc}{collectors}{young})) {
            $out{young} += $data->{nodes}{$full_node_name}{jvm}{gc}{collectors}{young}{collection_time_in_millis};
        }
        if (defined($data->{nodes}{$full_node_name}{jvm}{gc}{collectors}{old})) {
            $out{old} += $data->{nodes}{$full_node_name}{jvm}{gc}{collectors}{old}{collection_time_in_millis};
        }
    }
    if ($ARGV[0] and $ARGV[0] eq 'config') {
        print "graph_title Elasticsearch gc time\n";
        print "graph_category elasticsearch\n";
        print "graph_vlabel miliseconds\n";
    
        foreach my $name (keys %out) {
            print "$name.label $name\n"."$name.type COUNTER\n";
        }
    }
    elsif (!$ARGV[0] || $ARGV[0] eq 'autoconf') {
        foreach my $name (keys %out) {
            print "$name.value " . $out{$name} . "\n";
        }
    }
    
    exit(0);

    munin, 19 Февраля 2017

    Комментарии (0)
  6. Perl / Говнокод #22379

    −98

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    11. 11
    12. 12
    13. 13
    14. 14
    15. 15
    16. 16
    17. 17
    18. 18
    19. 19
    20. 20
    21. 21
    22. 22
    23. 23
    24. 24
    25. 25
    26. 26
    27. 27
    28. 28
    29. 29
    30. 30
    31. 31
    32. 32
    33. 33
    34. 34
    35. 35
    36. 36
    37. 37
    38. 38
    39. 39
    40. 40
    41. 41
    42. 42
    43. 43
    44. 44
    45. 45
    46. 46
    47. 47
    48. 48
    49. 49
    50. 50
    51. 51
    52. 52
    53. 53
    54. 54
    55. 55
    56. 56
    57. 57
    58. 58
    59. 59
    60. 60
    61. 61
    62. 62
    63. 63
    64. 64
    65. 65
    66. 66
    67. 67
    68. 68
    #!/usr/bin/env perl
    
    # Parameters supported:
    #
    # config
    # autoconf
    #
    # Magic markers:
    #%# family=auto
    #%# capabilities=autoconf
    
    use strict;
    use warnings;
    use LWP;
    use JSON qw/decode_json/;
    
    =head1 NAME
    elasticsearch_docs - A munin plugin that collects document stats of your elasticsearch instances
    =head1 APPLICABLE SYSTEMS
    Elasticsearch
    =head1 CONFIGURATION
    None
    =head1 BUGS
    None known so far. If you find any, let me know.
    =head1 AUTHOR
    Tomas Doran (t0m) - c<< <[email protected]> >>
    Kentaro Yoshida - https://github.com/y-ken
    =cut
    
    my $host = exists $ENV{'host'} ? $ENV{'host'} : 'localhost';
    my $port = exists $ENV{'port'} ? $ENV{'port'} : 9200;
    
    my $ua = LWP::UserAgent->new;
    $ua->timeout(10);
    
    sub get_json_from_url {
        my $uri = shift;
        my $res = $ua->get($uri, 'Content-Type' => 'application/json' );
        Carp::confess($res->code . " for " . $uri) unless $res->is_success;
        my $data = do { local $@; eval { decode_json($res->content) } };
        die("Could not decode JSON from: " . $res->content) unless $data;
        return $data;
    }
    
    my $data = get_json_from_url("http://$host:$port/_nodes");
    my $t_data = get_json_from_url("http://$host:$port/_nodes/stats");
    my %out = (num_docs => 0);
    
    foreach my $full_node_name (keys %{$data->{nodes}}) {
        next unless $t_data->{nodes}{$full_node_name};
        $out{num_docs} += $t_data->{nodes}{$full_node_name}{indices}{docs}{count};
    }
    
    if ($ARGV[0] and $ARGV[0] eq 'config') {
        print "graph_title elasticsearch documents\n";
        print "graph_category elasticsearch\n";
    
        foreach my $name (keys %out) {
            print "$name.label $name\n"."$name.type GAUGE\n";
        }
    }
    elsif (!$ARGV[0] || $ARGV[0] eq 'autoconf') {
        foreach my $name (keys %out) {
            print "$name.value " . $out{$name} . "\n";
        }
    }
    
    exit(0);

    munin, 19 Февраля 2017

    Комментарии (0)
  7. Perl / Говнокод #22378

    −61

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    11. 11
    12. 12
    13. 13
    14. 14
    15. 15
    16. 16
    17. 17
    18. 18
    19. 19
    20. 20
    21. 21
    22. 22
    23. 23
    24. 24
    25. 25
    26. 26
    27. 27
    28. 28
    29. 29
    30. 30
    31. 31
    32. 32
    33. 33
    34. 34
    35. 35
    36. 36
    37. 37
    38. 38
    39. 39
    40. 40
    41. 41
    42. 42
    43. 43
    44. 44
    45. 45
    46. 46
    47. 47
    48. 48
    49. 49
    50. 50
    51. 51
    52. 52
    53. 53
    54. 54
    55. 55
    56. 56
    57. 57
    58. 58
    59. 59
    60. 60
    61. 61
    62. 62
    #!/usr/bin/env perl
    
    # Parameters supported:
    #
    # config
    # autoconf
    #
    # Magic markers:
    #%# family=auto
    #%# capabilities=autoconf
    
    use strict;
    use warnings;
    use LWP;
    use JSON qw/decode_json/;
    
    =head1 NAME
    elasticsearch_cluster_shards - A munin plugin that collects shard stats of your elasticsearch instances
    =head1 APPLICABLE SYSTEMS
    Elasticsearch
    =head1 CONFIGURATION
    None
    =head1 BUGS
    None known so far. If you find any, let me know.
    =head1 AUTHOR
    Tomas Doran (t0m) - c<< <[email protected]> >>
    Kentaro Yoshida - https://github.com/y-ken
    =cut
    
    my $host = exists $ENV{'host'} ? $ENV{'host'} : 'localhost';
    my $port = exists $ENV{'port'} ? $ENV{'port'} : 9200;
    
    my $ua = LWP::UserAgent->new;
    $ua->timeout(10);
    
    sub get_json_from_url {
        my $uri = shift;
        my $res = $ua->get($uri, 'Content-Type' => 'application/json' );
        Carp::confess($res->code . " for " . $uri) unless $res->is_success;
        my $data = do { local $@; eval { decode_json($res->content) } };
        die("Could not decode JSON from: " . $res->content) unless $data;
        return $data;
    }
    
    my $data = get_json_from_url("http://$host:$port/_cluster/health");
    
    if ($ARGV[0] and $ARGV[0] eq 'config') {
        print "graph_title elasticsearch cluster shards\n";
        print "graph_category elasticsearch\n";
        print "graph_scale no\n";
    
        foreach my $name (grep { /_shards$/ } keys %$data) {
            print "$name.label $name\n"."$name.type GAUGE\n";
        }
    }
    elsif (!$ARGV[0] || $ARGV[0] eq 'autoconf') {
        foreach my $name (grep { /_shards$/ } keys %$data) {
            print "$name.value " . $data->{$name} . "\n";
        }
    }
    
    exit(0);

    munin, 19 Февраля 2017

    Комментарии (0)
  8. Perl / Говнокод #22377

    −98

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    11. 11
    12. 12
    13. 13
    14. 14
    15. 15
    16. 16
    17. 17
    18. 18
    19. 19
    20. 20
    21. 21
    22. 22
    23. 23
    24. 24
    25. 25
    26. 26
    27. 27
    28. 28
    29. 29
    30. 30
    31. 31
    32. 32
    33. 33
    34. 34
    35. 35
    36. 36
    37. 37
    38. 38
    39. 39
    40. 40
    41. 41
    42. 42
    43. 43
    44. 44
    45. 45
    46. 46
    47. 47
    48. 48
    49. 49
    50. 50
    51. 51
    52. 52
    53. 53
    54. 54
    55. 55
    56. 56
    57. 57
    58. 58
    59. 59
    60. 60
    61. 61
    62. 62
    63. 63
    64. 64
    65. 65
    66. 66
    67. 67
    68. 68
    69. 69
    70. 70
    71. 71
    72. 72
    73. 73
    74. 74
    #!/usr/bin/env perl
    
    # Parameters supported:
    #
    # config
    # autoconf
    #
    # Magic markers:
    #%# family=auto
    #%# capabilities=autoconf
    
    use strict;
    use warnings;
    use LWP;
    use JSON qw/decode_json/;
    
    =head1 NAME
    elasticsearch_cache - A munin plugin that collects cache stats of your elasticsearch instances
    =head1 APPLICABLE SYSTEMS
    Elasticsearch
    =head1 CONFIGURATION
    None
    =head1 BUGS
    None known so far. If you find any, let me know.
    =head1 AUTHOR
    Tomas Doran (t0m) - c<< <[email protected]> >>
    Kentaro Yoshida - https://github.com/y-ken
    =cut
    
    my $host = exists $ENV{'host'} ? $ENV{'host'} : 'localhost';
    my $port = exists $ENV{'port'} ? $ENV{'port'} : 9200;
    
    my $ua = LWP::UserAgent->new;
    $ua->timeout(10);
    
    sub get_json_from_url {
        my $uri = shift;
        my $res = $ua->get($uri, 'Content-Type' => 'application/json' );
        Carp::confess($res->code . " for " . $uri) unless $res->is_success;
        my $data = do { local $@; eval { decode_json($res->content) } };
        die("Could not decode JSON from: " . $res->content) unless $data;
        return $data;
    }
    
    my $data = get_json_from_url("http://$host:$port/_nodes");
    my $t_data = get_json_from_url("http://$host:$port/_nodes/stats");
    my %out = (field_size => 0, filter_size => 0);
    
    foreach my $full_node_name (keys %{$data->{nodes}}) {
        next unless $t_data->{nodes}{$full_node_name};
        if (defined($t_data->{nodes}{$full_node_name}{indices}{fielddata})) {
            $out{field_size} += $t_data->{nodes}{$full_node_name}{indices}{fielddata}{memory_size_in_bytes};
        }
        if (defined($t_data->{nodes}{$full_node_name}{indices}{filter_cache})) {
            $out{filter_size} += $t_data->{nodes}{$full_node_name}{indices}{filter_cache}{memory_size_in_bytes};
        }
    }
    if ($ARGV[0] and $ARGV[0] eq 'config') {
        print "graph_args --base 1024\n";
        print "graph_title elasticsearch cache\n";
        print "graph_category elasticsearch\n";
        print "graph_vlabel Bytes\n";
    
        foreach my $name (keys %out) {
            print "$name.label $name\n"."$name.type GAUGE\n";
        }
    }
    elsif (!$ARGV[0] || $ARGV[0] eq 'autoconf') {
        foreach my $name (keys %out) {
            print "$name.value " . $out{$name} . "\n";
        }
    }
    
    exit(0);

    munin, 19 Февраля 2017

    Комментарии (0)
  9. bash / Говнокод #22376

    −98

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    11. 11
    12. 12
    13. 13
    14. 14
    15. 15
    16. 16
    17. 17
    18. 18
    19. 19
    20. 20
    21. 21
    22. 22
    23. 23
    24. 24
    25. 25
    26. 26
    27. 27
    28. 28
    29. 29
    30. 30
    31. 31
    32. 32
    33. 33
    34. 34
    35. 35
    36. 36
    37. 37
    38. 38
    39. 39
    40. 40
    41. 41
    42. 42
    43. 43
    44. 44
    45. 45
    46. 46
    47. 47
    48. 48
    49. 49
    50. 50
    51. 51
    52. 52
    53. 53
    54. 54
    55. 55
    56. 56
    57. 57
    58. 58
    59. 59
    60. 60
    61. 61
    62. 62
    63. 63
    64. 64
    65. 65
    66. 66
    67. 67
    68. 68
    69. 69
    70. 70
    71. 71
    72. 72
    73. 73
    #!/bin/sh
    # 
    # Plugin to monitor the queues of a virtual_host in RabbitMQ
    #
    # Usage: Link or copy into /etc/munin/node.d/
    #
    # Parameters
    #     env.vhost <AMQ virtual host>
    #     env.queue_warn <warning queuesize>
    #     env.queue_crit <critical queuesize>
    #
    # Magic markers (optional - only used by munin-config and some
    # installation scripts):
    #
    #%# family=auto
    #%# capabilities=autoconf
    
    # If run with the "autoconf"-parameter, give our opinion on wether we
    # should be run on this system or not. This is optinal, and only used by
    # munin-config. In the case of this plugin, we should most probably
    # always be included.
    
    if [ "$1" = "autoconf" ]; then
    	echo yes
    	exit 0
    fi
    
    # If run with the "config"-parameter, give out information on how the
    # graphs should look. 
    
    HOME=/tmp/
    VHOST=${vhost:-"/"}
    QUEUES=$(rabbitmqctl list_queues -p $VHOST name | \
    		grep -v '^Listing' | \
    		grep -v 'done\.$' | sed -e 's/[.=-]/_/g' )
     
    if [ "$1" = "config" ]; then
            QUEUE_WARN=${queue_warn:-10000}
            QUEUE_CRIT=${queue_crit:-20000}
    
    	# The host name this plugin is for. (Can be overridden to have
    	# one machine answer for several)
    
    	# The title of the graph
    	echo "graph_title RabbitMQ $VHOST Memory used by queue"
    	# Arguments to "rrdtool graph". In this case, tell it that the
    	# lower limit of the graph is '0', and that 1k=1000 (not 1024)
    	echo 'graph_args --base 1024 --vertical-label Bytes -l 0'
    	# The Y-axis label
    	echo 'graph_vlabel memory'
    	# We want Cur/Min/Avg/Max unscaled (i.e. 0.42 load instead of
    	# 420 milliload)
    	#echo 'graph_scale no'
    	echo 'graph_category RabbitMQ'
    
    	for queue in $QUEUES; do
    		echo "$queue.label $queue"
    		echo "$queue.warning $QUEUE_WARN"
    		echo "$queue.critical $QUEUE_CRIT"
    		echo "$queue.info Memory used by $queue"
    	done
    
    	echo 'graph_info Show memory usage by queue'
    	# Last, if run with the "config"-parameter, quit here (don't
    	# display any data)
    	exit 0
    fi
    
    # If not run with any parameters at all (or only unknown ones), do the
    # real work - i.e. display the data. Almost always this will be
    # "value" subfield for every data field.
    
    HOME=$HOME rabbitmqctl list_queues -p $VHOST name memory | grep -v "^Listing" | grep -v "done.$" | sed "s/[\t]/.value /g"

    munin, 19 Февраля 2017

    Комментарии (0)
  10. bash / Говнокод #22375

    −98

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    11. 11
    12. 12
    13. 13
    14. 14
    15. 15
    16. 16
    17. 17
    18. 18
    19. 19
    20. 20
    21. 21
    22. 22
    23. 23
    24. 24
    25. 25
    26. 26
    27. 27
    28. 28
    29. 29
    30. 30
    31. 31
    32. 32
    33. 33
    34. 34
    35. 35
    36. 36
    37. 37
    38. 38
    39. 39
    40. 40
    41. 41
    42. 42
    43. 43
    44. 44
    45. 45
    46. 46
    47. 47
    48. 48
    49. 49
    50. 50
    51. 51
    52. 52
    53. 53
    54. 54
    55. 55
    56. 56
    57. 57
    58. 58
    59. 59
    60. 60
    61. 61
    62. 62
    63. 63
    64. 64
    65. 65
    66. 66
    67. 67
    68. 68
    69. 69
    70. 70
    71. 71
    72. 72
    73. 73
    #!/bin/sh
    # 
    # Plugin to monitor the queues of a virtual_host in RabbitMQ
    #
    # Usage: Link or copy into /etc/munin/node.d/
    #
    # Parameters
    #     env.vhost <AMQ virtual host>
    #     env.queue_warn <warning queuesize>
    #     env.queue_crit <critical queuesize>
    #
    # Magic markers (optional - only used by munin-config and some
    # installation scripts):
    #
    #%# family=auto
    #%# capabilities=autoconf
    
    # If run with the "autoconf"-parameter, give our opinion on wether we
    # should be run on this system or not. This is optinal, and only used by
    # munin-config. In the case of this plugin, we should most probably
    # always be included.
    
    if [ "$1" = "autoconf" ]; then
    	echo yes
    	exit 0
    fi
    
    # If run with the "config"-parameter, give out information on how the
    # graphs should look. 
    
    HOME=/tmp/
    VHOST=${vhost:-"/"}
    QUEUES=$(HOME=$HOME rabbitmqctl list_queues -p $VHOST name | \
    		grep -v '^Listing' | \
    		grep -v 'done\.$' | sed -e 's/[.=-]/_/g' )
     
    if [ "$1" = "config" ]; then
            QUEUE_WARN=${queue_warn:-10000}
            QUEUE_CRIT=${queue_crit:-20000}
    
    	# The host name this plugin is for. (Can be overridden to have
    	# one machine answer for several)
    
    	# The title of the graph
    	echo "graph_title RabbitMQ $VHOST Uncommitted Messages"
    	# Arguments to "rrdtool graph". In this case, tell it that the
    	# lower limit of the graph is '0', and that 1k=1000 (not 1024)
    	echo 'graph_args --base 1000 -l 0'
    	# The Y-axis label
    	echo 'graph_vlabel uncommitted'
    	# We want Cur/Min/Avg/Max unscaled (i.e. 0.42 load instead of
    	# 420 milliload)
    	#echo 'graph_scale no'
    	echo 'graph_category RabbitMQ'
    
    	for queue in $QUEUES; do
    		echo "$queue.label $queue"
    		echo "$queue.warning $QUEUE_WARN"
    		echo "$queue.critical $QUEUE_CRIT"
    		echo "$queue.info Uncommitted messages for $queue"
    	done
    
    	echo 'graph_info Lists how many messages are in each queue.'
    	# Last, if run with the "config"-parameter, quit here (don't
    	# display any data)
    	exit 0
    fi
    
    # If not run with any parameters at all (or only unknown ones), do the
    # real work - i.e. display the data. Almost always this will be
    # "value" subfield for every data field.
    
    HOME=$HOME rabbitmqctl list_channels name vhost messages_uncommitted | grep -v "\.\.\." | grep $VHOST | sed "s/[ ]->.*[\t]/.value /g"

    munin, 19 Февраля 2017

    Комментарии (0)
  11. bash / Говнокод #22374

    −98

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    11. 11
    12. 12
    13. 13
    14. 14
    15. 15
    16. 16
    17. 17
    18. 18
    19. 19
    20. 20
    21. 21
    22. 22
    23. 23
    24. 24
    25. 25
    26. 26
    27. 27
    28. 28
    29. 29
    30. 30
    31. 31
    32. 32
    33. 33
    34. 34
    35. 35
    36. 36
    37. 37
    38. 38
    39. 39
    40. 40
    41. 41
    42. 42
    43. 43
    44. 44
    45. 45
    46. 46
    47. 47
    48. 48
    49. 49
    50. 50
    51. 51
    52. 52
    53. 53
    54. 54
    55. 55
    56. 56
    57. 57
    58. 58
    59. 59
    60. 60
    61. 61
    62. 62
    63. 63
    64. 64
    65. 65
    66. 66
    67. 67
    68. 68
    69. 69
    70. 70
    71. 71
    72. 72
    73. 73
    74. 74
    #!/bin/sh
    # 
    # Plugin to monitor the queues of a virtual_host in RabbitMQ
    #
    # Usage: Link or copy into /etc/munin/node.d/
    #
    # Parameters
    #     env.vhost <AMQ virtual host>
    #     env.queue_warn <warning queuesize>
    #     env.queue_crit <critical queuesize>
    #
    # Magic markers (optional - only used by munin-config and some
    # installation scripts):
    #
    #%# family=auto
    #%# capabilities=autoconf
    
    # If run with the "autoconf"-parameter, give our opinion on wether we
    # should be run on this system or not. This is optinal, and only used by
    # munin-config. In the case of this plugin, we should most probably
    # always be included.
    
    if [ "$1" = "autoconf" ]; then
    	echo yes
    	exit 0
    fi
    
    # If run with the "config"-parameter, give out information on how the
    # graphs should look. 
    
    HOME=/tmp/
    VHOST=${vhost:-"/"}
    QUEUES=$(HOME=$HOME rabbitmqctl list_queues -p $VHOST name | \
    		grep -v '^Listing' | \
    		grep -v 'done\.$' | sed -e 's/[.=-]/_/g' )
     
    if [ "$1" = "config" ]; then
            QUEUE_WARN=${queue_warn:-10000}
            QUEUE_CRIT=${queue_crit:-20000}
    
    	# The host name this plugin is for. (Can be overridden to have
    	# one machine answer for several)
    
    	# The title of the graph
    	echo "graph_title RabbitMQ $VHOST Unacknowledged Messages"
    	# Arguments to "rrdtool graph". In this case, tell it that the
    	# lower limit of the graph is '0', and that 1k=1000 (not 1024)
    	echo 'graph_args --base 1000 -l 0'
    	# The Y-axis label
    	echo 'graph_vlabel unacknowledged'
    	# We want Cur/Min/Avg/Max unscaled (i.e. 0.42 load instead of
    	# 420 milliload)
    	#echo 'graph_scale no'
    	echo 'graph_category RabbitMQ'
    
    	for queue in $QUEUES; do
    		echo "$queue.label $queue"
    		echo "$queue.warning $QUEUE_WARN"
    		echo "$queue.critical $QUEUE_CRIT"
    		echo "$queue.info Unacknowledged messages for $queue"
    	done
    
    	echo 'graph_info Lists how many messages are in each queue.'
    	# Last, if run with the "config"-parameter, quit here (don't
    	# display any data)
    	exit 0
    fi
    
    # If not run with any parameters at all (or only unknown ones), do the
    # real work - i.e. display the data. Almost always this will be
    # "value" subfield for every data field.
    
    
    HOME=$HOME rabbitmqctl list_queues -p $VHOST name messages_unacknowledged | grep -v "^Listing" | grep -v "done.$" | sed "s/[\t]/.value /g"

    munin, 19 Февраля 2017

    Комментарии (0)