Files
EQN/appServer/test_redis.php
T
2017-09-22 23:17:20 +02:00

113 lines
3.4 KiB
PHP

<h1>EQN</h1>
Testing procedure Redis per EQN...
<?php
require 'redis.php';
require 'stopWatch.php';
# avvio misura tempi...
StopWatch::start();
function redis_error($error) {
// throw new error($error);
}
$redis = new redis_cli ();
$redis->connect("redis01");
$redis->set_error_function('redis_error');
$server = gethostname();
echo "Server ".$server." inizializzato, proseguo test<hr/>";
#------------------------------------------------------
# VALORI DI CONFIGURAZIONE (portare su file ext!!!)
#------------------------------------------------------
# ScoreList Posizioni
$semaforo = "EQN:USERS:SEMAPHORE";
$tblPos = "EQN:USERS:POS";
$tblLast= "EQN:USERS:UPD";
# timeout (x semaforo) IN SECONDI x gestione update POSIZIONI sul DB (cancello vecchi, inserisco nuovi): 1 min (poi 5?)
$tOutSemaforo = 30;
# età massima dei valori a sistema (2 minuti, in prod 30!!!)
$maxAgePos = 30;
# num record da processare in blocco
$nBlockRec = 10;
# controllo se serve cleanUp
$semOk=0;
# definizione funzioni helper x gestione REDIS dell'oggetto (UserID = numero, DTime in intero fino ai minuti yyMMddHHmm)
# Salva posizione utente
function salvaPosizione($redis, $tblPos, $tblLast, $User_ID, $Lat, $Lon, $DTime) {
# salvo dataora verifica
$redis->cmd('ZADD', $tblLast, $DTime, $User_ID )
// # salvo posizione Geolocalizzata
->cmd('GEOADD',$tblPos, $Lon, $Lat, $User_ID )
->set();
}
# Verifica SE ci sia semaforo rosso oppure se sia necessario a fine programma fare cleanUp
function checkSemaforo($redis, $semaforo, $tOutSemaforo) {
// verifico semaforo...
$answ=$redis->cmd('EXISTS', $semaforo )->get();
// se NON c'è lo creo
if($answ==0)
{
$redis->cmd('SET', $semaforo, date("YmdHi"))
->cmd('EXPIRE', $semaforo, $tOutSemaforo)
->set();
}
return $answ;
}
# effettua pulizia tabelle REDIS UTENTI (POS e UPD)
function cleanUp($redis, $tblPos, $tblLast, $DTime) {
// chiamo IN BLOCCO calcellazione dati vecchi (prima GEO e poi DTime)
echo "DTime Max: ".$DTime."<br/>";
// cerco i dati NUOVI (per DB) da persistere su DB $nBlockRec alla volta...
}
# conta quanti record ci siano nelle tab indicata
function cntRec($redis, $tblReq) {
// conteggio!
$answ=$redis->cmd('ZCOUNT', $tblReq, '-inf', '+inf')->set();
// ritorno valore
return $answ[0];
}
# Genero un UID univoco con nome server (numerico) + numero casuale
$uID = substr($server, 2, 2).rand(0,999999999);
# genero coordinate casuali LAT/LON
$cLat = rand(-80,80);
$cLon = rand(-170,170);
$currDT = date("YmdHi");
# in primis check semaforo SE debba fare pulizia
$semOk=checkSemaforo($redis, $semaforo, $tOutSemaforo);
$num=cntRec($redis, $tblLast);
echo"Semaforo: ".$semOk." | Trovati ".$num." valori in REDIS<br/>";
echo "Elapsed time: ".StopWatch::elapsed()." <br/>";
echo "<hr/>";
# effettuo update informazione posizione dell'utente (insert/update)
salvaPosizione($redis, $tblPos, $tblLast, $uID, $cLat, $cLon, $currDT);
echo"Valore salvato uID: ".$uID." | LAT: ".$cLat." | LON: ".$cLon." | DT: ".$currDT."<br/>";
echo "Elapsed time: ".StopWatch::elapsed()." <br/>";
echo "<hr/>";
# verifico semaforo $tOutPos2Db (se devo svuotare e aggiornare DB da redis)
if($semOk==0)
{
$maxDT = date("YmdHi",strtotime("-30 min"));
cleanUp($redis, $tblPos, $tblLast, $maxDT);
$num=cntRec($redis, $tblLast);
echo"Eseguito cleanUp: rimangono ".$num." valori in REDIS";
echo "<hr/>";
}
# mostro infine count record rimasti!!!
echo "<hr/>fatto!<br/>";
echo "Elapsed time: ".StopWatch::elapsed()." <br/>";
?>