mod_caucho.c

来自「《jsp编程起步》里面的所有源代码」· C语言 代码 · 共 884 行 · 第 1/2 页

C
884
字号
    }    */    s->read_offset += sublen;    len -= sublen;  }    ap_rflush(r);  return 1;}/** * Copy data from the JVM to the browser. */static intsend_data(stream_t *s, request_rec *r, int ack, int *keepalive){  int code = CSE_END;  char buf[8193];  char key[8193];  char value[8193];  int i;    do {    int l1, l2, l3;    int len;    ap_reset_timeout(r);        code = cse_read_byte(s);    l1 = cse_read_byte(s) & 0xff;    l2 = cse_read_byte(s) & 0xff;    l3 = cse_read_byte(s);    len = (l1 << 16) + (l2 << 8) + (l3 & 0xff);    if (s->socket < 0)      return -1;    switch (code) {    case CSE_STATUS:      cse_read_all(s, buf, len);      buf[len] = 0;      for (i = 0; buf[i] && buf[i] != ' '; i++) {      }      i++;      r->status = atoi(buf + i);      r->status_line = ap_pstrdup(r->pool, buf + i);      break;    case CSE_HEADER:      cse_read_all(s, key, len);      key[len] = 0;      cse_read_string(s, value, sizeof(value));      if (! strcasecmp(key, "content-type"))	r->content_type = ap_pstrdup(r->pool, value);      else if (! strcasecmp(key, "set-cookie"))	ap_table_add(r->headers_out, key, value);      else	ap_table_set(r->headers_out, key, value);      break;    case CSE_DATA:      if (cse_write_response(s, len, r) < 0)	return -1;      break;    case CSE_KEEPALIVE:      *keepalive = 1;      break;    case CSE_SEND_HEADER:      ap_send_http_header(r);      break;    case -1:      break;    default:      cse_read_all(s, buf, len);      break;    }  } while (code > 0 && code != CSE_END && code != CSE_CLOSE && code != ack);  return code;}/** * handles a client request */static intwrite_request(stream_t *s, request_rec *r, config_t *config, int *keepalive){  int len;  int code;  write_env(s, r);  write_headers(s, r);  /* read post data */  if (ap_should_client_block(r)) {    char buf[BUF_LENGTH];    int isFirst = 1;    while ((len = ap_get_client_block(r, buf, BUF_LENGTH)) > 0) {      ap_reset_timeout(r);      if (! isFirst) {	code = send_data(s, r, CSE_ACK, keepalive);	if (code < 0 || code == CSE_END || code == CSE_CLOSE)	  break;      }      cse_write_packet(s, CSE_DATA, buf, len);      isFirst = 0;    }  }  cse_write_packet(s, CSE_END, 0, 0);  code = send_data(s, r, CSE_END, keepalive);    return code == CSE_END;}/** * Handle a request. */static intcaucho_request(request_rec *r){  config_t *config = cse_get_module_config(r->server);  stream_t s;  int retval;  int keepalive = 0;  int reuse;  int session_index;  char *ip;  if ((retval = ap_setup_client_block(r, REQUEST_CHUNKED_ERROR)))    return retval;  ap_soft_timeout("servlet request", r);  session_index = get_session_index(r);  ip = r->connection->remote_ip;   if (! cse_open_connection(&s, config, session_index, ip,			  r->request_time, r->pool)) {    connection_error(config, config->srun_list, r);      ap_kill_timeout(r);    return OK;  }  reuse = write_request(&s, r, config, &keepalive);    ap_kill_timeout(r);  ap_rflush(r);  if (reuse)    cse_recycle(&s);  else    cse_close(&s, "no reuse");  return OK;}/** * Print the statistics for each JVM. */static voidjvm_status(config_t *config, request_rec *r){  int i;  stream_t s;  int code;  ap_rputs("<center><table border=2 cellspacing=0 cellpadding=2 width='60%'>\n", r);  ap_rputs("<tr><th>Host\n", r);  ap_rputs("    <th>Minute<br>%cpu/thread\n", r);  ap_rputs("    <th>Hour<br>%cpu/thread\n", r);  ap_rputs("    <th>Day<br>%cpu/thread\n", r);  for (i = 0; i < config->srun_size; i++) {    srun_t *srun = config->srun_list + i;    int port = srun->port;    ap_rputs("<tr>", r);    if (! cse_open(&s, config, srun, r->pool)) {      ap_rprintf(r, "<td bgcolor='#ff6666'>%s:%d%s</td><td colspan=3>&nbsp;",	       srun->hostname ? srun->hostname : "localhost",	       port, srun->is_backup ? "*" : "");    }    else {      char buf[8193];      FILE *file;      registry_t *reg;       ap_rprintf(r, "<td bgcolor='#66ff66'>%s:%d%s</td>",	       srun->hostname ? srun->hostname : "localhost",	       port, srun->is_backup ? "*" : "");      if (1) {	cse_recycle(&s);	continue;      }            cse_write_string(&s, CSE_URI, "/servlet/com.caucho.server.http.AdminServlet/xml");      cse_write_string(&s, CSE_PROTOCOL, "HTTP/0.9");      cse_write_string(&s, CSE_END, "");      cse_write_string(&s, CSE_CLOSE, "");      code = cse_read_string(&s, buf, sizeof(buf));      cse_close(&s, "status");      unlink("/tmp/caucho.stat");      file = fopen("/tmp/caucho.stat", "w+");      if (! file)	continue;      fprintf(file, "%s\n", buf);      fclose(file);      reg = 0;      file = fopen("/tmp/caucho.stat", "r");      config->pool = r->pool;      if (file) {	reg = cse_parse(file, config);      	fclose(file);      }      if (reg && (reg = cse_next_link(reg->first, "resin-stats"))) {	registry_t *group;	registry_t *data;	group = cse_next_link(reg->first, "minute");	if (group && (data = cse_next_link(group->first, "cpu-usage"))) {	  double v = atof(data->value);	  ap_rprintf(r, "<td>%.2f", v);	}	else	  ap_rprintf(r, "<td>--");		if (group && (data = cse_next_link(group->first, "threads"))) {	  double v = atof(data->value);	  ap_rprintf(r, "/%.2f", v);	}	else	  ap_rprintf(r, "/--");	group = cse_next_link(reg->first, "hour");	if (group && (data = cse_next_link(group->first, "cpu-usage"))) {	  double v = atof(data->value);	  ap_rprintf(r, "<td>%.2f", v);	}	else	  ap_rprintf(r, "<td>--");		if (group && (data = cse_next_link(group->first, "threads"))) {	  double v = atof(data->value);	  ap_rprintf(r, "/%.2f", v);	}	else	  ap_rprintf(r, "/--");	group = cse_next_link(reg->first, "day");	if (group && (data = cse_next_link(group->first, "cpu-usage"))) {	  double v = atof(data->value);	  ap_rprintf(r, "<td>%.2f", v);	}	else	  ap_rprintf(r, "<td>--");		if (group && (data = cse_next_link(group->first, "threads"))) {	  double v = atof(data->value);	  ap_rprintf(r, "/%.2f", v);	}	else	  ap_rprintf(r, "/--");      }    }    ap_rputs("</tr>\n", r);  }  ap_rputs("</table></center>\n", r);}/** * Print a summary of the configuration so users can understand what's * going on.  Ping the server to check that it's up. */static intcaucho_status(request_rec *r){  config_t *config = cse_get_module_config(r->server);  location_t *loc;   r->content_type = "text/html";  ap_soft_timeout("caucho status", r);  if (r->header_only) {    ap_kill_timeout(r);    return OK;  }  ap_send_http_header(r);  ap_rputs("<html><title>Status : Caucho Servlet Engine</title>\n", r);  ap_rputs("<body bgcolor=white>\n", r);  ap_rputs("<h1>Status : Caucho Servlet Engine</h1>\n", r);    jvm_status(config, r);  ap_rputs("<p><center><table border=2 cellspacing=0 cellpadding=2 width='60%'>\n", r);  ap_rputs("<tr><th width='50%'>Host\n", r);  ap_rputs("    <th>url-pattern\n", r);    loc = config ? config->locations : 0;  for (; loc; loc = loc->next) {    ap_rprintf(r, "<tr bgcolor='#ffcc66'><td>%s<td>%s%s%s%s</tr>\n", 	       loc->host && loc->host[0] ? loc->host : "*",	       loc->prefix,	       ! loc->is_exact && ! loc->suffix ? "/*" : 	       loc->suffix && loc->prefix[0] ? "/" : "",	       loc->suffix ? "*" : "",	       loc->suffix ? loc->suffix : "");  }  ap_rputs("</table></center>\n", r);  ap_rputs("</body></html>\n", r);  ap_kill_timeout(r);  return OK;}/** * When a child process starts, clear the srun structure so it doesn't * mistakenly think the old sockets areopen. */static voidcse_open_child(server_rec *server, pool *p){  config_t *config = cse_get_module_config(server);  int i;  cse_log("open child\n");  for (i = 0; i < config->srun_size; i++) {    srun_t *srun = config->srun_list + i;    srun->n_sockets = 0;    srun->max_sockets = 32;    srun->is_dead = 0;    srun->last_time = 0;  }}static voidcse_close_child(server_rec *server, pool *p){  config_t *config = cse_get_module_config(server);  int i;    LOG(("close child\n"));  for (i = 0; i < config->srun_size; i++) {    srun_t *srun = config->srun_list + i;    while (srun->n_sockets > 0) {      int socket = srun->sockets[--srun->n_sockets];            send(socket, "X\0\0\0", 4, 0);      closesocket(socket);    }    srun->n_sockets = 0;  }}/* * Only needed configuration is pointer to resin.conf */static command_rec caucho_commands[] = {    {"CauchoConfigFile", cse_config_file_command, NULL, RSRC_CONF, TAKE1,     "Pointer to the Caucho configuration file."},    {"CauchoHost", cse_host_command, NULL, RSRC_CONF, TAKE12,     "Servlet runner host."},    {"CauchoBackup", cse_backup_command, NULL, RSRC_CONF, TAKE12,     "Servlet runner backup."},    {"CauchoKeepalive", cse_keepalive_command, NULL, RSRC_CONF, FLAG,     "keeps srun connections alive."},    {"CauchoErrorPage", cse_error_page_command, NULL, RSRC_CONF, TAKE1,     "Error page when connections fail."},    {NULL}};/* * Caucho right has two content handlers: * caucho-status: summary information for debugging * caucho-request: dispatch a Caucho request */static const handler_rec caucho_handlers[] ={    {"caucho-status", caucho_status},    {"caucho-request", caucho_request},    {NULL}};/*  * module configuration */module caucho_module ={    STANDARD_MODULE_STUFF,    cse_module_init,            /* module initializer */    NULL,                       /* per-directory config creator */    NULL,                       /* dir config merger */    cse_create_server_config,   /* server config creator */    NULL,                       /* server config merger */    caucho_commands,            /* command table */    caucho_handlers,            /* [7] list of handlers */    NULL,                       /* [2] filename-to-URI translation */    NULL,                       /* [5] check/validate user_id */    NULL,                       /* [6] check user_id is valid *here* */    NULL,                       /* [4] check access by host address */    cse_dispatch,               /* [7] MIME type checker/setter */    NULL,                       /* [8] fixups */    NULL,                       /* [10] logger */    NULL,                       /* [3] header parser */#if MODULE_MAGIC_NUMBER > 19970719    cse_open_child,             /* apache child process init */    cse_close_child,            /* apache child process exit/cleanup */    NULL                        /* [1] post read_request handling */#endif};

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?