From 7267a5a1640fc006c2a226bfdb49d5f9dfcbee86 Mon Sep 17 00:00:00 2001 From: renzuzu <82306584+renzuzu@users.noreply.github.com> Date: Wed, 13 Oct 2021 16:19:24 +0800 Subject: [PATCH] tweak(server/client): Less sql queries applied batch saving with caching instead of saving per event triggered --- renzu_hud/client/client.lua | 36 ++++++++--- renzu_hud/server/server.lua | 120 +++++++++++++++++++++++++----------- 2 files changed, 112 insertions(+), 44 deletions(-) diff --git a/renzu_hud/client/client.lua b/renzu_hud/client/client.lua index 7337281a..6270d344 100644 --- a/renzu_hud/client/client.lua +++ b/renzu_hud/client/client.lua @@ -7,6 +7,7 @@ -- If you redistribute this software, you must link to ORIGINAL repository at https://github.com/renzuzu/renzu_hud -- This copyright should appear in every part of the project code ESX = nil +local getdata = false CreateThread(function() if config.framework == 'ESX' then while ESX == nil do TriggerEvent('esx:getSharedObject', function(obj) ESX = obj end) Wait(0) end @@ -177,7 +178,10 @@ CreateThread(function() Wait(2000) print("ESX") Hud.lastped = PlayerPedId() - TriggerServerEvent("renzu_hud:getdata",Hud.charslot) + if not getdata then + TriggerServerEvent("renzu_hud:getdata",Hud.charslot) + getdata = true + end DecorSetBool(PlayerPedId(), "PLAYERLOADED", true) Wait(5000) SendNUIMessage({content = true, type = 'pedface'}) @@ -190,7 +194,10 @@ CreateThread(function() Wait(2000) print("QB") Hud.lastped = PlayerPedId() - TriggerServerEvent("renzu_hud:getdata",Hud.charslot) + if not getdata then + TriggerServerEvent("renzu_hud:getdata",Hud.charslot) + getdata = true + end DecorSetBool(PlayerPedId(), "PLAYERLOADED", true) Wait(5000) SendNUIMessage({content = true, type = 'pedface'}) @@ -205,7 +212,10 @@ CreateThread(function() Wait(2000) Hud.lastped = PlayerPedId() DecorSetBool(PlayerPedId(), "PLAYERLOADED", true) - TriggerServerEvent("renzu_hud:getdata",Hud.charslot) + if not getdata then + TriggerServerEvent("renzu_hud:getdata",Hud.charslot) + getdata = true + end Wait(5000) SendNUIMessage({content = true, type = 'pedface'}) SendNUIMessage({content = true, type = 'playerloaded'}) @@ -220,14 +230,20 @@ CreateThread(function() end if DecorExistOn(PlayerPedId(), "PLAYERLOADED") and Hud.charslot ~= nil then print("PLAYERLOADED") - TriggerServerEvent("renzu_hud:getdata",Hud.charslot) + if not getdata then + TriggerServerEvent("renzu_hud:getdata",Hud.charslot) + getdata = true + end Hud.playerloaded = true SendNUIMessage({content = true, type = 'playerloaded'}) end Wait(500) if DecorExistOn(PlayerPedId(), "PLAYERLOADED") and config.loadedasmp and Hud:isplayer() then print("ISMP") - TriggerServerEvent("renzu_hud:getdata",0, config.multichar) + if not getdata then + TriggerServerEvent("renzu_hud:getdata",0, config.multichar) + getdata = true + end DecorSetBool(PlayerPedId(), "PLAYERLOADED", true) Hud.playerloaded = true SendNUIMessage({content = true, type = 'pedface'}) @@ -239,13 +255,19 @@ CreateThread(function() Wait(2000) Hud.lastped = PlayerPedId() DecorSetBool(PlayerPedId(), "PLAYERLOADED", true) - TriggerServerEvent("renzu_hud:getdata",Hud.charslot) + if not getdata then + TriggerServerEvent("renzu_hud:getdata",Hud.charslot) + getdata = true + end Wait(5000) SendNUIMessage({content = true, type = 'pedface'}) SendNUIMessage({content = true, type = 'playerloaded'}) elseif DecorExistOn(PlayerPedId(), "PLAYERLOADED") then print("already loaded") - TriggerServerEvent("renzu_hud:getdata",0, config.multichar) + if not getdata then + TriggerServerEvent("renzu_hud:getdata",0, config.multichar) + getdata = true + end DecorSetBool(PlayerPedId(), "PLAYERLOADED", true) Hud.playerloaded = true SendNUIMessage({content = true, type = 'pedface'}) diff --git a/renzu_hud/server/server.lua b/renzu_hud/server/server.lua index b6a787f9..6f3d7ffc 100644 --- a/renzu_hud/server/server.lua +++ b/renzu_hud/server/server.lua @@ -11,7 +11,8 @@ Renzu = {} charslot = {} ESX = nil QBCore = nil - +local vehicles = {} +vehicle_stat = {} function SQLQuery(plugin,type,query,var) local wait = promise.new() if type == 'fetchAll' and plugin == 'mysql-async' then @@ -47,8 +48,36 @@ function SQLQuery(plugin,type,query,var) return Citizen.Await(wait) end +function FetchVehicles() + local ownedvehicles = SQLQuery(config.Mysql,'fetchAll',"SELECT "..config.Owner_column..", `plate` FROM "..config.vehicle_table.." ", {}) + for k,v in pairs(ownedvehicles) do + local plate = string.gsub(v.plate:upper(), '^%s*(.-)%s*$', '%1') + v.plate = plate + vehicles[v.plate] = v + end +end + +Citizen.CreateThread(function() + while true do + FetchVehicles() + Wait(30000) + end +end) + Citizen.CreateThread(function() Wait(1000) + local ownedvehicles = SQLQuery(config.Mysql,'fetchAll',"SELECT "..config.Owner_column..", `plate` FROM "..config.vehicle_table.." ", {}) + local stat = SQLQuery(config.Mysql,'fetchAll',"SELECT stats,plate,owner FROM vehicle_status", {}) + for k , v in pairs(ownedvehicles) do + local plate = string.gsub(v.plate:upper(), '^%s*(.-)%s*$', '%1') + v.plate = plate + vehicles[v.plate] = v + end + for k , v in pairs(stat) do + local plate = string.gsub(v.plate:upper(), '^%s*(.-)%s*$', '%1') + v.plate = plate + vehicle_stat[v.plate] = v + end if config.Mysql == 'mysql-async' then MySQL.Sync.execute([[ CREATE TABLE IF NOT EXISTS `vehicle_status` ( @@ -157,7 +186,8 @@ Citizen.CreateThread(function() end) function isVehicleOwned(plate) - local owner = SQLQuery(config.Mysql,'fetchAll',"SELECT "..config.Owner_column.." FROM "..config.vehicle_table.." WHERE UPPER(plate)=@plate", {['@plate'] = plate:upper()}) + local plate = string.gsub(plate:upper(), '^%s*(.-)%s*$', '%1') + local owner = vehicles[plate] ~= nil and vehicles[plate] or nil return owner end @@ -187,43 +217,58 @@ SyncStat = function(stat) end local kids = {} +local oldt = {} +local toupdate = 0 +local lastupdate = 0 +local unsaved = {} RegisterNetEvent("renzu_hud:savedata") AddEventHandler("renzu_hud:savedata", function(plate,table,updatevehicles) local source = source - if plate ~= nil and kids[source] ~= nil and kids[source] < GetGameTimer() or plate ~= nil and kids[source] == nil then -- block any request until the timer is lessthan the gametimer or if its nil - kids[source] = GetGameTimer() + 2000 -- i receive some reports this event is being used by kiddies to perform a noob things :D - --local plate = string.gsub(plate, "%s+", "") + if plate ~= nil and kids[source] ~= nil and kids[source] < GetGameTimer() or plate ~= nil and kids[source] == nil then + kids[source] = GetGameTimer() + 2000 local foundplate = false local newcreated = false if plate ~= nil then - --print("SAVING") - adv_table[tostring(plate)] = table - local results = SQLQuery(config.Mysql,'fetchAll',"SELECT stats,plate,owner FROM vehicle_status WHERE UPPER(plate)=@plate", {['@plate'] = plate:upper()}) - if #results <= 0 then + adv_table[string.gsub(plate, '^%s*(.-)%s*$', '%1')] = table + local results = vehicle_stat[string.gsub(plate, '^%s*(.-)%s*$', '%1')] + if results == nil then local owner = isVehicleOwned(plate) - --print(owner,#owner) - if owner ~= nil and #owner > 0 then + if owner ~= nil then SQLQuery(config.Mysql,'execute',"INSERT INTO vehicle_status (stats, plate, owner) VALUES (@stats, @plate, @owner)", { - ['@stats'] = json.encode(adv_table[tostring(plate)]), + ['@stats'] = json.encode(adv_table[string.gsub(plate, '^%s*(.-)%s*$', '%1')]), ['@plate'] = plate:upper(), - ['@owner'] = owner[1][config.Owner_column] + ['@owner'] = owner[config.Owner_column] }) foundplate = true - adv_table[tostring(plate)].owner = owner[1][config.Owner_column] + print("INSERT") + adv_table[string.gsub(plate, '^%s*(.-)%s*$', '%1')].owner = owner[config.Owner_column] + vehicle_stat[string.gsub(plate, '^%s*(.-)%s*$', '%1')] = adv_table[string.gsub(plate, '^%s*(.-)%s*$', '%1')] end end - if #results > 0 then + if results then foundplate = true local owner = isVehicleOwned(plate) - SQLQuery(config.Mysql,'execute',"UPDATE vehicle_status SET stats = @stats WHERE UPPER(plate) = @plate", { - ['@stats'] = json.encode(adv_table[tostring(plate)]), - ['@plate'] = plate:upper(), - ['owner'] = owner[1][config.Owner_column] - }) - adv_table[tostring(plate)].owner = owner[1][config.Owner_column] + if toupdate > 10 or lastupdate == 0 or lastupdate <= GetGameTimer() then + for k,v in pairs(unsaved) do + SQLQuery(config.Mysql,'execute',"UPDATE vehicle_status SET stats = @stats WHERE TRIM(UPPER(plate)) = @plate", { + ['@stats'] = json.encode(unsaved[string.gsub(v.plate:upper(), '^%s*(.-)%s*$', '%1')]), + ['@plate'] = string.gsub(v.plate:upper(), '^%s*(.-)%s*$', '%1'), + ['owner'] = v.owner + }) + print("Update"..v.plate) + end + lastupdate = GetGameTimer() + 20000 + toupdate = 0 + end + toupdate = toupdate + 1 + if toupdate < 10 then + unsaved[string.gsub(plate, '^%s*(.-)%s*$', '%1')] = adv_table[string.gsub(plate, '^%s*(.-)%s*$', '%1')] + end + adv_table[string.gsub(plate, '^%s*(.-)%s*$', '%1')].owner = owner[config.Owner_column] + oldt[string.gsub(plate, '^%s*(.-)%s*$', '%1')] = adv_table[string.gsub(plate, '^%s*(.-)%s*$', '%1')] end if not foundplate then - adv_table[tostring(plate)].owner = nil + adv_table[string.gsub(plate, '^%s*(.-)%s*$', '%1')].owner = nil end SyncStat(adv_table) --ply.state:set( --[[keyName]] 'adv_stat', --[[value]] adv_table, --[[replicate to server]] true) @@ -403,20 +448,20 @@ AddEventHandler("renzu_hud:wheelsetting", function(entity,val,coords) TriggerClientEvent("renzu_hud:wheelsetting", -1, entity,wheelsetting) end) -local antispam = {} -RegisterServerEvent("mumble:SetVoiceData") -AddEventHandler("mumble:SetVoiceData", function(mode,prox) - local source = source - if mode == 'mode' then - TriggerClientEvent("renzu_hud:SetVoiceData", source, 'proximity', prox) - end - if mode == 'radio' and not antispam[source] then - antispam[source] = true - TriggerClientEvent("renzu_hud:SetVoiceData", source, 'radio', prox) - Wait(10) - antispam[source] = false - end -end) +-- local antispam = {} +-- RegisterServerEvent("mumble:SetVoiceData") +-- AddEventHandler("mumble:SetVoiceData", function(mode,prox) +-- local source = source +-- if mode == 'mode' then +-- TriggerClientEvent("renzu_hud:SetVoiceData", source, 'proximity', prox) +-- end +-- if mode == 'radio' and not antispam[source] then +-- antispam[source] = true +-- TriggerClientEvent("renzu_hud:SetVoiceData", source, 'radio', prox) +-- Wait(10) +-- antispam[source] = false +-- end +-- end) function PlayerIdentifier(source) local source = source @@ -592,7 +637,8 @@ RegisterServerEvent('renzu_hud:change_engine') AddEventHandler('renzu_hud:change_engine', function(plate, stats) local plate = plate adv_table[tostring(plate)] = stats - results = SQLQuery(config.Mysql,'fetchAll',"SELECT stats,plate FROM vehicle_status WHERE UPPER(plate)=@plate", {['@plate'] = plate:upper()}) + FetchVehicles() + results = SQLQuery(config.Mysql,'fetchAll',"SELECT stats,plate FROM vehicle_status WHERE TRIM(UPPER(plate))=@plate", {['@plate'] = string.gsub(plate:upper(), '^%s*(.-)%s*$', '%1')}) if #results > 0 then foundplate = true SQLQuery(config.Mysql,'execute',"UPDATE vehicle_status SET stats = @status WHERE UPPER(plate) = @plate", {