mirror of
https://github.com/FairRootGroup/FairMQ.git
synced 2025-10-13 16:46:47 +00:00
Add ParameterMQServer and example of its use
This commit is contained in:
parent
19b3347ade
commit
2e789e4439
|
@ -18,6 +18,7 @@ EndIf(DDS_FOUND)
|
|||
add_subdirectory(examples/4-copypush)
|
||||
add_subdirectory(examples/5-req-rep)
|
||||
add_subdirectory(examples/6-multiple-channels)
|
||||
add_subdirectory(examples/7-parameters)
|
||||
|
||||
add_subdirectory(test)
|
||||
|
||||
|
|
96
fairmq/examples/7-parameters/CMakeLists.txt
Normal file
96
fairmq/examples/7-parameters/CMakeLists.txt
Normal file
|
@ -0,0 +1,96 @@
|
|||
################################################################################
|
||||
# Copyright (C) 2014 GSI Helmholtzzentrum fuer Schwerionenforschung GmbH #
|
||||
# #
|
||||
# This software is distributed under the terms of the #
|
||||
# GNU Lesser General Public Licence version 3 (LGPL) version 3, #
|
||||
# copied verbatim in the file "LICENSE" #
|
||||
################################################################################
|
||||
|
||||
configure_file(${CMAKE_SOURCE_DIR}/fairmq/examples/7-parameters/ex7-client.json ${CMAKE_BINARY_DIR}/bin/config/ex7-client.json)
|
||||
|
||||
Set(INCLUDE_DIRECTORIES
|
||||
${BASE_INCLUDE_DIRECTORIES}
|
||||
${CMAKE_SOURCE_DIR}/fairmq
|
||||
${CMAKE_SOURCE_DIR}/fairmq/devices
|
||||
${CMAKE_SOURCE_DIR}/fairmq/tools
|
||||
${CMAKE_SOURCE_DIR}/fairmq/options
|
||||
${CMAKE_SOURCE_DIR}/fairmq/examples/7-parameters
|
||||
${CMAKE_CURRENT_BINARY_DIR}
|
||||
)
|
||||
|
||||
Set(SYSTEM_INCLUDE_DIRECTORIES
|
||||
${SYSTEM_INCLUDE_DIRECTORIES}
|
||||
${Boost_INCLUDE_DIR}
|
||||
)
|
||||
|
||||
If(NANOMSG_FOUND)
|
||||
Set(INCLUDE_DIRECTORIES
|
||||
${INCLUDE_DIRECTORIES}
|
||||
${CMAKE_SOURCE_DIR}/fairmq/nanomsg
|
||||
)
|
||||
Set(SYSTEM_INCLUDE_DIRECTORIES
|
||||
${SYSTEM_INCLUDE_DIRECTORIES}
|
||||
${ZMQ_INCLUDE_DIR}
|
||||
)
|
||||
Else(NANOMSG_FOUND)
|
||||
Set(INCLUDE_DIRECTORIES
|
||||
${INCLUDE_DIRECTORIES}
|
||||
${CMAKE_SOURCE_DIR}/fairmq/zeromq
|
||||
)
|
||||
Set(SYSTEM_INCLUDE_DIRECTORIES
|
||||
${SYSTEM_INCLUDE_DIRECTORIES}
|
||||
${ZMQ_INCLUDE_DIR}
|
||||
)
|
||||
EndIf(NANOMSG_FOUND)
|
||||
|
||||
Include_Directories(${INCLUDE_DIRECTORIES})
|
||||
Include_Directories(SYSTEM ${SYSTEM_INCLUDE_DIRECTORIES})
|
||||
|
||||
Set(LINK_DIRECTORIES
|
||||
${Boost_LIBRARY_DIRS}
|
||||
${ROOT_LIBRARY_DIR}
|
||||
)
|
||||
|
||||
Link_Directories(${LINK_DIRECTORIES})
|
||||
|
||||
set(SRCS
|
||||
"FairMQExample7ParOne.cxx"
|
||||
"FairMQExample7ContFact.cxx"
|
||||
)
|
||||
|
||||
Set(NO_DICT_SRCS
|
||||
"FairMQExample7Client.cxx"
|
||||
)
|
||||
|
||||
set(DEPENDENCIES
|
||||
${DEPENDENCIES}
|
||||
FairMQ
|
||||
Base
|
||||
MCStack
|
||||
)
|
||||
|
||||
set(LINKDEF "FairMQExample7LinkDef.h")
|
||||
|
||||
set(LIBRARY_NAME FairMQExample7)
|
||||
|
||||
GENERATE_LIBRARY()
|
||||
|
||||
set(Exe_Names
|
||||
ex7-client
|
||||
)
|
||||
|
||||
set(Exe_Source
|
||||
runExample7Client.cxx
|
||||
)
|
||||
|
||||
list(LENGTH Exe_Names _length)
|
||||
math(EXPR _length ${_length}-1)
|
||||
|
||||
ForEach(_file RANGE 0 ${_length})
|
||||
list(GET Exe_Names ${_file} _name)
|
||||
list(GET Exe_Source ${_file} _src)
|
||||
set(EXE_NAME ${_name})
|
||||
set(SRCS ${_src})
|
||||
set(DEPENDENCIES FairMQExample7)
|
||||
GENERATE_EXECUTABLE()
|
||||
EndForEach(_file RANGE 0 ${_length})
|
130
fairmq/examples/7-parameters/FairMQExample7Client.cxx
Normal file
130
fairmq/examples/7-parameters/FairMQExample7Client.cxx
Normal file
|
@ -0,0 +1,130 @@
|
|||
/********************************************************************************
|
||||
* Copyright (C) 2014 GSI Helmholtzzentrum fuer Schwerionenforschung GmbH *
|
||||
* *
|
||||
* This software is distributed under the terms of the *
|
||||
* GNU Lesser General Public Licence version 3 (LGPL) version 3, *
|
||||
* copied verbatim in the file "LICENSE" *
|
||||
********************************************************************************/
|
||||
/**
|
||||
* FairMQExample7Client.cpp
|
||||
*
|
||||
* @since 2015-10-26
|
||||
* @author A. Rybalchenko
|
||||
*/
|
||||
|
||||
#include <boost/thread.hpp>
|
||||
#include <boost/bind.hpp>
|
||||
|
||||
#include "FairMQLogger.h"
|
||||
#include "FairMQExample7Client.h"
|
||||
#include "FairMQExample7ParOne.h"
|
||||
|
||||
#include "TMessage.h"
|
||||
#include "Rtypes.h"
|
||||
|
||||
using namespace std;
|
||||
|
||||
FairMQExample7Client::FairMQExample7Client() :
|
||||
fRunId(0),
|
||||
fParameterName()
|
||||
{
|
||||
}
|
||||
|
||||
FairMQExample7Client::~FairMQExample7Client()
|
||||
{
|
||||
}
|
||||
|
||||
void FairMQExample7Client::CustomCleanup(void *data, void *hint)
|
||||
{
|
||||
delete (string*)hint;
|
||||
}
|
||||
|
||||
// special class to expose protected TMessage constructor
|
||||
class FairMQExample7TMessage : public TMessage
|
||||
{
|
||||
public:
|
||||
FairMQExample7TMessage(void* buf, Int_t len)
|
||||
: TMessage(buf, len)
|
||||
{
|
||||
ResetBit(kIsOwner);
|
||||
}
|
||||
};
|
||||
|
||||
void FairMQExample7Client::Run()
|
||||
{
|
||||
int runId = 2001;
|
||||
|
||||
while (CheckCurrentState(RUNNING))
|
||||
{
|
||||
boost::this_thread::sleep(boost::posix_time::milliseconds(1000));
|
||||
|
||||
string* reqStr = new string(fParameterName + "," + to_string(runId));
|
||||
|
||||
LOG(INFO) << "Requesting parameter \"" << fParameterName << "\" for Run ID " << runId << ".";
|
||||
|
||||
unique_ptr<FairMQMessage> req(fTransportFactory->CreateMessage(const_cast<char*>(reqStr->c_str()), reqStr->length(), CustomCleanup, reqStr));
|
||||
unique_ptr<FairMQMessage> rep(fTransportFactory->CreateMessage());
|
||||
|
||||
if (fChannels.at("data").at(0).Send(req) > 0)
|
||||
{
|
||||
if (fChannels.at("data").at(0).Receive(rep) > 0)
|
||||
{
|
||||
FairMQExample7TMessage tmsg(rep->GetData(), rep->GetSize());
|
||||
FairMQExample7ParOne* par = (FairMQExample7ParOne*)(tmsg.ReadObject(tmsg.GetClass()));
|
||||
LOG(INFO) << "Received parameter from the server:";
|
||||
par->print();
|
||||
}
|
||||
}
|
||||
|
||||
runId++;
|
||||
if (runId == 2101)
|
||||
{
|
||||
runId = 2001;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
void FairMQExample7Client::SetProperty(const int key, const string& value)
|
||||
{
|
||||
switch (key)
|
||||
{
|
||||
case ParameterName:
|
||||
fParameterName = value;
|
||||
break;
|
||||
default:
|
||||
FairMQDevice::SetProperty(key, value);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
string FairMQExample7Client::GetProperty(const int key, const string& default_ /*= ""*/)
|
||||
{
|
||||
switch (key)
|
||||
{
|
||||
case ParameterName:
|
||||
return fParameterName;
|
||||
break;
|
||||
default:
|
||||
return FairMQDevice::GetProperty(key, default_);
|
||||
}
|
||||
}
|
||||
|
||||
void FairMQExample7Client::SetProperty(const int key, const int value)
|
||||
{
|
||||
switch (key)
|
||||
{
|
||||
default:
|
||||
FairMQDevice::SetProperty(key, value);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
int FairMQExample7Client::GetProperty(const int key, const int default_ /*= 0*/)
|
||||
{
|
||||
switch (key)
|
||||
{
|
||||
default:
|
||||
return FairMQDevice::GetProperty(key, default_);
|
||||
}
|
||||
}
|
48
fairmq/examples/7-parameters/FairMQExample7Client.h
Normal file
48
fairmq/examples/7-parameters/FairMQExample7Client.h
Normal file
|
@ -0,0 +1,48 @@
|
|||
/********************************************************************************
|
||||
* Copyright (C) 2014 GSI Helmholtzzentrum fuer Schwerionenforschung GmbH *
|
||||
* *
|
||||
* This software is distributed under the terms of the *
|
||||
* GNU Lesser General Public Licence version 3 (LGPL) version 3, *
|
||||
* copied verbatim in the file "LICENSE" *
|
||||
********************************************************************************/
|
||||
/**
|
||||
* FairMQExample7Client.h
|
||||
*
|
||||
* @since 2015-10-26
|
||||
* @author A. Rybalchenko
|
||||
*/
|
||||
|
||||
#ifndef FAIRMQEXAMPLE7CLIENT_H_
|
||||
#define FAIRMQEXAMPLE7CLIENT_H_
|
||||
|
||||
#include <string>
|
||||
|
||||
#include "FairMQDevice.h"
|
||||
|
||||
class FairMQExample7Client : public FairMQDevice
|
||||
{
|
||||
public:
|
||||
enum
|
||||
{
|
||||
ParameterName = FairMQDevice::Last,
|
||||
Last
|
||||
};
|
||||
FairMQExample7Client();
|
||||
virtual ~FairMQExample7Client();
|
||||
|
||||
static void CustomCleanup(void* data, void* hint);
|
||||
|
||||
virtual void SetProperty(const int key, const std::string& value);
|
||||
virtual std::string GetProperty(const int key, const std::string& default_ = "");
|
||||
virtual void SetProperty(const int key, const int value);
|
||||
virtual int GetProperty(const int key, const int default_ = 0);
|
||||
|
||||
protected:
|
||||
virtual void Run();
|
||||
|
||||
private:
|
||||
int fRunId;
|
||||
std::string fParameterName;
|
||||
};
|
||||
|
||||
#endif /* FAIRMQEXAMPLE7CLIENT_H_ */
|
46
fairmq/examples/7-parameters/FairMQExample7ContFact.cxx
Normal file
46
fairmq/examples/7-parameters/FairMQExample7ContFact.cxx
Normal file
|
@ -0,0 +1,46 @@
|
|||
/********************************************************************************
|
||||
* Copyright (C) 2014 GSI Helmholtzzentrum fuer Schwerionenforschung GmbH *
|
||||
* *
|
||||
* This software is distributed under the terms of the *
|
||||
* GNU Lesser General Public Licence version 3 (LGPL) version 3, *
|
||||
* copied verbatim in the file "LICENSE" *
|
||||
********************************************************************************/
|
||||
#include <iostream>
|
||||
|
||||
#include "FairRuntimeDb.h"
|
||||
|
||||
#include "FairMQExample7ContFact.h"
|
||||
#include "FairMQExample7ParOne.h"
|
||||
|
||||
static FairMQExample7ContFact gFairMQExample7ContFact;
|
||||
|
||||
FairMQExample7ContFact::FairMQExample7ContFact()
|
||||
{
|
||||
fName = "FairMQExample7ContFact";
|
||||
fTitle = "Factory for parameter containers in FairMQ Example 7";
|
||||
setAllContainers();
|
||||
FairRuntimeDb::instance()->addContFactory(this);
|
||||
}
|
||||
|
||||
void FairMQExample7ContFact::setAllContainers()
|
||||
{
|
||||
FairContainer* container = new FairContainer("FairMQExample7ParOne", "FairMQExample7ParOne Parameters", "TestDefaultContext");
|
||||
container->addContext("TestNonDefaultContext");
|
||||
|
||||
containers->Add(container);
|
||||
}
|
||||
|
||||
FairParSet* FairMQExample7ContFact::createContainer(FairContainer* container)
|
||||
{
|
||||
const char* name = container->GetName();
|
||||
FairParSet* p = NULL;
|
||||
|
||||
if (strcmp(name, "FairMQExample7ParOne") == 0)
|
||||
{
|
||||
p = new FairMQExample7ParOne(container->getConcatName().Data(), container->GetTitle(), container->getContext());
|
||||
}
|
||||
|
||||
return p;
|
||||
}
|
||||
|
||||
ClassImp(FairMQExample7ContFact);
|
28
fairmq/examples/7-parameters/FairMQExample7ContFact.h
Normal file
28
fairmq/examples/7-parameters/FairMQExample7ContFact.h
Normal file
|
@ -0,0 +1,28 @@
|
|||
/********************************************************************************
|
||||
* Copyright (C) 2014 GSI Helmholtzzentrum fuer Schwerionenforschung GmbH *
|
||||
* *
|
||||
* This software is distributed under the terms of the *
|
||||
* GNU Lesser General Public Licence version 3 (LGPL) version 3, *
|
||||
* copied verbatim in the file "LICENSE" *
|
||||
********************************************************************************/
|
||||
#ifndef FAIRMQEXAMPLE7CONTFACT_H_
|
||||
#define FAIRMQEXAMPLE7CONTFACT_H_
|
||||
|
||||
#include "FairContFact.h"
|
||||
|
||||
class FairContainer;
|
||||
|
||||
class FairMQExample7ContFact : public FairContFact
|
||||
{
|
||||
private:
|
||||
void setAllContainers();
|
||||
|
||||
public:
|
||||
FairMQExample7ContFact();
|
||||
~FairMQExample7ContFact() {}
|
||||
|
||||
FairParSet* createContainer(FairContainer*);
|
||||
ClassDef(FairMQExample7ContFact,0)
|
||||
};
|
||||
|
||||
#endif /* FAIRMQEXAMPLE7CONTFACT_H_ */
|
17
fairmq/examples/7-parameters/FairMQExample7LinkDef.h
Normal file
17
fairmq/examples/7-parameters/FairMQExample7LinkDef.h
Normal file
|
@ -0,0 +1,17 @@
|
|||
/********************************************************************************
|
||||
* Copyright (C) 2014 GSI Helmholtzzentrum fuer Schwerionenforschung GmbH *
|
||||
* *
|
||||
* This software is distributed under the terms of the *
|
||||
* GNU Lesser General Public Licence version 3 (LGPL) version 3, *
|
||||
* copied verbatim in the file "LICENSE" *
|
||||
********************************************************************************/
|
||||
#ifdef __CINT__
|
||||
|
||||
#pragma link off all globals;
|
||||
#pragma link off all classes;
|
||||
#pragma link off all functions;
|
||||
|
||||
#pragma link C++ class FairMQExample7ContFact+;
|
||||
#pragma link C++ class FairMQExample7ParOne+;
|
||||
|
||||
#endif
|
70
fairmq/examples/7-parameters/FairMQExample7ParOne.cxx
Normal file
70
fairmq/examples/7-parameters/FairMQExample7ParOne.cxx
Normal file
|
@ -0,0 +1,70 @@
|
|||
/********************************************************************************
|
||||
* Copyright (C) 2014 GSI Helmholtzzentrum fuer Schwerionenforschung GmbH *
|
||||
* *
|
||||
* This software is distributed under the terms of the *
|
||||
* GNU Lesser General Public Licence version 3 (LGPL) version 3, *
|
||||
* copied verbatim in the file "LICENSE" *
|
||||
********************************************************************************/
|
||||
#include "FairMQExample7ParOne.h"
|
||||
|
||||
#include "FairParamList.h"
|
||||
#include "FairDetParIo.h"
|
||||
|
||||
#include "FairLogger.h"
|
||||
#include "TString.h"
|
||||
|
||||
FairMQExample7ParOne::FairMQExample7ParOne(const char* name, const char* title, const char* context) :
|
||||
FairParGenericSet(name, title, context),
|
||||
fParameterValue(0)
|
||||
{
|
||||
detName = "TutorialDet";
|
||||
}
|
||||
|
||||
FairMQExample7ParOne::~FairMQExample7ParOne()
|
||||
{
|
||||
clear();
|
||||
}
|
||||
|
||||
void FairMQExample7ParOne::clear()
|
||||
{
|
||||
status = kFALSE;
|
||||
resetInputVersions();
|
||||
}
|
||||
|
||||
void FairMQExample7ParOne::print()
|
||||
{
|
||||
LOG(INFO) << "Print" << FairLogger::endl;
|
||||
LOG(INFO) << "fParameterValue: " << fParameterValue << FairLogger::endl;
|
||||
}
|
||||
|
||||
void FairMQExample7ParOne::putParams(FairParamList* list)
|
||||
{
|
||||
LOG(INFO) << "FairMQExample7ParOne::putParams()" << FairLogger::endl;
|
||||
|
||||
if (!list)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
list->add("Example7ParameterValue", fParameterValue);
|
||||
}
|
||||
|
||||
|
||||
Bool_t FairMQExample7ParOne::getParams(FairParamList* list)
|
||||
{
|
||||
LOG(INFO) << "FairMQExample7ParOne::getParams()" << FairLogger::endl;
|
||||
|
||||
if (!list)
|
||||
{
|
||||
return kFALSE;
|
||||
}
|
||||
|
||||
if (!list->fill("Example7ParameterValue", &fParameterValue))
|
||||
{
|
||||
return kFALSE;
|
||||
}
|
||||
|
||||
return kTRUE;
|
||||
}
|
||||
|
||||
ClassImp(FairMQExample7ParOne)
|
47
fairmq/examples/7-parameters/FairMQExample7ParOne.h
Normal file
47
fairmq/examples/7-parameters/FairMQExample7ParOne.h
Normal file
|
@ -0,0 +1,47 @@
|
|||
/********************************************************************************
|
||||
* Copyright (C) 2014 GSI Helmholtzzentrum fuer Schwerionenforschung GmbH *
|
||||
* *
|
||||
* This software is distributed under the terms of the *
|
||||
* GNU Lesser General Public Licence version 3 (LGPL) version 3, *
|
||||
* copied verbatim in the file "LICENSE" *
|
||||
********************************************************************************/
|
||||
#ifndef FAIRMQEXAMPLE7PARONE_H_
|
||||
#define FAIRMQEXAMPLE7PARONE_H_
|
||||
|
||||
#include "FairParGenericSet.h"
|
||||
|
||||
#include "TObject.h"
|
||||
|
||||
class FairParamList;
|
||||
|
||||
class FairMQExample7ParOne : public FairParGenericSet
|
||||
{
|
||||
public:
|
||||
/** Standard constructor **/
|
||||
FairMQExample7ParOne(const char* name = "FairMQExample7ParOne",
|
||||
const char* title = "FairMQ Example 7 Parameter One",
|
||||
const char* context = "Default");
|
||||
|
||||
/** Destructor **/
|
||||
virtual ~FairMQExample7ParOne();
|
||||
|
||||
virtual void print();
|
||||
|
||||
/** Reset all parameters **/
|
||||
virtual void clear();
|
||||
|
||||
void putParams(FairParamList* list);
|
||||
Bool_t getParams(FairParamList* list);
|
||||
|
||||
inline void SetValue(const Int_t& val) { fParameterValue = val; }
|
||||
|
||||
private:
|
||||
Int_t fParameterValue; //
|
||||
|
||||
FairMQExample7ParOne(const FairMQExample7ParOne&);
|
||||
FairMQExample7ParOne& operator=(const FairMQExample7ParOne&);
|
||||
|
||||
ClassDef(FairMQExample7ParOne,1);
|
||||
};
|
||||
|
||||
#endif // FAIRMQEXAMPLE7PARONE_H_
|
10
fairmq/examples/7-parameters/README.md
Normal file
10
fairmq/examples/7-parameters/README.md
Normal file
|
@ -0,0 +1,10 @@
|
|||
Example 7: Communicating with ParameterMQServer
|
||||
===============
|
||||
|
||||
This example shows how to communicate with the ParameterMQServer, that retrieves parameters from FairRuntimeDb.
|
||||
|
||||
The `fill_parameters.C` ROOT macro can be used to generate the parameter file for the server to read from. The generated file will contain paramters with the name `FairMQExample7ParOne` for run IDs 2000-2099.
|
||||
|
||||
FairMQExample7Client device requests parameter data from ParameterMQServer via REQ-REP pattern. The request contains parameter name and run ID.
|
||||
|
||||
The parameter name can be configured via command line (`--parameter-name`, default is `FairMQExample7ParOne`) and the run ID is hardcoded for this example.
|
23
fairmq/examples/7-parameters/ex7-client.json
Normal file
23
fairmq/examples/7-parameters/ex7-client.json
Normal file
|
@ -0,0 +1,23 @@
|
|||
{
|
||||
"fairMQOptions":
|
||||
{
|
||||
"device":
|
||||
{
|
||||
"id": "parmq-client",
|
||||
"channel":
|
||||
{
|
||||
"name": "data",
|
||||
"socket":
|
||||
{
|
||||
"type": "req",
|
||||
"method": "connect",
|
||||
"address": "tcp://localhost:5005",
|
||||
"sndBufSize": "1000",
|
||||
"rcvBufSize": "1000",
|
||||
"rateLogging": "0"
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
24
fairmq/examples/7-parameters/fill_parameters.C
Normal file
24
fairmq/examples/7-parameters/fill_parameters.C
Normal file
|
@ -0,0 +1,24 @@
|
|||
{
|
||||
FairRuntimeDb *rtdb = FairRuntimeDb::instance();
|
||||
|
||||
Bool_t kParameterMerged = kTRUE;
|
||||
FairParRootFileIo* parOut = new FairParRootFileIo(kParameterMerged);
|
||||
parOut->open("mqexample7_param.root");
|
||||
rtdb->setOutput(parOut);
|
||||
//rtdb->saveOutput();
|
||||
//rtdb->print();
|
||||
|
||||
FairMQExample7ParOne *par = rtdb->getContainer("FairMQExample7ParOne");
|
||||
|
||||
for(Int_t i = 0; i < 100; i++)
|
||||
{
|
||||
rtdb->addRun(2000 + i);
|
||||
|
||||
par->SetValue(1983 + i);
|
||||
par->setChanged();
|
||||
|
||||
rtdb->saveOutput();
|
||||
}
|
||||
|
||||
rtdb->print();
|
||||
}
|
19
fairmq/examples/7-parameters/read_parameters.C
Normal file
19
fairmq/examples/7-parameters/read_parameters.C
Normal file
|
@ -0,0 +1,19 @@
|
|||
{
|
||||
FairRuntimeDb *rtdb = FairRuntimeDb::instance();
|
||||
|
||||
Bool_t kParameterMerged = kTRUE;
|
||||
FairParRootFileIo* parOut = new FairParRootFileIo(kParameterMerged);
|
||||
parOut->open("mqexample7_param.root");
|
||||
rtdb->setFirstInput(parOut);
|
||||
//rtdb->saveOutput();
|
||||
//rtdb->print();
|
||||
|
||||
FairMQExample7ParOne *par = rtdb->getContainer("FairMQExample7ParOne");
|
||||
|
||||
for(Int_t i = 0; i < 100; i++)
|
||||
{
|
||||
rtdb->initContainers(2000+i);
|
||||
|
||||
par->print();
|
||||
}
|
||||
}
|
99
fairmq/examples/7-parameters/runExample7Client.cxx
Normal file
99
fairmq/examples/7-parameters/runExample7Client.cxx
Normal file
|
@ -0,0 +1,99 @@
|
|||
/********************************************************************************
|
||||
* Copyright (C) 2014 GSI Helmholtzzentrum fuer Schwerionenforschung GmbH *
|
||||
* *
|
||||
* This software is distributed under the terms of the *
|
||||
* GNU Lesser General Public Licence version 3 (LGPL) version 3, *
|
||||
* copied verbatim in the file "LICENSE" *
|
||||
********************************************************************************/
|
||||
/**
|
||||
* runExample7Client.cxx
|
||||
*
|
||||
* @since 2013-04-23
|
||||
* @author D. Klein, A. Rybalchenko
|
||||
*/
|
||||
|
||||
#include <iostream>
|
||||
|
||||
#include "FairMQLogger.h"
|
||||
#include "FairMQParser.h"
|
||||
#include "FairMQProgOptions.h"
|
||||
#include "FairMQExample7Client.h"
|
||||
|
||||
#ifdef NANOMSG
|
||||
#include "FairMQTransportFactoryNN.h"
|
||||
#else
|
||||
#include "FairMQTransportFactoryZMQ.h"
|
||||
#endif
|
||||
|
||||
using namespace std;
|
||||
using namespace boost::program_options;
|
||||
|
||||
int main(int argc, char** argv)
|
||||
{
|
||||
FairMQExample7Client client;
|
||||
client.CatchSignals();
|
||||
|
||||
FairMQProgOptions config;
|
||||
|
||||
try
|
||||
{
|
||||
string parameterName;
|
||||
|
||||
options_description clientOptions("Parameter Client options");
|
||||
clientOptions.add_options()
|
||||
("parameter-name", value<string>(¶meterName)->default_value("FairMQExample7ParOne"), "Parameter Name");
|
||||
|
||||
config.AddToCmdLineOptions(clientOptions);
|
||||
|
||||
if (config.ParseAll(argc, argv))
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
string file = config.GetValue<string>("config-json-file");
|
||||
string id = config.GetValue<string>("id");
|
||||
|
||||
config.UserParser<FairMQParser::JSON>(file, id);
|
||||
|
||||
client.fChannels = config.GetFairMQMap();
|
||||
|
||||
LOG(INFO) << "PID: " << getpid();
|
||||
|
||||
#ifdef NANOMSG
|
||||
FairMQTransportFactory* transportFactory = new FairMQTransportFactoryNN();
|
||||
#else
|
||||
FairMQTransportFactory* transportFactory = new FairMQTransportFactoryZMQ();
|
||||
#endif
|
||||
|
||||
client.SetTransport(transportFactory);
|
||||
|
||||
client.SetProperty(FairMQExample7Client::Id, "client");
|
||||
client.SetProperty(FairMQExample7Client::ParameterName, parameterName);
|
||||
client.SetProperty(FairMQExample7Client::NumIoThreads, 1);
|
||||
|
||||
FairMQChannel requestChannel("req", "connect", "tcp://localhost:5005");
|
||||
requestChannel.UpdateSndBufSize(10000);
|
||||
requestChannel.UpdateRcvBufSize(10000);
|
||||
requestChannel.UpdateRateLogging(0);
|
||||
|
||||
client.fChannels["data"].push_back(requestChannel);
|
||||
|
||||
client.ChangeState("INIT_DEVICE");
|
||||
client.WaitForEndOfState("INIT_DEVICE");
|
||||
|
||||
client.ChangeState("INIT_TASK");
|
||||
client.WaitForEndOfState("INIT_TASK");
|
||||
|
||||
client.ChangeState("RUN");
|
||||
client.InteractiveStateLoop();
|
||||
}
|
||||
catch (exception& e)
|
||||
{
|
||||
LOG(ERROR) << e.what();
|
||||
LOG(INFO) << "Command line options are the following: ";
|
||||
config.PrintHelp();
|
||||
return 1;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
|
@ -58,7 +58,6 @@ int main(int argc, char** argv)
|
|||
|
||||
string filename = config.GetValue<string>("config-json-file");
|
||||
string id = config.GetValue<string>("id");
|
||||
int ioThreads = config.GetValue<int>("io-threads");
|
||||
|
||||
config.UserParser<JSON>(filename, id);
|
||||
|
||||
|
@ -75,7 +74,7 @@ int main(int argc, char** argv)
|
|||
sampler.SetProperty(FairMQBenchmarkSampler::Id, id);
|
||||
sampler.SetProperty(FairMQBenchmarkSampler::EventSize, eventSize);
|
||||
sampler.SetProperty(FairMQBenchmarkSampler::EventRate, eventRate);
|
||||
sampler.SetProperty(FairMQBenchmarkSampler::NumIoThreads, ioThreads);
|
||||
sampler.SetProperty(FairMQBenchmarkSampler::NumIoThreads, config.GetValue<int>("io-threads"));
|
||||
|
||||
sampler.ChangeState("INIT_DEVICE");
|
||||
sampler.WaitForEndOfState("INIT_DEVICE");
|
||||
|
|
|
@ -64,7 +64,7 @@ int main(int argc, char** argv)
|
|||
sink.SetTransport(transportFactory);
|
||||
|
||||
sink.SetProperty(FairMQSink::Id, id);
|
||||
sink.SetProperty(FairMQSink::NumIoThreads, ioThreads);
|
||||
sink.SetProperty(FairMQSink::NumIoThreads, config.GetValue<int>("io-threads"));
|
||||
|
||||
sink.ChangeState("INIT_DEVICE");
|
||||
sink.WaitForEndOfState("INIT_DEVICE");
|
||||
|
|
Loading…
Reference in New Issue
Block a user