2、浏览器访问注释:或许是memcached没有任何数据吧!
可是朋友的博客是这样的
[root@lnmp ~]# telnet 127.0.0.1 11211
Trying 127.0.0.1...
Connected to 127.0.0.1.
Escape character is '^]'.
stats
STAT pid 63992
STAT uptime 6204
STAT time 1412164192
STAT version 1.4.17
STAT libevent 2.0.21-stable
STAT pointer_size 64
STAT rusage_user 0.225965
STAT rusage_system 0.309952
STAT curr_connections 10
STAT total_connections 243
STAT connection_structures 12
STAT reserved_fds 20
STAT cmd_get 108
STAT cmd_set 43
STAT cmd_flush 0
STAT cmd_touch 0
STAT get_hits 68
STAT get_misses 40
STAT delete_misses 0
STAT delete_hits 0
STAT incr_misses 0
STAT incr_hits 0
STAT decr_misses 0
STAT decr_hits 0
STAT cas_misses 0
STAT cas_hits 0
STAT cas_badval 0
STAT touch_hits 0
STAT touch_misses 0
STAT auth_cmds 0
STAT auth_errors 0
STAT bytes_read 7326
STAT bytes_written 125489
STAT limit_maxbytes 67108864
STAT accepting_conns 1
STAT listen_disabled_num 0
STAT threads 4
STAT conn_yields 0
STAT hash_power_level 16
STAT hash_bytes 524288
STAT hash_is_expanding 0
STAT malloc_fails 0
STAT bytes 205
STAT curr_items 2
STAT total_items 43
STAT expired_unfetched 0
STAT evicted_unfetched 0
STAT evictions 0
STAT reclaimed 0
END或者利用nagios的check_tcp来监测,如下[root@NagiosServer libexec]# ./check_tcp -H 192.168.0.12 -p 11211 -t 5 -E -s 'stats\r\nquit\r\n' -e 'uptime' -M crit
TCP OK - 0.001 second response time on 192.168.0.12 port 11211 [STAT pid 63992
STAT uptime 6295
STAT time 1412164283
STAT version 1.4.17
STAT libevent 2.0.21-stable
STAT pointer_size 64
STAT rusage_user 0.225965
STAT rusage_system 0.317951
STAT curr_connections 11
STAT total_connections 249
STAT connection_structures 12
STAT reserved_fds 20
STAT cmd_get 108
STAT cmd_set 43
STAT cmd_flush 0
STAT cmd_touch 0
STAT get_hits 68
STAT get_misses 40
STAT delete_misses 0
STAT delete_hits 0
STAT incr_misses 0
STAT incr_hits 0
STAT decr_misses 0
STAT decr_hits 0
STAT cas_misses 0
STAT cas_hits 0
STAT cas_badval 0
STAT touch_hits 0
STAT touch_misses 0
STAT auth_cmds 0
STAT auth_errors 0
STAT bytes_read 7374
STAT bytes_written 131873
STAT limit_maxbytes 67108864
STAT accepting_conns 1
STAT listen_disabled_num 0
STAT threads 4
STAT conn_yields 0
STAT hash_power_level 16
STAT hash_bytes 524288
STAT hash_is_expanding 0
STAT malloc_fails 0
STAT bytes 205
STAT curr_items 2
STAT total_items 43
STAT expired_unfetched 0
STAT evicted_unfetched 0
S]|time=0.001293s;;;0.000000;5.000000[root@NagiosServer ~]# yum -y install perl*
或者
[root@NagiosServer ~]# yum install perl-Carp-Clan perl-Cache-Memcached perl-Nagios-Plugin
[root@NagiosServer ~]# tar xf Nagios-Plugins-Memcached-0.02.tar.gz
[root@NagiosServer Nagios-Plugins-Memcached-0.02]# cd Nagios-Plugins-Memcached-0.02
[root@NagiosServer ~]# perl Makefile.PL
[root@NagiosServer ~]# make && make install做适应的修改#默认check_memcached的安装路径
[root@NagiosServer ~]# find / -name check_memcached
/usr/local/bin/check_memcached
#对其进行适应的修改
[root@NagiosServer ~]# cp /usr/local/bin/check_memcached /usr/local/nagios/libexec/[root@NagiosServer objects]# vim commands.cfg
#定义Memcached的内存使用比例
define command {
command_name check_memcached_11211
command_line $USER1$/check_memcached -H 192.168.0.12:11211 --size-warning 80 --size-critical 90
}
#定义Memcached是否有应答
define command {
command_name memcached_response_11211
command_line $USER1$/check_memcached -H 192.168.0.12 -w 300 -c 500
}
#定义Memcached的命中率
define command {
command_name check_memcached_hit
command_line $USER1$/check_memcached -H 192.168.0.12 --hit-warning 10 --size-critical 5
}2、定义服务和主机define host{
use linux-server
host_name Linux Server 02
alias My Linux 02
address 192.168.0.12
}
#define hostgroup{
# hostgroup_name admins
# alias Nagios Administrators
# members Linux Server 02
# }
define service{
use generic-service
host_name Linux Server 02
service_description PING
check_command check_ping!100.0,20%!500.0,60%
}
define service{
use generic-service
host_name Linux Server 02
service_description Root Partition
check_command check_local_disk!20%!10%!/
}
define service{
use generic-service
host_name Linux Server 02
service_description Current Users
check_command check_local_users!20!50
}
define service{
use generic-service
host_name Linux Server 02
service_description Total Processes
check_command check_local_procs!250!400!RSZDT
}
define service{
use generic-service
host_name Linux Server 02
service_description Current Load
check_command check_local_load!5.0,4.0,3.0!10.0,6.0,4.0
}
define service{
use generic-service
host_name Linux Server 02
service_description Swap Usage
check_command check_local_swap!20!10
}
define service{
use generic-service
host_name Linux Server 02
service_description SSH
check_command check_ssh
notifications_enabled 0
}
define service{
use generic-service
host_name Linux Server 02
service_description HTTP
check_command check_http
notifications_enabled 0
}
define service{
use generic-service
host_name Linux Server 02
service_description users
check_command check_nrpe!check_users
}
define service{
use generic-service
host_name Linux Server 02
service_description load
check_command check_nrpe!check_load
}
define service{
use generic-service
host_name Linux Server 02
service_description disk sda1
check_command check_nrpe!check_sda1
}
define service{
use generic-service
host_name Linux Server 02
service_description zombie_proces
check_command check_nrpe!check_zombie_procs
}
define service{
use generic-service
host_name Linux Server 02
service_description Total_proces
check_command check_nrpe!check_total_procs
}
define service{
use generic-service
host_name Linux Server 02
service_description Memcached Reponse
check_command check_memcached_11211
}
define service{
use generic-service
host_name Linux Server 02
service_description Memcached Size
check_command memcached_response_11211
}
define service{
use generic-service
host_name Linux Server 02
service_description Memcached Hit
check_command check_memcached_hit
}3、启用定义的主机配置文件[root@NagiosServer etc]# vim nagios.cfg
cfg_file=/usr/local/nagios/etc/objects/hosts/linux02.cfg4、重新启动nagios服务[root@NagiosServer ~]# service nagios restart
Running configuration check...
Stopping nagios: done.
Starting nagios: done.五、查看页面监控结果
暂且就先到这里吧!更多的会在下一篇博文中写到[root@NagiosServer libexec]# cat check_nginx.sh
#!/bin/bash
PROGNAME=`basename $0`
VERSION="Version 1.0"
AUTHOR="2010.11.18-www.nginxs.com"
ST_OK=0
ST_WR=1
ST_CR=2
ST_UK=3
print_version() {
echo "$VERSION $AUTHOR"
}
print_help() {
print_version $PROGNAME $VERSION
echo "$PROGNAME is a Nagios plugin to monitor nginx status"
echo "Use of wget nginxstatus page"
echo "When using optional warning/critical thresholds all values except"
echo "Usage parameters:"
echo ""
echo "$PROGNAME [-u|--url] [-p|--path] [-w/--warning] [-c/--critical]"
echo ""
echo "Options:"
echo " --url|-u)"
echo " Sets nginx status url"
echo ""
echo " --path|-p)"
echo " Sets nginx status url path"
echo ""
echo " --warning|-w)"
echo " Sets a warning level for nginx Active connections. Default is: off"
echo ""
echo " --critical|-c)"
echo " Sets a critical level for nginx Active connections. Default is: off"
echo ""
echo "Example:"
echo "http://www.nginxs.com/status"
echo "./check_nginx.sh -u www.nginxs.com -p /status -w 10000 -c 15000"
exit $ST_UK
}
while test -n "$1";do
case "$1" in
--help|-h)
print_help
exit $ST_UK
;;
--url|-u)
url=$2
shift
;;
--path|-p)
path=$2
shift
;;
--warning|-w)
warn=$2
shift
;;
--critical|-c)
crit=$2
shift
;;
*)
echo "Unknown argument: $1"
print_help
exit $ST_UK
;;
esac
shift
done
if [ -z $url ];then
echo "Must Sets --url|-u) Parameters"
exit $ST_UK
elif [ -z $path ];then
echo "Must sets --path|-p) Parameters"
echo "Please look help"
echo "$PROGNAME --help"
exit $ST_UK
fi
if [ -n "$warn" -a -n "$crit" ];then
if [ $warn -ge $crit ];then
echo "Please adjust your warning/critical thresholds. The warning must be lower than the critical level!"
exit $ST_UK
fi
fi
do_status() {
wget -qNO /tmp/nginx.html ${url}${path}
ActiveConn=`awk -F: {'print $2'} /tmp/nginx.html |head -1`
serveraccepts=`awk {'print $1'} /tmp/nginx.html |tail -n 2|head -1`
handled=`awk {'print $2'} /tmp/nginx.html |tail -n 2|head -1`
requests=`awk {'print $3'} /tmp/nginx.html |tail -n 2|head -1`
reading=`tail -n 1 /tmp/nginx.html|awk {'print $2'}`
writing=`tail -n 1 /tmp/nginx.html|awk {'print $4'}`
waiting=`tail -n 1 /tmp/nginx.html|awk {'print $6'}`
}
do_output() {
output="ActiveConn:${ActiveConn},serveraccepts:${serveraccepts},handled:${handled},requests:${requests},reading:${reading},writing:${writing},waiting:${waiting}"
}
do_perfdata() {
perfdata="'ActiveConn'=${ActiveConn},'serveraccepts'=${serveraccepts},'handled'=${handled},'requests'=${requests},'reading'=${reading},'writing'=${writing},'waiting'=${waiting}"
}
do_status
do_output
do_perfdata
if [ -n "warn" -a -n "$crit" ];then
if [ $ActiveConn -ge $warn -a $ActiveConn -lt $crit ];then
echo "WARNING - $output |$perfdata"
exit $ST_WR
elif [ $ActiveConn -ge $crit ];then
echo "CRITICAL - $output|$perfdata"
exit $ST_CR
else
echo "OK - $output|$perfdata"
exit $ST_OK
fi
else
echo "OK - $output|$perfdata"
exit $ST_OK
fi[root@NagiosServer libexec]# ./check_nginx.sh -h
Version 1.0 2010.11.18-www.nginxs.com
check_nginx.sh is a Nagios plugin to monitor nginx status
Use of wget nginxstatus page
When using optional warning/critical thresholds all values except
Usage parameters:
check_nginx.sh [-u|--url] [-p|--path] [-w/--warning] [-c/--critical]
Options:
--url|-u)
Sets nginx status url
--path|-p)
Sets nginx status url path
--warning|-w)
Sets a warning level for nginx Active connections. Default is: off
--critical|-c)
Sets a critical level for nginx Active connections. Default is: off
Example:
http://www.nginxs.com/status
./check_nginx.sh -u www.nginxs.com -p /status -w 10000 -c 15000[root@NagiosServer libexec]# ./check_nginx.sh -u 192.168.0.12 -p /nginx_status -w 10000 -c 15000
OK - ActiveConn: 1 ,serveraccepts:47,handled:47,requests:47,reading:0,writing:1,waiting:0|'ActiveConn'= 1 ,'serveraccepts'=47,'handled'=47,'requests'=47,'reading'=0,'writing'=1,'waiting'=0[root@NagiosServer libexec]# vim ../etc/objects/commands.cfg
define command {
command_name check_nginx
command_line $USER1$/check_nginx.sh -u 192.168.0.12 -p /nginx_status -w 10000 -c 15000
}
[root@NagiosServer libexec]# vim ../etc/objects/hosts/linux02.cfg
define service{
use generic-service
host_name Linux Server 02
service_description Nginx Status
check_command check_nginx
}查看监控页面
然后看ab压力测试页面,看监控是否有变化[root@NagiosServer libexec]# ab -c 1000 -n 1000 http://192.168.0.12/index.php
This is ApacheBench, Version 2.3 <$Revision: 655654 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/
Benchmarking 192.168.0.12 (be patient)
Completed 100 requests
Completed 200 requests
Completed 300 requests
Completed 400 requests
Completed 500 requests
Completed 600 requests
Completed 700 requests
Completed 800 requests
Completed 900 requests
Completed 1000 requests
Finished 1000 requests
Server Software: nginx/1.4.7
Server Hostname: 192.168.0.12
Server Port: 80
Document Path: /index.php
Document Length: 192 bytes
Concurrency Level: 1000
Time taken for tests: 1.579 seconds
Complete requests: 1000
Failed requests: 142
(Connect: 0, Receive: 0, Length: 142, Exceptions: 0)
Write errors: 0
Non-2xx responses: 858
Total transferred: 7851142 bytes
HTML transferred: 7692130 bytes
Requests per second: 633.33 [#/sec] (mean)
Time per request: 1578.963 [ms] (mean)
Time per request: 1.579 [ms] (mean, across all concurrent requests)
Transfer rate: 4855.80 [Kbytes/sec] received
Connection Times (ms)
min mean[+/-sd] median max
Connect: 122 135 10.4 135 163
Processing: 120 253 149.8 218 1294
Waiting: 107 250 147.8 218 1292
Total: 265 388 144.8 351 1416
Percentage of the requests served within a certain time (ms)
50% 351
66% 377
75% 390
80% 402
90% 624
95% 754
98% 822
99% 842
100% 1416 (longest request)
memcached参考博文http://storysky.blog.51cto.com/628458/244962 http://linuxjcq.blog.51cto.com/3042600/718180nginx参考博文http://deidara.blog.51cto.com/400447/429213我正在尝试使用ruby和Savon来使用网络服务。测试服务为http://www.webservicex.net/WS/WSDetails.aspx?WSID=9&CATID=2require'rubygems'require'savon'client=Savon::Client.new"http://www.webservicex.net/stockquote.asmx?WSDL"client.get_quotedo|soap|soap.body={:symbol=>"AAPL"}end返回SOAP异常。检查soap信封,在我看来soap请求没有正确的命名空间。任何人都可以建议我
我想安装一个带有一些身份验证的私有(private)Rubygem服务器。我希望能够使用公共(public)Ubuntu服务器托管内部gem。我读到了http://docs.rubygems.org/read/chapter/18.但是那个没有身份验证-如我所见。然后我读到了https://github.com/cwninja/geminabox.但是当我使用基本身份验证(他们在他们的Wiki中有)时,它会提示从我的服务器获取源。所以。如何制作带有身份验证的私有(private)Rubygem服务器?这是不可能的吗?谢谢。编辑:Geminabox问题。我尝试“捆绑”以安装新的gem..
我的瘦服务器配置了nginx,我的ROR应用程序正在它们上运行。在我发布代码更新时运行thinrestart会给我的应用程序带来一些停机时间。我试图弄清楚如何优雅地重启正在运行的Thin实例,但找不到好的解决方案。有没有人能做到这一点? 最佳答案 #Restartjustthethinserverdescribedbythatconfigsudothin-C/etc/thin/mysite.ymlrestartNginx将继续运行并代理请求。如果您将Nginx设置为使用多个上游服务器,例如server{listen80;server
最近,当我启动我的Rails服务器时,我收到了一长串警告。虽然它不影响我的应用程序,但我想知道如何解决这些警告。我的估计是imagemagick以某种方式被调用了两次?当我在警告前后检查我的git日志时。我想知道如何解决这个问题。-bcrypt-ruby(3.1.2)-better_errors(1.0.1)+bcrypt(3.1.7)+bcrypt-ruby(3.1.5)-bcrypt(>=3.1.3)+better_errors(1.1.0)bcrypt和imagemagick有关系吗?/Users/rbchris/.rbenv/versions/2.0.0-p247/lib/ru
在Rails4.0.2中,我使用s3_direct_upload和aws-sdkgems直接为s3存储桶上传文件。在开发环境中它工作正常,但在生产环境中它会抛出如下错误,ActionView::Template::Error(noimplicitconversionofnilintoString)在View中,create_cv_url,:id=>"s3_uploader",:key=>"cv_uploads/{unique_id}/${filename}",:key_starts_with=>"cv_uploads/",:callback_param=>"cv[direct_uplo
我想在Ruby中创建一个用于开发目的的极其简单的Web服务器(不,不想使用现成的解决方案)。代码如下:#!/usr/bin/rubyrequire'socket'server=TCPServer.new('127.0.0.1',8080)whileconnection=server.acceptheaders=[]length=0whileline=connection.getsheaders想法是从命令行运行这个脚本,提供另一个脚本,它将在其标准输入上获取请求,并在其标准输出上返回完整的响应。到目前为止一切顺利,但事实证明这真的很脆弱,因为它在第二个请求上中断并出现错误:/usr/b
您如何在Rails中的实时服务器上进行有效调试,无论是在测试版/生产服务器上?我试过直接在服务器上修改文件,然后重启应用,但是修改好像没有生效,或者需要很长时间(缓存?)我也试过在本地做“脚本/服务器生产”,但是那很慢另一种选择是编码和部署,但效率很低。有人对他们如何有效地做到这一点有任何见解吗? 最佳答案 我会回答你的问题,即使我不同意这种热修补服务器代码的方式:)首先,你真的确定你已经重启了服务器吗?您可以通过跟踪日志文件来检查它。您更改的代码显示的View可能会被缓存。缓存页面位于tmp/cache文件夹下。您可以尝试手动删除
这篇文章是继上一篇文章“Observability:从零开始创建Java微服务并监控它(一)”的续篇。在上一篇文章中,我们讲述了如何创建一个Javaweb应用,并使用Filebeat来收集应用所生成的日志。在今天的文章中,我来详述如何收集应用的指标,使用APM来监控应用并监督web服务的在线情况。源码可以在地址 https://github.com/liu-xiao-guo/java_observability 进行下载。摄入指标指标被视为可以随时更改的时间点值。当前请求的数量可以改变任何毫秒。你可能有1000个请求的峰值,然后一切都回到一个请求。这也意味着这些指标可能不准确,你还想提取最小/
require"socket"server="irc.rizon.net"port="6667"nick="RubyIRCBot"channel="#0x40"s=TCPSocket.open(server,port)s.print("USERTesting",0)s.print("NICK#{nick}",0)s.print("JOIN#{channel}",0)这个IRC机器人没有连接到IRC服务器,我做错了什么? 最佳答案 失败并显示此消息::irc.shakeababy.net461*USER:Notenoughparame
我有一个使用PDFKit呈现网页的pdf版本的Rails应用程序。我使用Thin作为开发服务器。问题是当我处于开发模式时。当我使用“bundleexecrailss”启动我的服务器并尝试呈现任何PDF时,整个过程会陷入僵局,因为当您呈现PDF时,会向服务器请求一些额外的资源,如图像和css,看起来只有一个线程.如何配置Rails开发服务器以运行多个工作线程?非常感谢。 最佳答案 我找到的最简单的解决方案是unicorn.geminstallunicorn创建一个unicorn.conf:worker_processes3然后使用它: