8#include <daq/dqm/HistoServer2.h>
10#include <framework/pcore/MsgHandler.h>
19HistoServer2::HistoServer2(
int port,
const string& filename)
23 m_filename = filename;
26HistoServer2::~HistoServer2()
33int HistoServer2::init()
43int HistoServer2::server()
49 char* buffer =
new char[c_maxBufSize];
54 while (m_force_exit == 0) {
56 int exam_stat = m_man->examine();
58 }
else if (exam_stat == 1) {
60 vector<int>& recvsock = m_man->connected_socket_list();
61 for (vector<int>::iterator it = recvsock.begin();
62 it != recvsock.end(); ++it) {
64 if (m_man->connected(fd)) {
65 struct sockaddr_in isa;
66 socklen_t isize =
sizeof(isa);
67 getpeername(fd, (
struct sockaddr*)&isa, &isize);
68 char address[INET_ADDRSTRLEN];
69 strcpy(address, inet_ntoa(isa.sin_addr));
70 char* ptr = strrchr(address,
'.');
75 m_unit_last_conn_time[address] = now;
77 int is = sio.get(fd, buffer, c_maxBufSize);
80 strftime(mbstr,
sizeof(mbstr),
"%F %T", localtime(&now));
81 printf(
"[%s] HistoServer2: fd %d / %s disconnected\n", mbstr, fd, address);
90 vector<TObject*> objlist;
91 vector<string> strlist;
92 msghdl.decode_msg(hmsg, objlist, strlist);
93 int nobjs = (hmsg->
header())->reserved[1];
97 strftime(mbstr,
sizeof(mbstr),
"%F %T", localtime(&now));
98 m_unit_last_packet_time[address] = now;
99 printf(
"[%s] HistoServer2 : received nobjs = %d from %s\n", mbstr, nobjs, address);
100 if (nobjs > 0) m_unit_last_content_time[address] = now;
101 for (
int i = 0; i < nobjs; i++) {
104 string objname = strlist.at(i);
105 if (objname ==
string(
"DQMRC:CLEAR")) {
109 m_last_merge_time = time(0);
110 strftime(mbstr,
sizeof(mbstr),
"%F %T", localtime(&m_last_merge_time));
111 printf(
"[%s] HistoServer2: CLEAR\n", mbstr);
114 if (objname ==
string(
"DQMRC:MERGE")) {
117 m_last_merge_time = time(0);
118 strftime(mbstr,
sizeof(mbstr),
"%F %T", localtime(&m_last_merge_time));
119 printf(
"[%s] HistoServer2: MERGE\n", mbstr);
122 auto lpos = objname.find(
"DQMRC:SAVE:");
123 if (lpos != string::npos) {
124 auto filename = objname.substr(11);
125 m_hman->filedump(filename);
128 lpos = objname.find(
"SUBDIR:");
129 if (lpos != string::npos) {
130 subdir = objname.substr(7);
131 if (subdir ==
"EXIT") subdir =
"";
135 m_hman->update(subdir, strlist.at(i), fd, (TH1*)objlist.at(i));
144 if (loop_counter % c_mergeIntervall == 0) {
146 m_last_merge_time = time(0);
147 strftime(mbstr,
sizeof(mbstr),
"%F %T", localtime(&m_last_merge_time));
148 printf(
"[%s] HistoServer2: merging histograms\n", mbstr);
163 std::string name =
"/tmp/dqm_hserver_state_" + m_filename;
164 FILE* fh = fopen(name.c_str(),
"wt+");
166 time_t now = time(0);
167 strftime(mbstr,
sizeof(mbstr),
"%F %T", localtime(&now));
168 strftime(mbstr2,
sizeof(mbstr2),
"%F %T", localtime(&m_last_merge_time));
169 fprintf(fh,
"%s,%s,%s\n", m_filename.c_str(), mbstr, mbstr2);
172 int nr = it.second.first;
173 int con = it.second.second;
174 strftime(mbstr,
sizeof(mbstr),
"%F %T", localtime(&m_unit_last_conn_time[it.first]));
175 strftime(mbstr2,
sizeof(mbstr2),
"%F %T", localtime(&m_unit_last_packet_time[it.first]));
176 strftime(mbstr3,
sizeof(mbstr3),
"%F %T", localtime(&m_unit_last_content_time[it.first]));
177 if (it.first ==
"127.0.0.1") {
178 fprintf(fh,
"RUNCONTROL,");
180 if (nr >= 0 and nr < 20) {
181 fprintf(fh,
"HLT%d,", nr);
182 }
else if (nr > 100 and nr < 110) {
183 fprintf(fh,
"ERECO%d,", nr - 100);
185 fprintf(fh,
"UNKNOWN,");
188 fprintf(fh,
"%s,%d,%s,%s,%s\n", it.first.c_str(), con, mbstr, mbstr2, mbstr3);
Class to manage streamed object.
EvtHeader * header()
Get pointer to EvtHeader.
std::map< std::string, std::pair< int, bool > > m_units_connected
connection IP, state and last update time
void write_state(void)
Write connection state to a file.
A class to encode/decode an EvtMessage.
Abstract base class for different kinds of events.