RRDCGI(1) rrdtool RRDCGI(1) NNAAMMEE rrdcgi - create web pages containing RRD graphs based on templates SSYYNNOOPPSSIISS #!/path/to/rrrrddccggii [----ggooooddffoorr|--gg _s_e_c_o_n_d_s] [----ffiilltteerr] [----rreeffrreesshh|--rr] DDEESSCCRRIIPPTTIIOONN rrrrddccggii is a sort of very limited script interpreter. Its purpose is to run as a cgi-program and parse a web page template containing special might give you the name of the remote user given you are using some sort of access control on the directory PPaassss 22 RRD::GOODFOR _s_e_c_o_n_d_s Specify the number of seconds this page should remain valid. This will prompt the rrdcgi to out­ put a Last-Modified, an Expire and if the number of seconds is _n_e_g_a_t_i_v_e a Refresh headers. RRD::INCLUDE _f_i_l_e_n_a_m_e Include the contents of the given file into the page returned from the cgi RRD::SETENV _v_a_r_i_a_b_l_e _v_a_l_u_e If you want to present your graphs in another time zone than your own, you could use to make sure everything is presented in Universal Time. Note that the values permitted to TZ depend on your OS. RRD::TIME::LAST _r_r_d_-_f_i_l_e _s_t_r_f_t_i_m_e_-_f_o_r_m_a_t This gets replaced by the last modification time of the selected RRD. The time is _s_t_r_f_t_i_m_e-formated with the string specified in the second argument. RRD::TIME::NOW _s_t_r_f_t_i_m_e_-_f_o_r_m_a_t This gets replaced by the current time of day. The time is _s_t_r_f_t_i_m_e-formated with the string speci­ fied in the argument. PPaassss 33 RRD::GRAPH _r_r_d_g_r_a_p_h _a_r_g_u_m_e_n_t_s This tag creates the RRD graph defined in its argument and then gets replaced by an appropriate tag referring to the graph. The ----llaazzyy option in RRD graph can be used to make sure that graphs are only regenerated when they are out of date. The arguments to the RRRRDD::::GGRRAAPPHH tag work as described in the rrrrddggrraapphh manual page. Use the ----llaazzyy option in your RRD::GRAPH tags, to reduce the load on your server. This option makes sure that graphs are only regenerated when the old ones are out of date. If you do not specify your own ----iimmggiinnffoo format, the following will be used: Note that %s stands for the filename part of the graph generated, all directories given in the GIF file argument will get dropped. RRD::PRINT _n_u_m_b_e_r If the preceding RRRRDD::::GGRRAAPPHH tag contained and PPRRIINNTT arguments, then you can access their output with this tag. The _n_u_m_b_e_r argument refers to the number of the PPRRIINNTT argument. This first PPRRIINNTT has _n_u_m_b_e_r 0. EEXXAAMMPPLLEE 11 The example below creates a web pages with a single RRD graph. #!/usr/local/bin/rrdcgi RRDCGI Demo

RRDCGI Example Page

EEXXAAMMPPLLEE 22 This script is slightly more elaborate, it allows you to run it from a form which sets RRD_NAME. RRD_NAME is then used to select which RRD you want to use a source for your graph. #!/usr/local/bin/rrdcgi RRDCGI Demo

RRDCGI Example Page for

Selection

Room A, Room B.

Graph

.gif --lazy --title "Temperatures for " DEF:cel=.rrd:exhaust:AVERAGE LINE2:cel#00a000:"D. Celsius">

EEXXAAMMPPLLEE 33 This example shows how to handle the case where the RRD, graphs and cgi-bins are seperate directories #!/.../bin/rrdcgi RRDCGI Demo

RRDCGI test Page

' --lazy --start -1d --end now DEF:http_src=/.../rrds/test.rrd:http_src:AVERAGE AREA:http_src#00ff00:http_src > Note 1: Replace /.../ with the relevant directories Note 2: The SRC=/.../gifs should be paths from the view of the webserver/browser AAUUTTHHOORR Tobias Oetiker 1.0.35 2001-02-21 RRDCGI(1)