В моем журнале Apache mod_jk есть записи в следующем формате:
[Wed Oct 26 10:59:43 2011] [3732:2460] [error] jk_ajp_common.c (1618): (myJbossServer) Tomcat is down or network problems. Part of the response has already been sent to the client
Руководство по устранению неполадок RedHat говорит,
Обратите внимание, что в этих сообщениях часть сообщения [11159: 3086420192] служит идентификатором для рассматриваемого соединения / запроса. Таким образом, отслеживание в журналах с момента возникновения ошибки может помочь прояснить действия, связанные с подключением / запросом, которые привели к ошибке.
Как мне это сделать? Я не могу найти идентификатор в журналах JBoss. Я не вижу никаких идентификаторов в журналах JBoss, ошибок, да, номеров отслеживания, нет. Где мне нужно искать, чтобы отследить этот идентификатор? Я не особо ищу решение проблемы, только как использовать идентификатор и проверять между Apache mod_jk и Jboss.
РЕДАКТИРОВАТЬ: Я спрашиваю, где я могу найти идентификатор [3732: 2460] в журналах myJBossServer.
На самом деле это перед вами, отказавший рабочий - это тот, который находится в скобках, и называется myJbossServer.
Проверьте ваши worker.properties для этого воркера, и вы найдете его IP или имя хоста.
Надеюсь, что примерно в это время вы получите подсказки от JBoss / операционной системы (sar get очень удобен, если у вас возникли проблемы с CPU / Memory / ecc BTW).
На самом деле вы меня заинтересовали цифры в квадратных скобках. Я попытался выполнить поиск в документации, но не смог найти, что это было. Хотя проверка исходного кода показала следующее:
int jk_log(jk_logger_t *l,
const char *file, int line, const char *funcname, int level,
const char *fmt, ...)
{
...
if (line) { /* line==0 only used for request log item */
/* Log [pid:threadid] for all levels except REQUEST.
* This information helps to correlate lines from different logs.
* Performance is no issue, because with production log levels
* we only call it often, if we have a lot of errors
*/
rc = snprintf(buf + used, usable_size - used,
"[%" JK_PID_T_FMT ":%" JK_PTHREAD_T_FMT "] ", getpid(), jk_gettid());
Глядя на вставленный вами документ RedHat, эта идентификация PID: TOD может помочь сопоставить тот же самый mod_jk.log, который вы видите, а не перекрестную ссылку на mod_jk.log с JBoss. Если вы хотите связать два журнала с перекрестными ссылками, вам следует найти другой способ, установив собственный заголовок в Apache / mod_jk и распечатав его в журнале JBoss, это первый способ, о котором я подумал прямо сейчас. Или, по крайней мере, вы можете проверить запросы во время сбоя.