我有一种感觉,我错过了明显的,但没有成功的man [curl|wget]或谷歌(“http”使如此糟糕的搜索词)。我正在寻找一个快速和肮脏的修复我们的网络服务器之一,经常失败,返回状态码500与错误消息。一旦发生这种情况,就需要重新启动。

由于根本原因似乎很难找到,我们的目标是快速修复,希望这将足以弥补时间,直到我们真正修复它(服务不需要高可用性)

建议的解决方案是创建一个每5分钟运行一次的cron作业,检查http://localhost:8080/。如果返回状态码为500,则web服务器将重新启动。服务器将在一分钟内重新启动,因此不需要检查已经在运行的重新启动。

所讨论的服务器是ubuntu 8.04最小安装,只安装了足够运行当前所需的包。在bash中执行该任务没有硬性要求,但我希望它能在这样一个最小的环境中运行,而不需要安装任何解释器。

(我非常熟悉脚本,命令/选项将http状态代码分配给一个环境变量就足够了——这是我一直在寻找的,但没有找到。)


当前回答

假设您已经为应用程序实现了一个停止和启动脚本。创建一个如下所示的脚本,检查应用程序url的http状态,并在出现502时重新启动:

httpStatusCode=$(curl -s -o /dev/null -w "%{http_code}" https://{your_url}/) if [$httpStatusCode = 502];然后执行sh /{path_to_folder}/stopscript.sh sh /{path_to_folder}/startscript.sh fi .sh

实现一个cron作业,每5分钟调用一次这个脚本。假设上面的脚本名为checkBootAndRestart.sh。那么你的crontab应该看起来像- */5 * * * */ {path_to_folder}/checkBootAndRestart.sh

其他回答

遵循3XX重定向并打印所有请求的响应代码:

HTTP_STATUS="$(curl -IL --silent example.com | grep HTTP )";    
echo "${HTTP_STATUS}";

补充一下@DennisWilliamson的评论:

@VaibhavBajpai:试试这个:response=$(curl——write-out \n%{http_code}——silent——output - servername) -结果中的最后一行将是响应代码

然后,您可以使用类似以下的代码从响应中解析响应代码,其中X可以表示一个regex,以标记响应的结束(此处使用json示例)

X='*\}'
code=$(echo ${response##$X})

参见子字符串移除:http://tldp.org/LDP/abs/html/string-manipulation.html

另一个变化:

       status=$(curl -sS  -I https://www.healthdata.gov/user/login  2> /dev/null | head -n 1 | cut -d' ' -f2)
status_w_desc=$(curl -sS  -I https://www.healthdata.gov/user/login  2> /dev/null | head -n 1 | cut -d' ' -f2-)

假设您已经为应用程序实现了一个停止和启动脚本。创建一个如下所示的脚本,检查应用程序url的http状态,并在出现502时重新启动:

httpStatusCode=$(curl -s -o /dev/null -w "%{http_code}" https://{your_url}/) if [$httpStatusCode = 502];然后执行sh /{path_to_folder}/stopscript.sh sh /{path_to_folder}/startscript.sh fi .sh

实现一个cron作业,每5分钟调用一次这个脚本。假设上面的脚本名为checkBootAndRestart.sh。那么你的crontab应该看起来像- */5 * * * */ {path_to_folder}/checkBootAndRestart.sh

这可以帮助评估HTTP状态

var=`curl -I http://www.example.org 2>/dev/null | head -n 1 | awk -F" " '{print $2}'`
echo http:$var