Apache HTTPD
mod_logio.c
Go to the documentation of this file.
1/* Licensed to the Apache Software Foundation (ASF) under one or more
2 * contributor license agreements. See the NOTICE file distributed with
3 * this work for additional information regarding copyright ownership.
4 * The ASF licenses this file to You under the Apache License, Version 2.0
5 * (the "License"); you may not use this file except in compliance with
6 * the License. You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17/*
18 * Written by Bojan Smojver <bojan rexursive.com>.
19 */
20
21#include "apr_strings.h"
22#include "apr_lib.h"
23#include "apr_hash.h"
24#include "apr_optional.h"
25
26#define APR_WANT_STRFUNC
27#include "apr_want.h"
28
29#include "ap_config.h"
30#include "mod_log_config.h"
31#include "httpd.h"
32#include "http_core.h"
33#include "http_config.h"
34#include "http_connection.h"
35#include "http_protocol.h"
36#include "http_request.h"
37
38module AP_MODULE_DECLARE_DATA logio_module;
39
40static const char logio_filter_name[] = "LOG_INPUT_OUTPUT";
41static const char logio_ttfb_filter_name[] = "LOGIO_TTFB_OUT";
42
43/*
44 * Logging of input and output config...
45 */
46
52
53typedef struct logio_dirconf_t {
54 unsigned int track_ttfb:1;
56
60
61
62
63/*
64 * Optional function for the core to add to bytes_out
65 */
66
68{
69 logio_config_t *cf = ap_get_module_config(c->conn_config, &logio_module);
70 cf->bytes_out += bytes;
71}
72
73/*
74 * Optional function for modules to adjust bytes_in
75 */
76
78{
79 logio_config_t *cf = ap_get_module_config(c->conn_config, &logio_module);
80
81 cf->bytes_in += bytes;
82}
83
84/*
85 * Optional function to get total byte count of last request for
86 * ap_increment_counts.
87 */
88
90{
91 logio_config_t *cf = ap_get_module_config(c->conn_config, &logio_module);
92
93 return cf->bytes_last_request;
94}
95
96/*
97 * Format items...
98 */
99
100static const char *log_bytes_in(request_rec *r, char *a)
101{
103 &logio_module);
104
105 return apr_off_t_toa(r->pool, cf->bytes_in);
106}
107
108static const char *log_bytes_out(request_rec *r, char *a)
109{
111 &logio_module);
112
113 return apr_off_t_toa(r->pool, cf->bytes_out);
114}
115
116static const char *log_bytes_combined(request_rec *r, char *a)
117{
119 &logio_module);
120
121 return apr_off_t_toa(r->pool, cf->bytes_out + cf->bytes_in);
122}
123
124static const char *log_ttfb(request_rec *r, char *a)
125{
127 &logio_module);
128
129 if (!rconf || !rconf->ttfb) {
130 return "-";
131 }
132
133 return apr_psprintf(r->pool, "%" APR_TIME_T_FMT, rconf->ttfb);
134}
135/*
136 * Reset counters after logging...
137 */
138
140{
142 &logio_module);
143
144 /* need to save byte count of last request for ap_increment_counts */
145 cf->bytes_last_request = cf->bytes_in + cf->bytes_out;
146 cf->bytes_in = cf->bytes_out = 0;
147
148 return OK;
149}
150
151/*
152 * Logging of input filter...
153 */
154
160{
163 logio_config_t *cf = ap_get_module_config(f->c->conn_config, &logio_module);
164
165 status = ap_get_brigade(f->next, bb, mode, block, readbytes);
166
167 apr_brigade_length (bb, 0, &length);
168
169 if (length > 0)
170 cf->bytes_in += length;
171
172 return status;
173}
174
175/*
176 * The hooks...
177 */
178
179static int logio_pre_conn(conn_rec *c, void *csd)
180{
181 logio_config_t *cf = apr_pcalloc(c->pool, sizeof(*cf));
182
183 ap_set_module_config(c->conn_config, &logio_module, cf);
184
186
187 return OK;
188}
189
205
207{
208 request_rec *r = f->r;
210 &logio_module);
211 if (conf && conf->track_ttfb) {
213 &logio_module);
214 if (rconf == NULL) {
215 rconf = apr_pcalloc(r->pool, sizeof(logio_req_t));
216 rconf->ttfb = apr_time_now() - r->request_time;
217 ap_set_module_config(r->request_config, &logio_module, rconf);
218 }
219 }
221 return ap_pass_brigade(f->next, b);
222}
223
225{
227 &logio_module);
228 if (conf->track_ttfb) {
230 }
231}
232
233static const char *logio_track_ttfb(cmd_parms *cmd, void *in_dir_config, int arg)
234{
237 return NULL;
238}
239
241{
242 logio_dirconf_t *new =
244 return (void *) new;
245}
246
247
248static const command_rec logio_cmds[] = {
249 AP_INIT_FLAG ("LogIOTrackTTFB", logio_track_ttfb, NULL, OR_ALL,
250 "Set to 'ON' to enable tracking time to first byte"),
251 {NULL}
252};
253
254
274
276{
278 create_logio_dirconf, /* create per-dir config */
279 NULL, /* merge per-dir config */
280 NULL, /* server config */
281 NULL, /* merge server config */
282 logio_cmds, /* command apr_table_t */
283 register_hooks /* register hooks */
284};
Symbol export macros and hook functions.
APR Hash Tables.
APR general purpose library routines.
APR-UTIL registration of functions exported by modules.
APR Strings library.
APR Standard Headers Support.
void ap_hook_pre_connection(ap_HOOK_pre_connection_t *pf, const char *const *aszPre, const char *const *aszSucc, int nOrder)
Definition connection.c:43
#define ap_get_module_config(v, m)
#define AP_DECLARE_MODULE(foo)
#define AP_INIT_FLAG(directive, func, mconfig, where, help)
#define ap_set_module_config(v, m, val)
void ap_hook_pre_config(ap_HOOK_pre_config_t *pf, const char *const *aszPre, const char *const *aszSucc, int nOrder)
Definition config.c:91
request_rec * r
void * csd
#define OK
Definition httpd.h:456
apr_status_t ap_pass_brigade(ap_filter_t *filter, apr_bucket_brigade *bucket)
ap_filter_t * ap_add_input_filter(const char *name, void *ctx, request_rec *r, conn_rec *c)
ap_filter_rec_t * ap_register_output_filter(const char *name, ap_out_filter_func filter_func, ap_init_filter_func filter_init, ap_filter_type ftype)
ap_filter_t * ap_add_output_filter(const char *name, void *ctx, request_rec *r, conn_rec *c)
apr_status_t ap_filter_rec_t * ap_register_input_filter(const char *name, ap_in_filter_func filter_func, ap_init_filter_func filter_init, ap_filter_type ftype)
apr_status_t ap_get_brigade(ap_filter_t *filter, apr_bucket_brigade *bucket, ap_input_mode_t mode, apr_read_type_e block, apr_off_t readbytes)
void ap_remove_output_filter(ap_filter_t *f)
@ AP_FTYPE_NETWORK
@ AP_FTYPE_RESOURCE
void ap_hook_log_transaction(ap_HOOK_log_transaction_t *pf, const char *const *aszPre, const char *const *aszSucc, int nOrder)
Definition protocol.c:2587
void ap_hook_insert_filter(ap_HOOK_insert_filter_t *pf, const char *const *aszPre, const char *const *aszSucc, int nOrder)
Definition request.c:96
void * dummy
Definition http_vhost.h:62
void const char * arg
Definition http_vhost.h:63
apr_file_t * f
apr_read_type_e
Definition apr_buckets.h:57
apr_bucket apr_bucket_brigade * a
int apr_off_t * length
apr_dbd_transaction_t int mode
Definition apr_dbd.h:261
#define APR_HOOK_LAST
Definition apr_hooks.h:305
#define APR_HOOK_REALLY_FIRST
Definition apr_hooks.h:299
#define APR_HOOK_MIDDLE
Definition apr_hooks.h:303
#define APR_RETRIEVE_OPTIONAL_FN(name)
#define APR_OPTIONAL_FN_TYPE(name)
#define APR_REGISTER_OPTIONAL_FN(name)
#define OR_ALL
#define STANDARD20_MODULE_STUFF
apr_size_t size
int apr_status_t
Definition apr_errno.h:44
apr_vformatter_buff_t * c
Definition apr_lib.h:175
apr_pool_t * b
Definition apr_pools.h:529
#define apr_pcalloc(p, size)
Definition apr_pools.h:465
const void apr_size_t bytes
Definition apr_random.h:91
apr_cmdtype_e cmd
int int status
#define APR_TIME_T_FMT
Definition apr_time.h:52
apr_int64_t apr_time_t
Definition apr_time.h:45
Apache Configuration.
Apache connection library.
CORE HTTP Daemon.
HTTP protocol handling.
Apache Request library.
HTTP Daemon routines.
apr_pool_t * p
Definition md_event.c:32
static void ap_register_log_handler(apr_pool_t *p, char *tag, ap_log_handler_fn_t *handler, int def)
Logging Configuration Extension Module for Apache.
static void ap_logio_add_bytes_in(conn_rec *c, apr_off_t bytes)
Definition mod_logio.c:77
static const char * log_bytes_in(request_rec *r, char *a)
Definition mod_logio.c:100
static int logio_pre_conn(conn_rec *c, void *csd)
Definition mod_logio.c:179
static const char * logio_track_ttfb(cmd_parms *cmd, void *in_dir_config, int arg)
Definition mod_logio.c:233
static int logio_transaction(request_rec *r)
Definition mod_logio.c:139
static const char logio_filter_name[]
Definition mod_logio.c:40
static apr_off_t ap_logio_get_last_bytes(conn_rec *c)
Definition mod_logio.c:89
static const char * log_bytes_out(request_rec *r, char *a)
Definition mod_logio.c:108
static void ap_logio_add_bytes_out(conn_rec *c, apr_off_t bytes)
Definition mod_logio.c:67
static const char * log_ttfb(request_rec *r, char *a)
Definition mod_logio.c:124
static void register_hooks(apr_pool_t *p)
Definition mod_logio.c:255
static int logio_pre_config(apr_pool_t *p, apr_pool_t *plog, apr_pool_t *ptemp)
Definition mod_logio.c:190
static apr_status_t logio_in_filter(ap_filter_t *f, apr_bucket_brigade *bb, ap_input_mode_t mode, apr_read_type_e block, apr_off_t readbytes)
Definition mod_logio.c:155
static apr_status_t logio_ttfb_filter(ap_filter_t *f, apr_bucket_brigade *b)
Definition mod_logio.c:206
static const char logio_ttfb_filter_name[]
Definition mod_logio.c:41
static void logio_insert_filter(request_rec *r)
Definition mod_logio.c:224
static const char * log_bytes_combined(request_rec *r, char *a)
Definition mod_logio.c:116
static const command_rec logio_cmds[]
Definition mod_logio.c:248
static void * create_logio_dirconf(apr_pool_t *p, char *dummy)
Definition mod_logio.c:240
return NULL
Definition mod_so.c:359
The representation of a filter chain.
Structure to store things which are per connection.
Definition httpd.h:1152
struct ap_conf_vector_t * conn_config
Definition httpd.h:1190
apr_off_t bytes_in
Definition mod_logio.c:48
apr_off_t bytes_last_request
Definition mod_logio.c:50
apr_off_t bytes_out
Definition mod_logio.c:49
unsigned int track_ttfb
Definition mod_logio.c:54
apr_time_t ttfb
Definition mod_logio.c:58
A structure that represents the current request.
Definition httpd.h:845
apr_pool_t * pool
Definition httpd.h:847
apr_time_t request_time
Definition httpd.h:886
conn_rec * connection
Definition httpd.h:849
struct ap_conf_vector_t * request_config
Definition httpd.h:1049
struct ap_conf_vector_t * per_dir_config
Definition httpd.h:1047
ap_input_mode_t
input filtering modes
Definition util_filter.h:41