Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
U
uniset2
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
1
Issues
1
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
UniSet project repositories
uniset2
Commits
bef704d0
Commit
bef704d0
authored
May 23, 2015
by
Pavel Vainerman
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
(SharedMemory): встроил LogServer..
parent
8d4fbf3b
Show whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
114 additions
and
89 deletions
+114
-89
MBSlave.h
extensions/ModbusSlave/MBSlave.h
+0
-1
SharedMemory.cc
extensions/SharedMemory/SharedMemory.cc
+83
-61
SharedMemory.h
extensions/SharedMemory/SharedMemory.h
+12
-1
smemory.cc
extensions/SharedMemory/smemory.cc
+4
-1
start_fg.sh
extensions/SharedMemory/start_fg.sh
+2
-1
LogServer.h
include/LogServer.h
+1
-1
ModbusTCPServer.cc
src/Communications/Modbus/ModbusTCPServer.cc
+2
-12
LogServer.cc
src/Log/LogServer.cc
+10
-11
No files found.
extensions/ModbusSlave/MBSlave.h
View file @
bef704d0
...
@@ -19,7 +19,6 @@
...
@@ -19,7 +19,6 @@
#include "IOBase.h"
#include "IOBase.h"
#include "VTypes.h"
#include "VTypes.h"
#include "ThreadCreator.h"
#include "ThreadCreator.h"
#include "LogAgregator.h"
#include "LogServer.h"
#include "LogServer.h"
#include "modbus/MBLogSugar.h"
#include "modbus/MBLogSugar.h"
// -----------------------------------------------------------------------------
// -----------------------------------------------------------------------------
...
...
extensions/SharedMemory/SharedMemory.cc
View file @
bef704d0
...
@@ -13,7 +13,6 @@ using namespace UniSetExtensions;
...
@@ -13,7 +13,6 @@ using namespace UniSetExtensions;
void
SharedMemory
::
help_print
(
int
argc
,
const
char
*
const
*
argv
)
void
SharedMemory
::
help_print
(
int
argc
,
const
char
*
const
*
argv
)
{
{
cout
<<
"--smemory-id - SharedMemeory ID"
<<
endl
;
cout
<<
"--smemory-id - SharedMemeory ID"
<<
endl
;
cout
<<
"--logfile fname - выводить логи в файл fname. По умолчанию smemory.log"
<<
endl
;
cout
<<
"--datfile fname - Файл с картой датчиков. По умолчанию configure.xml"
<<
endl
;
cout
<<
"--datfile fname - Файл с картой датчиков. По умолчанию configure.xml"
<<
endl
;
cout
<<
"--s-filter-field - Фильтр для загрузки списка датчиков."
<<
endl
;
cout
<<
"--s-filter-field - Фильтр для загрузки списка датчиков."
<<
endl
;
cout
<<
"--s-filter-value - Значение фильтра для загрузки списка датчиков."
<<
endl
;
cout
<<
"--s-filter-value - Значение фильтра для загрузки списка датчиков."
<<
endl
;
...
@@ -29,6 +28,18 @@ void SharedMemory::help_print( int argc, const char* const* argv )
...
@@ -29,6 +28,18 @@ void SharedMemory::help_print( int argc, const char* const* argv )
cout
<<
"--sm-no-history - отключить ведение истории (аварийного следа)"
<<
endl
;
cout
<<
"--sm-no-history - отключить ведение истории (аварийного следа)"
<<
endl
;
cout
<<
"--pulsar-id - датчик 'мигания'"
<<
endl
;
cout
<<
"--pulsar-id - датчик 'мигания'"
<<
endl
;
cout
<<
"--pulsar-msec - период 'мигания'. По умолчанию: 5000."
<<
endl
;
cout
<<
"--pulsar-msec - период 'мигания'. По умолчанию: 5000."
<<
endl
;
cout
<<
endl
;
cout
<<
" Logs: "
<<
endl
;
cout
<<
"--sm-log-... - log control"
<<
endl
;
cout
<<
" add-levels ..."
<<
endl
;
cout
<<
" del-levels ..."
<<
endl
;
cout
<<
" set-levels ..."
<<
endl
;
cout
<<
" logfile filaname"
<<
endl
;
cout
<<
" no-debug "
<<
endl
;
cout
<<
" LogServer: "
<<
endl
;
cout
<<
"--sm-run-logserver - run logserver. Default: localhost:id"
<<
endl
;
cout
<<
"--sm-logserver-host ip - listen ip. Default: localhost"
<<
endl
;
cout
<<
"--sm-logserver-port num - listen port. Default: ID"
<<
endl
;
}
}
// -----------------------------------------------------------------------------
// -----------------------------------------------------------------------------
SharedMemory
::
SharedMemory
(
ObjectId
id
,
const
std
::
string
&
datafile
,
const
std
::
string
&
confname
)
:
SharedMemory
::
SharedMemory
(
ObjectId
id
,
const
std
::
string
&
datafile
,
const
std
::
string
&
confname
)
:
...
@@ -55,9 +66,27 @@ SharedMemory::SharedMemory( ObjectId id, const std::string& datafile, const std:
...
@@ -55,9 +66,27 @@ SharedMemory::SharedMemory( ObjectId id, const std::string& datafile, const std:
if
(
confnode
==
NULL
)
if
(
confnode
==
NULL
)
throw
SystemError
(
"Not found conf-node for "
+
cname
);
throw
SystemError
(
"Not found conf-node for "
+
cname
);
string
prefix
=
"sm"
;
smlog
=
make_shared
<
DebugStream
>
();
conf
->
initLogStream
(
smlog
,
prefix
+
"-log"
);
loga
=
make_shared
<
LogAgregator
>
();
loga
->
add
(
smlog
);
loga
->
add
(
ulog
());
logserv
=
make_shared
<
LogServer
>
(
loga
);
UniXML
::
iterator
it
(
confnode
);
UniXML
::
iterator
it
(
confnode
);
// ----------------------
// ----------------------
if
(
findArgParam
(
"--"
+
prefix
+
"-run-logserver"
,
conf
->
getArgc
(),
conf
->
getArgv
())
!=
-
1
)
{
logserv_host
=
conf
->
getArg2Param
(
"--"
+
prefix
+
"-logserver-host"
,
it
.
getProp
(
"logserverHost"
),
"localhost"
);
logserv_port
=
conf
->
getArgPInt
(
"--"
+
prefix
+
"-logserver-port"
,
it
.
getProp
(
"logserverPort"
),
getId
());
}
// ----------------------
buildHistoryList
(
confnode
);
buildHistoryList
(
confnode
);
signal_change_value
().
connect
(
sigc
::
mem_fun
(
*
this
,
&
SharedMemory
::
updateHistory
));
signal_change_value
().
connect
(
sigc
::
mem_fun
(
*
this
,
&
SharedMemory
::
updateHistory
));
...
@@ -78,10 +107,10 @@ SharedMemory::SharedMemory( ObjectId id, const std::string& datafile, const std:
...
@@ -78,10 +107,10 @@ SharedMemory::SharedMemory( ObjectId id, const std::string& datafile, const std:
if
(
heartbeat_node
.
empty
()
)
if
(
heartbeat_node
.
empty
()
)
{
{
d
warn
<<
myname
<<
"(init): --heartbeat-node NULL ===> heartbeat NOT USED..."
<<
endl
;
sm
warn
<<
myname
<<
"(init): --heartbeat-node NULL ===> heartbeat NOT USED..."
<<
endl
;
}
}
else
else
d
info
<<
myname
<<
"(init): heartbeat-node: "
<<
heartbeat_node
<<
endl
;
sm
info
<<
myname
<<
"(init): heartbeat-node: "
<<
heartbeat_node
<<
endl
;
heartbeatCheckTime
=
conf
->
getArgInt
(
"--heartbeat-check-time"
,
"1000"
);
heartbeatCheckTime
=
conf
->
getArgInt
(
"--heartbeat-check-time"
,
"1000"
);
...
@@ -97,7 +126,7 @@ SharedMemory::SharedMemory( ObjectId id, const std::string& datafile, const std:
...
@@ -97,7 +126,7 @@ SharedMemory::SharedMemory( ObjectId id, const std::string& datafile, const std:
if
(
!
wdt_dev
.
empty
()
)
if
(
!
wdt_dev
.
empty
()
)
wdt
=
make_shared
<
WDTInterface
>
(
wdt_dev
);
wdt
=
make_shared
<
WDTInterface
>
(
wdt_dev
);
else
else
d
warn
<<
myname
<<
"(init): watchdog timer NOT USED (--wdt-device NULL)"
<<
endl
;
sm
warn
<<
myname
<<
"(init): watchdog timer NOT USED (--wdt-device NULL)"
<<
endl
;
dblogging
=
conf
->
getArgInt
(
"--db-logging"
);
dblogging
=
conf
->
getArgInt
(
"--db-logging"
);
...
@@ -119,7 +148,7 @@ SharedMemory::SharedMemory( ObjectId id, const std::string& datafile, const std:
...
@@ -119,7 +148,7 @@ SharedMemory::SharedMemory( ObjectId id, const std::string& datafile, const std:
{
{
ostringstream
err
;
ostringstream
err
;
err
<<
myname
<<
": ID not found ('pulsar') for "
<<
p
;
err
<<
myname
<<
": ID not found ('pulsar') for "
<<
p
;
d
crit
<<
myname
<<
"(init): "
<<
err
.
str
()
<<
endl
;
sm
crit
<<
myname
<<
"(init): "
<<
err
.
str
()
<<
endl
;
throw
SystemError
(
err
.
str
());
throw
SystemError
(
err
.
str
());
}
}
...
@@ -166,6 +195,12 @@ void SharedMemory::sysCommand( const SystemMessage* sm )
...
@@ -166,6 +195,12 @@ void SharedMemory::sysCommand( const SystemMessage* sm )
{
{
case
SystemMessage
:
:
StartUp
:
case
SystemMessage
:
:
StartUp
:
{
{
if
(
!
logserv_host
.
empty
()
&&
logserv_port
!=
0
&&
!
logserv
->
isRunning
()
)
{
sminfo
<<
myname
<<
"(init): run log server "
<<
logserv_host
<<
":"
<<
logserv_port
<<
endl
;
logserv
->
run
(
logserv_host
,
logserv_port
,
true
);
}
PassiveTimer
ptAct
(
activateTimeout
);
PassiveTimer
ptAct
(
activateTimeout
);
while
(
!
activated
&&
!
ptAct
.
checkTime
()
)
while
(
!
activated
&&
!
ptAct
.
checkTime
()
)
...
@@ -175,7 +210,7 @@ void SharedMemory::sysCommand( const SystemMessage* sm )
...
@@ -175,7 +210,7 @@ void SharedMemory::sysCommand( const SystemMessage* sm )
}
}
if
(
!
activated
)
if
(
!
activated
)
d
crit
<<
myname
<<
"(sysCommand): ************* don`t activate?! ************"
<<
endl
;
sm
crit
<<
myname
<<
"(sysCommand): ************* don`t activate?! ************"
<<
endl
;
// подождать пока пройдёт инициализация
// подождать пока пройдёт инициализация
// см. activateObject()
// см. activateObject()
...
@@ -207,26 +242,13 @@ void SharedMemory::sysCommand( const SystemMessage* sm )
...
@@ -207,26 +242,13 @@ void SharedMemory::sysCommand( const SystemMessage* sm )
}
}
// ------------------------------------------------------------------------------------------
// ------------------------------------------------------------------------------------------
bool
SharedMemory
::
deactivateObject
()
void
SharedMemory
::
askSensors
(
UniversalIO
::
UIOCommand
cmd
)
{
{
/*
if
(
logserv
)
for( History::iterator it=hist.begin(); it!=hist.end(); ++it )
logserv
=
nullptr
;
{
if( sm->id == it->fuse_id )
{
try
{
ui->askState( SID, cmd);
}
catch( const Exception& ex )
{
dlog.crit() << myname << "(askSensors): " << ex << endl;
}
}
*/
}
return
IONotifyController_LT
::
deactivateObject
();
}
// ------------------------------------------------------------------------------------------
// ------------------------------------------------------------------------------------------
bool
SharedMemory
::
activateObject
()
bool
SharedMemory
::
activateObject
()
{
{
...
@@ -326,11 +348,11 @@ void SharedMemory::checkHeartBeat()
...
@@ -326,11 +348,11 @@ void SharedMemory::checkHeartBeat()
}
}
catch
(
const
Exception
&
ex
)
catch
(
const
Exception
&
ex
)
{
{
d
crit
<<
myname
<<
"(checkHeartBeat): "
<<
ex
<<
endl
;
sm
crit
<<
myname
<<
"(checkHeartBeat): "
<<
ex
<<
endl
;
}
}
catch
(...)
catch
(...)
{
{
d
crit
<<
myname
<<
"(checkHeartBeat): ..."
<<
endl
;
sm
crit
<<
myname
<<
"(checkHeartBeat): ..."
<<
endl
;
}
}
}
}
...
@@ -370,7 +392,7 @@ bool SharedMemory::readItem( const std::shared_ptr<UniXML>& xml, UniXML::iterato
...
@@ -370,7 +392,7 @@ bool SharedMemory::readItem( const std::shared_ptr<UniXML>& xml, UniXML::iterato
<<
") указан неверно ("
<<
") указан неверно ("
<<
it
.
getProp
(
"iotype"
)
<<
") должен быть 'AI'"
;
<<
it
.
getProp
(
"iotype"
)
<<
") должен быть 'AI'"
;
d
crit
<<
msg
.
str
()
<<
endl
;
sm
crit
<<
msg
.
str
()
<<
endl
;
kill
(
getpid
(),
SIGTERM
);
kill
(
getpid
(),
SIGTERM
);
// throw NameNotFound(msg.str());
// throw NameNotFound(msg.str());
};
};
...
@@ -385,7 +407,7 @@ bool SharedMemory::readItem( const std::shared_ptr<UniXML>& xml, UniXML::iterato
...
@@ -385,7 +407,7 @@ bool SharedMemory::readItem( const std::shared_ptr<UniXML>& xml, UniXML::iterato
{
{
ostringstream
msg
;
ostringstream
msg
;
msg
<<
"(SharedMemory::readItem): дискретный датчик (heartbeat_ds_name) связанный с "
<<
it
.
getProp
(
"name"
);
msg
<<
"(SharedMemory::readItem): дискретный датчик (heartbeat_ds_name) связанный с "
<<
it
.
getProp
(
"name"
);
d
warn
<<
msg
.
str
()
<<
endl
;
sm
warn
<<
msg
.
str
()
<<
endl
;
}
}
}
}
else
else
...
@@ -399,7 +421,7 @@ bool SharedMemory::readItem( const std::shared_ptr<UniXML>& xml, UniXML::iterato
...
@@ -399,7 +421,7 @@ bool SharedMemory::readItem( const std::shared_ptr<UniXML>& xml, UniXML::iterato
// Если уж задали имя для датчика, то он должен существовать..
// Если уж задали имя для датчика, то он должен существовать..
// поэтому завершаем процесс, если не нашли..
// поэтому завершаем процесс, если не нашли..
d
crit
<<
msg
.
str
()
<<
endl
;
sm
crit
<<
msg
.
str
()
<<
endl
;
kill
(
getpid
(),
SIGTERM
);
kill
(
getpid
(),
SIGTERM
);
// throw NameNotFound(msg.str());
// throw NameNotFound(msg.str());
}
}
...
@@ -414,7 +436,7 @@ bool SharedMemory::readItem( const std::shared_ptr<UniXML>& xml, UniXML::iterato
...
@@ -414,7 +436,7 @@ bool SharedMemory::readItem( const std::shared_ptr<UniXML>& xml, UniXML::iterato
msg
<<
"(SharedMemory::readItem): НЕ УКАЗАН id для "
msg
<<
"(SharedMemory::readItem): НЕ УКАЗАН id для "
<<
it
.
getProp
(
"name"
)
<<
" секция "
<<
sec
;
<<
it
.
getProp
(
"name"
)
<<
" секция "
<<
sec
;
d
crit
<<
msg
.
str
()
<<
endl
;
sm
crit
<<
msg
.
str
()
<<
endl
;
kill
(
getpid
(),
SIGTERM
);
kill
(
getpid
(),
SIGTERM
);
// throw NameNotFound(msg.str());
// throw NameNotFound(msg.str());
};
};
...
@@ -469,7 +491,7 @@ void SharedMemory::readEventList( const std::string& oname )
...
@@ -469,7 +491,7 @@ void SharedMemory::readEventList( const std::string& oname )
if
(
enode
==
NULL
)
if
(
enode
==
NULL
)
{
{
d
warn
<<
myname
<<
"(readEventList): "
<<
oname
<<
" не найден..."
<<
endl
;
sm
warn
<<
myname
<<
"(readEventList): "
<<
oname
<<
" не найден..."
<<
endl
;
return
;
return
;
}
}
...
@@ -477,7 +499,7 @@ void SharedMemory::readEventList( const std::string& oname )
...
@@ -477,7 +499,7 @@ void SharedMemory::readEventList( const std::string& oname )
if
(
!
it
.
goChildren
()
)
if
(
!
it
.
goChildren
()
)
{
{
d
warn
<<
myname
<<
"(readEventList): <eventlist> пустой..."
<<
endl
;
sm
warn
<<
myname
<<
"(readEventList): <eventlist> пустой..."
<<
endl
;
return
;
return
;
}
}
...
@@ -490,11 +512,11 @@ void SharedMemory::readEventList( const std::string& oname )
...
@@ -490,11 +512,11 @@ void SharedMemory::readEventList( const std::string& oname )
if
(
oid
!=
0
)
if
(
oid
!=
0
)
{
{
d
info
<<
myname
<<
"(readEventList): add "
<<
it
.
getProp
(
"name"
)
<<
endl
;
sm
info
<<
myname
<<
"(readEventList): add "
<<
it
.
getProp
(
"name"
)
<<
endl
;
elst
.
push_back
(
oid
);
elst
.
push_back
(
oid
);
}
}
else
else
d
crit
<<
myname
<<
"(readEventList): Не найден ID для "
sm
crit
<<
myname
<<
"(readEventList): Не найден ID для "
<<
it
.
getProp
(
"name"
)
<<
endl
;
<<
it
.
getProp
(
"name"
)
<<
endl
;
}
}
}
}
...
@@ -518,7 +540,7 @@ void SharedMemory::sendEvent( UniSetTypes::SystemMessage& sm )
...
@@ -518,7 +540,7 @@ void SharedMemory::sendEvent( UniSetTypes::SystemMessage& sm )
}
}
if
(
!
ok
)
if
(
!
ok
)
d
crit
<<
myname
<<
"(sendEvent): Объект "
<<
it
<<
" НЕДОСТУПЕН"
<<
endl
;
sm
crit
<<
myname
<<
"(sendEvent): Объект "
<<
it
<<
" НЕДОСТУПЕН"
<<
endl
;
}
}
}
}
// -----------------------------------------------------------------------------
// -----------------------------------------------------------------------------
...
@@ -535,13 +557,13 @@ void SharedMemory::loggingInfo( SensorMessage& sm )
...
@@ -535,13 +557,13 @@ void SharedMemory::loggingInfo( SensorMessage& sm )
// -----------------------------------------------------------------------------
// -----------------------------------------------------------------------------
void
SharedMemory
::
buildHistoryList
(
xmlNode
*
cnode
)
void
SharedMemory
::
buildHistoryList
(
xmlNode
*
cnode
)
{
{
d
info
<<
myname
<<
"(buildHistoryList): ..."
<<
endl
;
sm
info
<<
myname
<<
"(buildHistoryList): ..."
<<
endl
;
const
std
::
shared_ptr
<
UniXML
>
xml
=
uniset_conf
()
->
getConfXML
();
const
std
::
shared_ptr
<
UniXML
>
xml
=
uniset_conf
()
->
getConfXML
();
if
(
!
xml
)
if
(
!
xml
)
{
{
d
warn
<<
myname
<<
"(buildHistoryList): xml=NULL?!"
<<
endl
;
sm
warn
<<
myname
<<
"(buildHistoryList): xml=NULL?!"
<<
endl
;
return
;
return
;
}
}
...
@@ -549,7 +571,7 @@ void SharedMemory::buildHistoryList( xmlNode* cnode )
...
@@ -549,7 +571,7 @@ void SharedMemory::buildHistoryList( xmlNode* cnode )
if
(
!
n
)
if
(
!
n
)
{
{
d
warn
<<
myname
<<
"(buildHistoryList): <History> not found. ignore..."
<<
endl
;
sm
warn
<<
myname
<<
"(buildHistoryList): <History> not found. ignore..."
<<
endl
;
hist
.
clear
();
hist
.
clear
();
return
;
return
;
}
}
...
@@ -560,7 +582,7 @@ void SharedMemory::buildHistoryList( xmlNode* cnode )
...
@@ -560,7 +582,7 @@ void SharedMemory::buildHistoryList( xmlNode* cnode )
if
(
no_history
)
if
(
no_history
)
{
{
d
warn
<<
myname
<<
"(buildHistoryList): no_history='1'.. history skipped..."
<<
endl
;
sm
warn
<<
myname
<<
"(buildHistoryList): no_history='1'.. history skipped..."
<<
endl
;
hist
.
clear
();
hist
.
clear
();
return
;
return
;
}
}
...
@@ -572,7 +594,7 @@ void SharedMemory::buildHistoryList( xmlNode* cnode )
...
@@ -572,7 +594,7 @@ void SharedMemory::buildHistoryList( xmlNode* cnode )
if
(
!
it
.
goChildren
()
)
if
(
!
it
.
goChildren
()
)
{
{
d
warn
<<
myname
<<
"(buildHistoryList): <History> empty. ignore..."
<<
endl
;
sm
warn
<<
myname
<<
"(buildHistoryList): <History> empty. ignore..."
<<
endl
;
return
;
return
;
}
}
...
@@ -594,7 +616,7 @@ void SharedMemory::buildHistoryList( xmlNode* cnode )
...
@@ -594,7 +616,7 @@ void SharedMemory::buildHistoryList( xmlNode* cnode )
if
(
hi
.
fuse_id
==
DefaultObjectId
)
if
(
hi
.
fuse_id
==
DefaultObjectId
)
{
{
d
warn
<<
myname
<<
"(buildHistory): not found sensor ID for "
sm
warn
<<
myname
<<
"(buildHistory): not found sensor ID for "
<<
it
.
getProp
(
"fuse_id"
)
<<
it
.
getProp
(
"fuse_id"
)
<<
" history item id="
<<
it
.
getProp
(
"id"
)
<<
" history item id="
<<
it
.
getProp
(
"id"
)
<<
" ..ignore.."
<<
endl
;
<<
" ..ignore.."
<<
endl
;
...
@@ -611,7 +633,7 @@ void SharedMemory::buildHistoryList( xmlNode* cnode )
...
@@ -611,7 +633,7 @@ void SharedMemory::buildHistoryList( xmlNode* cnode )
hi
.
fuse_val
=
it
.
getIntProp
(
"fuse_value"
);
hi
.
fuse_val
=
it
.
getIntProp
(
"fuse_value"
);
}
}
d
info
<<
myname
<<
"(buildHistory): add fuse_id="
<<
hi
.
fuse_id
sm
info
<<
myname
<<
"(buildHistory): add fuse_id="
<<
hi
.
fuse_id
<<
" fuse_val="
<<
hi
.
fuse_val
<<
" fuse_val="
<<
hi
.
fuse_val
<<
" fuse_use_val="
<<
hi
.
fuse_use_val
<<
" fuse_use_val="
<<
hi
.
fuse_use_val
<<
" fuse_invert="
<<
hi
.
fuse_invert
<<
" fuse_invert="
<<
hi
.
fuse_invert
...
@@ -621,7 +643,7 @@ void SharedMemory::buildHistoryList( xmlNode* cnode )
...
@@ -621,7 +643,7 @@ void SharedMemory::buildHistoryList( xmlNode* cnode )
hist
.
push_back
(
hi
);
hist
.
push_back
(
hi
);
}
}
d
info
<<
myname
<<
"(buildHistoryList): history logs count="
<<
hist
.
size
()
<<
endl
;
sm
info
<<
myname
<<
"(buildHistoryList): history logs count="
<<
hist
.
size
()
<<
endl
;
}
}
// -----------------------------------------------------------------------------
// -----------------------------------------------------------------------------
void
SharedMemory
::
checkHistoryFilter
(
UniXML
::
iterator
&
xit
)
void
SharedMemory
::
checkHistoryFilter
(
UniXML
::
iterator
&
xit
)
...
@@ -642,7 +664,7 @@ void SharedMemory::checkHistoryFilter( UniXML::iterator& xit )
...
@@ -642,7 +664,7 @@ void SharedMemory::checkHistoryFilter( UniXML::iterator& xit )
if
(
id
==
DefaultObjectId
)
if
(
id
==
DefaultObjectId
)
{
{
d
warn
<<
myname
<<
"(checkHistoryFilter): not found sensor ID for "
<<
xit
.
getProp
(
"name"
)
<<
endl
;
sm
warn
<<
myname
<<
"(checkHistoryFilter): not found sensor ID for "
<<
xit
.
getProp
(
"name"
)
<<
endl
;
continue
;
continue
;
}
}
...
@@ -698,7 +720,7 @@ void SharedMemory::updateHistory( std::shared_ptr<USensorInfo>& s_it, IOControll
...
@@ -698,7 +720,7 @@ void SharedMemory::updateHistory( std::shared_ptr<USensorInfo>& s_it, IOControll
sm_tv_usec
=
s_it
->
tv_usec
;
sm_tv_usec
=
s_it
->
tv_usec
;
}
}
d
info
<<
myname
<<
"(updateHistory): "
sm
info
<<
myname
<<
"(updateHistory): "
<<
" sid="
<<
s_it
->
si
.
id
<<
" sid="
<<
s_it
->
si
.
id
<<
" value="
<<
value
<<
" value="
<<
value
<<
endl
;
<<
endl
;
...
@@ -717,7 +739,7 @@ void SharedMemory::updateHistory( std::shared_ptr<USensorInfo>& s_it, IOControll
...
@@ -717,7 +739,7 @@ void SharedMemory::updateHistory( std::shared_ptr<USensorInfo>& s_it, IOControll
if
(
st
)
if
(
st
)
{
{
d
info
<<
myname
<<
"(updateHistory): HISTORY EVENT for "
<<
(
*
it
)
<<
endl
;
sm
info
<<
myname
<<
"(updateHistory): HISTORY EVENT for "
<<
(
*
it
)
<<
endl
;
it
->
fuse_sec
=
sm_tv_sec
;
it
->
fuse_sec
=
sm_tv_sec
;
it
->
fuse_usec
=
sm_tv_usec
;
it
->
fuse_usec
=
sm_tv_usec
;
...
@@ -736,7 +758,7 @@ void SharedMemory::updateHistory( std::shared_ptr<USensorInfo>& s_it, IOControll
...
@@ -736,7 +758,7 @@ void SharedMemory::updateHistory( std::shared_ptr<USensorInfo>& s_it, IOControll
if
(
!
st
)
if
(
!
st
)
{
{
d
info
<<
myname
<<
"(updateHistory): HISTORY EVENT for "
<<
(
*
it
)
<<
endl
;
sm
info
<<
myname
<<
"(updateHistory): HISTORY EVENT for "
<<
(
*
it
)
<<
endl
;
it
->
fuse_sec
=
sm_tv_sec
;
it
->
fuse_sec
=
sm_tv_sec
;
it
->
fuse_usec
=
sm_tv_usec
;
it
->
fuse_usec
=
sm_tv_usec
;
...
@@ -747,7 +769,7 @@ void SharedMemory::updateHistory( std::shared_ptr<USensorInfo>& s_it, IOControll
...
@@ -747,7 +769,7 @@ void SharedMemory::updateHistory( std::shared_ptr<USensorInfo>& s_it, IOControll
{
{
if
(
value
==
it
->
fuse_val
)
if
(
value
==
it
->
fuse_val
)
{
{
d
info
<<
myname
<<
"(updateHistory): HISTORY EVENT for "
<<
(
*
it
)
<<
endl
;
sm
info
<<
myname
<<
"(updateHistory): HISTORY EVENT for "
<<
(
*
it
)
<<
endl
;
it
->
fuse_sec
=
sm_tv_sec
;
it
->
fuse_sec
=
sm_tv_sec
;
it
->
fuse_usec
=
sm_tv_usec
;
it
->
fuse_usec
=
sm_tv_usec
;
...
@@ -786,13 +808,13 @@ void SharedMemory::initFromReserv()
...
@@ -786,13 +808,13 @@ void SharedMemory::initFromReserv()
if
(
!
it
.
find
(
"ReservList"
)
)
if
(
!
it
.
find
(
"ReservList"
)
)
{
{
d
info
<<
myname
<<
"(initFromReserv): <ReservList> not found... ignore.. "
<<
endl
;
sm
info
<<
myname
<<
"(initFromReserv): <ReservList> not found... ignore.. "
<<
endl
;
return
;
return
;
}
}
if
(
!
it
.
goChildren
()
)
if
(
!
it
.
goChildren
()
)
{
{
d
warn
<<
myname
<<
"(initFromReserv): <ReservList> EMPTY?... ignore.. "
<<
endl
;
sm
warn
<<
myname
<<
"(initFromReserv): <ReservList> EMPTY?... ignore.. "
<<
endl
;
return
;
return
;
}
}
...
@@ -814,7 +836,7 @@ void SharedMemory::initFromReserv()
...
@@ -814,7 +836,7 @@ void SharedMemory::initFromReserv()
{
{
ostringstream
err
;
ostringstream
err
;
err
<<
myname
<<
"(initFromReserv): Not found ID for '"
<<
smName
<<
"'"
;
err
<<
myname
<<
"(initFromReserv): Not found ID for '"
<<
smName
<<
"'"
;
d
crit
<<
err
.
str
()
<<
endl
;
sm
crit
<<
err
.
str
()
<<
endl
;
// throw SystemError(err.str());
// throw SystemError(err.str());
raise
(
SIGTERM
);
raise
(
SIGTERM
);
}
}
...
@@ -830,7 +852,7 @@ void SharedMemory::initFromReserv()
...
@@ -830,7 +852,7 @@ void SharedMemory::initFromReserv()
{
{
ostringstream
err
;
ostringstream
err
;
err
<<
myname
<<
"(initFromReserv): Not found NodeID for '"
<<
smNode
<<
"'"
;
err
<<
myname
<<
"(initFromReserv): Not found NodeID for '"
<<
smNode
<<
"'"
;
d
crit
<<
err
.
str
()
<<
endl
;
sm
crit
<<
err
.
str
()
<<
endl
;
// throw SystemError(err.str());
// throw SystemError(err.str());
raise
(
SIGTERM
);
raise
(
SIGTERM
);
}
}
...
@@ -838,25 +860,25 @@ void SharedMemory::initFromReserv()
...
@@ -838,25 +860,25 @@ void SharedMemory::initFromReserv()
if
(
sm_id
==
getId
()
&&
sm_node
==
conf
->
getLocalNode
()
)
if
(
sm_id
==
getId
()
&&
sm_node
==
conf
->
getLocalNode
()
)
{
{
d
crit
<<
myname
<<
"(initFromReserv): Initialization of himself?! ignore.."
<<
endl
;
sm
crit
<<
myname
<<
"(initFromReserv): Initialization of himself?! ignore.."
<<
endl
;
continue
;
continue
;
}
}
if
(
initFromSM
(
sm_id
,
sm_node
)
)
if
(
initFromSM
(
sm_id
,
sm_node
)
)
{
{
d
info
<<
myname
<<
"(initFromReserv): init from sm_id='"
<<
smName
<<
"' sm_node='"
<<
smNode
<<
"' [OK]"
<<
endl
;
sm
info
<<
myname
<<
"(initFromReserv): init from sm_id='"
<<
smName
<<
"' sm_node='"
<<
smNode
<<
"' [OK]"
<<
endl
;
return
;
return
;
}
}
d
info
<<
myname
<<
"(initFromReserv): init from sm_id='"
<<
smName
<<
"' sm_node='"
<<
smNode
<<
"' [FAILED]"
<<
endl
;
sm
info
<<
myname
<<
"(initFromReserv): init from sm_id='"
<<
smName
<<
"' sm_node='"
<<
smNode
<<
"' [FAILED]"
<<
endl
;
}
}
d
warn
<<
myname
<<
"(initFromReserv): FAILED INIT FROM <ReservList>"
<<
endl
;
sm
warn
<<
myname
<<
"(initFromReserv): FAILED INIT FROM <ReservList>"
<<
endl
;
}
}
// ----------------------------------------------------------------------------
// ----------------------------------------------------------------------------
bool
SharedMemory
::
initFromSM
(
UniSetTypes
::
ObjectId
sm_id
,
UniSetTypes
::
ObjectId
sm_node
)
bool
SharedMemory
::
initFromSM
(
UniSetTypes
::
ObjectId
sm_id
,
UniSetTypes
::
ObjectId
sm_node
)
{
{
d
info
<<
myname
<<
"(initFromSM): init from sm_id='"
<<
sm_id
<<
"' sm_node='"
<<
sm_node
<<
"'"
<<
endl
;
sm
info
<<
myname
<<
"(initFromSM): init from sm_id='"
<<
sm_id
<<
"' sm_node='"
<<
sm_node
<<
"'"
<<
endl
;
// SENSORS MAP
// SENSORS MAP
try
try
...
@@ -880,7 +902,7 @@ bool SharedMemory::initFromSM( UniSetTypes::ObjectId sm_id, UniSetTypes::ObjectI
...
@@ -880,7 +902,7 @@ bool SharedMemory::initFromSM( UniSetTypes::ObjectId sm_id, UniSetTypes::ObjectI
if
(
io
==
myioEnd
()
)
if
(
io
==
myioEnd
()
)
{
{
d
crit
<<
myname
<<
"(initFromSM): not found sensor id="
<<
ii
.
si
.
id
<<
"'"
<<
endl
;
sm
crit
<<
myname
<<
"(initFromSM): not found sensor id="
<<
ii
.
si
.
id
<<
"'"
<<
endl
;
continue
;
continue
;
}
}
...
@@ -897,11 +919,11 @@ bool SharedMemory::initFromSM( UniSetTypes::ObjectId sm_id, UniSetTypes::ObjectI
...
@@ -897,11 +919,11 @@ bool SharedMemory::initFromSM( UniSetTypes::ObjectId sm_id, UniSetTypes::ObjectI
}
}
catch
(
const
Exception
&
ex
)
catch
(
const
Exception
&
ex
)
{
{
d
crit
<<
myname
<<
"(initFromSM): "
<<
ex
<<
endl
;
sm
crit
<<
myname
<<
"(initFromSM): "
<<
ex
<<
endl
;
}
}
catch
(
const
IOController_i
::
NameNotFound
&
ex
)
catch
(
const
IOController_i
::
NameNotFound
&
ex
)
{
{
d
crit
<<
myname
<<
"(initFromSM): not found sensor id="
<<
ii
.
si
.
id
<<
"'"
<<
endl
;
sm
crit
<<
myname
<<
"(initFromSM): not found sensor id="
<<
ii
.
si
.
id
<<
"'"
<<
endl
;
}
}
}
}
...
@@ -909,7 +931,7 @@ bool SharedMemory::initFromSM( UniSetTypes::ObjectId sm_id, UniSetTypes::ObjectI
...
@@ -909,7 +931,7 @@ bool SharedMemory::initFromSM( UniSetTypes::ObjectId sm_id, UniSetTypes::ObjectI
}
}
catch
(
const
UniSetTypes
::
Exception
&
ex
)
catch
(
const
UniSetTypes
::
Exception
&
ex
)
{
{
d
warn
<<
myname
<<
"(initFromSM): "
<<
ex
<<
endl
;
sm
warn
<<
myname
<<
"(initFromSM): "
<<
ex
<<
endl
;
}
}
return
false
;
return
false
;
...
...
extensions/SharedMemory/SharedMemory.h
View file @
bef704d0
...
@@ -11,6 +11,10 @@
...
@@ -11,6 +11,10 @@
#include "PassiveTimer.h"
#include "PassiveTimer.h"
#include "NCRestorer.h"
#include "NCRestorer.h"
#include "WDTInterface.h"
#include "WDTInterface.h"
#include "LogServer.h"
#include "DebugStream.h"
#include "SMLogSugar.h"
#include "LogAgregator.h"
// -----------------------------------------------------------------------------
// -----------------------------------------------------------------------------
/*! \page page_SharedMemory Реализация разделямой между процессами памяти (SharedMemory)
/*! \page page_SharedMemory Реализация разделямой между процессами памяти (SharedMemory)
...
@@ -377,7 +381,7 @@ class SharedMemory:
...
@@ -377,7 +381,7 @@ class SharedMemory:
virtual
void
sysCommand
(
const
UniSetTypes
::
SystemMessage
*
sm
)
override
;
virtual
void
sysCommand
(
const
UniSetTypes
::
SystemMessage
*
sm
)
override
;
virtual
void
timerInfo
(
const
UniSetTypes
::
TimerMessage
*
tm
)
override
;
virtual
void
timerInfo
(
const
UniSetTypes
::
TimerMessage
*
tm
)
override
;
virtual
void
askSensors
(
UniversalIO
::
UIOCommand
cmd
);
virtual
void
askSensors
(
UniversalIO
::
UIOCommand
cmd
)
{}
;
void
sendEvent
(
UniSetTypes
::
SystemMessage
&
sm
);
void
sendEvent
(
UniSetTypes
::
SystemMessage
&
sm
);
void
initFromReserv
();
void
initFromReserv
();
bool
initFromSM
(
UniSetTypes
::
ObjectId
sm_id
,
UniSetTypes
::
ObjectId
sm_node
);
bool
initFromSM
(
UniSetTypes
::
ObjectId
sm_id
,
UniSetTypes
::
ObjectId
sm_node
);
...
@@ -385,6 +389,7 @@ class SharedMemory:
...
@@ -385,6 +389,7 @@ class SharedMemory:
// действия при завершении работы
// действия при завершении работы
virtual
void
sigterm
(
int
signo
)
override
;
virtual
void
sigterm
(
int
signo
)
override
;
virtual
bool
activateObject
()
override
;
virtual
bool
activateObject
()
override
;
virtual
bool
deactivateObject
()
override
;
bool
readItem
(
const
std
::
shared_ptr
<
UniXML
>&
xml
,
UniXML
::
iterator
&
it
,
xmlNode
*
sec
);
bool
readItem
(
const
std
::
shared_ptr
<
UniXML
>&
xml
,
UniXML
::
iterator
&
it
,
xmlNode
*
sec
);
void
buildEventList
(
xmlNode
*
cnode
);
void
buildEventList
(
xmlNode
*
cnode
);
...
@@ -464,6 +469,12 @@ class SharedMemory:
...
@@ -464,6 +469,12 @@ class SharedMemory:
xmlNode
*
confnode
;
xmlNode
*
confnode
;
std
::
shared_ptr
<
LogAgregator
>
loga
;
std
::
shared_ptr
<
DebugStream
>
smlog
;
std
::
shared_ptr
<
LogServer
>
logserv
;
std
::
string
logserv_host
=
{
""
};
int
logserv_port
=
{
0
};
private
:
private
:
HistorySlot
m_historySignal
;
HistorySlot
m_historySignal
;
};
};
...
...
extensions/SharedMemory/smemory.cc
View file @
bef704d0
...
@@ -23,10 +23,13 @@ int main(int argc, const char** argv)
...
@@ -23,10 +23,13 @@ int main(int argc, const char** argv)
{
{
auto
conf
=
uniset_init
(
argc
,
argv
);
auto
conf
=
uniset_init
(
argc
,
argv
);
string
logfilename
=
conf
->
getArgParam
(
"--logfile"
,
"smemory.log"
);
string
logfilename
=
conf
->
getArgParam
(
"--logfile"
,
""
);
if
(
!
logfilename
.
empty
()
)
{
string
logname
(
conf
->
getLogDir
()
+
logfilename
);
string
logname
(
conf
->
getLogDir
()
+
logfilename
);
ulog
()
->
logFile
(
logname
);
ulog
()
->
logFile
(
logname
);
dlog
()
->
logFile
(
logname
);
dlog
()
->
logFile
(
logname
);
}
auto
shm
=
SharedMemory
::
init_smemory
(
argc
,
argv
);
auto
shm
=
SharedMemory
::
init_smemory
(
argc
,
argv
);
...
...
extensions/SharedMemory/start_fg.sh
View file @
bef704d0
...
@@ -5,6 +5,7 @@ export LD_LIBRARY_PATH="../../lib/.libs;../lib/.libs"
...
@@ -5,6 +5,7 @@ export LD_LIBRARY_PATH="../../lib/.libs;../lib/.libs"
ulimit
-Sc
10000000000
ulimit
-Sc
10000000000
./uniset2-start.sh
-f
./uniset2-smemory
--smemory-id
SharedMemory
--pulsar-id
DO_C
--pulsar-iotype
DO
--pulsar-msec
100
\
./uniset2-start.sh
-f
./uniset2-smemory
--smemory-id
SharedMemory
--pulsar-id
DO_C
--pulsar-iotype
DO
--pulsar-msec
100
\
--confile
test.xml
--datfile
test.xml
--db-logging
1
--ulog-add-levels
system
$*
\
--confile
test.xml
--datfile
test.xml
--db-logging
1
--ulog-add-levels
system
\
--sm-log-add-levels
any
$*
\
#--ulog-add-levels info,crit,warn,level9,system \
#--ulog-add-levels info,crit,warn,level9,system \
#--dlog-add-levels info,crit,warn \
#--dlog-add-levels info,crit,warn \
include/LogServer.h
View file @
bef704d0
...
@@ -106,7 +106,7 @@ class LogServer
...
@@ -106,7 +106,7 @@ class LogServer
std
::
atomic_bool
cancelled
;
std
::
atomic_bool
cancelled
;
DebugStream
mylog
;
DebugStream
mylog
;
ThreadCreator
<
LogServer
>*
thr
;
std
::
shared_ptr
<
ThreadCreator
<
LogServer
>
>
thr
;
ost
::
TCPSocket
*
tcp
;
ost
::
TCPSocket
*
tcp
;
std
::
shared_ptr
<
DebugStream
>
elog
;
std
::
shared_ptr
<
DebugStream
>
elog
;
...
...
src/Communications/Modbus/ModbusTCPServer.cc
View file @
bef704d0
...
@@ -24,16 +24,6 @@ ModbusTCPServer::ModbusTCPServer( ost::InetAddress& ia, int port ):
...
@@ -24,16 +24,6 @@ ModbusTCPServer::ModbusTCPServer( ost::InetAddress& ia, int port ):
ModbusTCPServer
::~
ModbusTCPServer
()
ModbusTCPServer
::~
ModbusTCPServer
()
{
{
terminate
();
terminate
();
/*
{
uniset_mutex_lock l(sMutex);
for( auto& s: slist )
{
if( s->isRunning() )
s->ost::Thread::join();
}
}
*/
}
}
// -------------------------------------------------------------------------
// -------------------------------------------------------------------------
void
ModbusTCPServer
::
setMaxSessions
(
unsigned
int
num
)
void
ModbusTCPServer
::
setMaxSessions
(
unsigned
int
num
)
...
@@ -375,7 +365,7 @@ void ModbusTCPServer::terminate()
...
@@ -375,7 +365,7 @@ void ModbusTCPServer::terminate()
uniset_mutex_lock
l
(
sMutex
);
uniset_mutex_lock
l
(
sMutex
);
for
(
auto
&
s
:
slist
)
for
(
const
auto
&
s
:
slist
)
{
{
try
try
{
{
...
@@ -404,7 +394,7 @@ void ModbusTCPServer::getSessions( Sessions& lst )
...
@@ -404,7 +394,7 @@ void ModbusTCPServer::getSessions( Sessions& lst )
{
{
uniset_mutex_lock
l
(
sMutex
);
uniset_mutex_lock
l
(
sMutex
);
for
(
auto
&
i
:
slist
)
for
(
const
auto
&
i
:
slist
)
{
{
SessionInfo
inf
(
i
->
getClientAddress
(),
i
->
getAskCount
()
);
SessionInfo
inf
(
i
->
getClientAddress
(),
i
->
getAskCount
()
);
lst
.
push_back
(
inf
);
lst
.
push_back
(
inf
);
...
...
src/Log/LogServer.cc
View file @
bef704d0
...
@@ -12,10 +12,9 @@ LogServer::~LogServer()
...
@@ -12,10 +12,9 @@ LogServer::~LogServer()
{
{
if
(
nullsess
)
if
(
nullsess
)
nullsess
->
cancel
();
nullsess
->
cancel
();
{
{
// uniset_rwmutex_wrlock l(mutSList);
// uniset_rwmutex_wrlock l(mutSList);
for
(
auto
&
i
:
slist
)
for
(
const
auto
&
i
:
slist
)
{
{
if
(
i
->
isRunning
()
)
if
(
i
->
isRunning
()
)
i
->
cancel
();
i
->
cancel
();
...
@@ -24,17 +23,14 @@ LogServer::~LogServer()
...
@@ -24,17 +23,14 @@ LogServer::~LogServer()
cancelled
=
true
;
cancelled
=
true
;
if
(
tcp
&&
!
slist
.
empty
()
)
tcp
->
reject
();
if
(
thr
)
if
(
thr
)
{
thr
->
stop
();
thr
->
stop
();
if
(
thr
->
isRunning
()
)
thr
->
join
();
delete
thr
;
}
delete
tcp
;
delete
tcp
;
tcp
=
0
;
}
}
// -------------------------------------------------------------------------
// -------------------------------------------------------------------------
LogServer
::
LogServer
(
std
::
shared_ptr
<
LogAgregator
>
log
)
:
LogServer
::
LogServer
(
std
::
shared_ptr
<
LogAgregator
>
log
)
:
...
@@ -110,7 +106,7 @@ void LogServer::run( const std::string& addr, ost::tpport_t port, bool thread )
...
@@ -110,7 +106,7 @@ void LogServer::run( const std::string& addr, ost::tpport_t port, bool thread )
work
();
work
();
else
else
{
{
thr
=
new
ThreadCreator
<
LogServer
>
(
this
,
&
LogServer
::
work
);
thr
=
make_shared
<
ThreadCreator
<
LogServer
>
>
(
this
,
&
LogServer
::
work
);
thr
->
start
();
thr
->
start
();
}
}
}
}
...
@@ -125,6 +121,7 @@ void LogServer::work()
...
@@ -125,6 +121,7 @@ void LogServer::work()
{
{
while
(
!
cancelled
&&
tcp
->
isPendingConnection
(
timeout
)
)
while
(
!
cancelled
&&
tcp
->
isPendingConnection
(
timeout
)
)
{
{
if
(
cancelled
)
break
;
{
{
uniset_rwmutex_wrlock
l
(
mutSList
);
uniset_rwmutex_wrlock
l
(
mutSList
);
int
sz
=
slist
.
size
();
int
sz
=
slist
.
size
();
...
@@ -149,6 +146,8 @@ void LogServer::work()
...
@@ -149,6 +146,8 @@ void LogServer::work()
}
}
}
}
if
(
cancelled
)
break
;
auto
s
=
make_shared
<
LogSession
>
(
*
tcp
,
elog
,
sessTimeout
,
cmdTimeout
,
outTimeout
);
auto
s
=
make_shared
<
LogSession
>
(
*
tcp
,
elog
,
sessTimeout
,
cmdTimeout
,
outTimeout
);
s
->
setSessionLogLevel
(
sessLogLevel
);
s
->
setSessionLogLevel
(
sessLogLevel
);
{
{
...
@@ -178,7 +177,7 @@ void LogServer::work()
...
@@ -178,7 +177,7 @@ void LogServer::work()
{
{
// uniset_rwmutex_wrlock l(mutSList);
// uniset_rwmutex_wrlock l(mutSList);
for
(
auto
&
i
:
slist
)
for
(
const
auto
&
i
:
slist
)
i
->
disconnect
();
i
->
disconnect
();
if
(
nullsess
)
if
(
nullsess
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment