1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
SÞjc@s¬ddlZddlZddlZddlZddlZddlZddlZddlZddlZddl    Z    ddl
Z
ddl Z ddl Z ddl Z ddlZddlZdZdZdZdZd„Zd„Zd„Zd    „Zd
„Zed „Zd „Zd „Zdd„Zd„Zd„Zde fd„ƒYZ!d„Z"d„Z#d„Z$d„Z%d„Z&d„Z'd„Z(d„Z)d„Z*dS(iÿÿÿÿNsC:\ServerRealTimeBackups.rtbiicCs$tjdƒtƒs tƒndS(NsµØÍ¼·þÎñÆ÷Æô¶¯(t    GameWorldtDebugLogtLoadGameWorldDataFromBackuptLoadGameWorldDataFromDB(((sdD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\DB\DBDataMgr.pyt OnServerStart)s     
cCs tƒdS(N(tSaveGameWorldDataToDB(((sdD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\DB\DBDataMgr.pyt OnServerClose0scCs]tjr dStjƒtjƒ|j|jgddggkrOttƒn
tt    ƒdS(Nii(
t
PyGameDatatg_serverClosingtDBFamilytOnMinutet DBBillboardthourtminutetBackupGameWorldDatatTruetFalse(tcurTime((sdD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\DB\DBDataMgr.pyR
5s    
 
! 
c
Csèg}xËtj|ƒD]º\}}}x¨|D] }|jtƒsGq,ntjj||ƒ}||jdƒ jdƒ}t|ƒdkrq,nt    j
|dƒ}t    j
|dƒ}    |j |    ||gƒq,WqW|j dt ƒ|S(Ns.t_iiitreverse(tostwalktendswitht BakFileTypetpathtjointindextsplittlenRtToIntDeftappendtsortR(
tbakPatht bakFileListtparentRt    filenamestfilenametfullPathtbakInfot dataVersionNOtbakTime((sdD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\DB\DBDataMgr.pytGetBakFileSortListCs c
Cstjƒjƒ}d|}tjjt|ƒ}tjd|ƒt|ƒ}|setjdƒdS|d}|d}|d}|t    j
kr²tj d|t    j
fƒ‚ntjd|ƒt |d    ƒ}|j ƒ}|jƒtj|ƒ}    |    s‚nt|    dƒt|    ƒtS(
NsS%ss ¼ÓÔØ±¸µµ: %ss ²»´æÔÚ±¸µµ!iiisk±¸µµÊý¾Ý°æ±¾ºÅУÑéʧ°Ü£¬ÇëʹÓÃÕýÈ·°æ±¾·þÎñÆ÷Æô¶¯ÖØÐµ¼ÈëÊý¾Ý! bakVersionNO=%s, GAMEWORLD_DATA_VERSION_NO=%ss ¶ÁÈ¡±¸µµ: %strb(Rt GetGameWorldt GetServerIDRRRtBakRoottLogR)tDBStructtGAMEWORLD_DATA_VERSION_NOtErrLogtopentreadtclosetCommFunct
DecompresstLoadPyGameDataRR(
tserverIDt
serverNametBakDirR!t finalBakInfot bakVersionNOt bakFilePathtftcompressed_datatsaveData((sdD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\DB\DBDataMgr.pyRTs2
 
 
 
     
 
cCs6tjr dStjs'tjdƒdSttjƒƒ}|sl|tjkrl|tjtdkrldSntj    ƒj
ƒ}d|}t j j t|ƒ}tjd|ƒt j j|ƒsÐt j|ƒntj}tj|tjƒ}t j j |d|||tfƒ}tƒ}tjd|t|ƒ|fƒtj|ƒ}    |    sbtjdƒdStjdt|    ƒƒy*t|d    ƒ}
|
j|    ƒ|
jƒWndSX|t_t|ƒ} xY| t D]M} | d
} y"t j!| ƒtjd | ƒWqÎtj"d | ƒqÎXqÎW|r2t#|ƒndS( Ns¼ÓÔØÊý¾ÝδÍê³É£¬²»´æ´¢±¸µµi<sS%ss·þÎñÆ÷±¸µµ: %ss
%s_%s_%s%ssBak:%s, len=%s, %stServerDataBackupErrorscompress len=%stwbiÿÿÿÿsɾ³ý¶àÓ౸µµÎļþ: %ssɾ³ý¶àÓ౸µµÎļþʧ°Ü: %s($RRt g_loadDataOKRR.tintttimet g_lastRTBTimetBackupIntervalR+R,RRRR-texiststmakedirsR/R0tChangeTimeNumToStrtChConfigtTYPE_Time_Format_YmdHMSRt GetSavePyDataRR5tCompresst SendGameErrorR2twriteR4R)t BackupCopyMaxtremoveR1R(tsaveToDBRR8R9R:R't
bakTiemStrR=R@R?tfpR!R&tfilePath((sdD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\DB\DBDataMgr.pyRusV         &
    %            
  cCsVtjƒjƒ}d|}tjjt|ƒ}tjd|ƒtj    |t
ƒdS(NsS%ss Çå¿Õ±¸µµ: %s( RR+R,RRRR-R.R5t    DelFolderR(R8R9R:((sdD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\DB\DBDataMgr.pytClearBackupFile¬s 
cCs0tjdƒtjƒjƒ}t|dƒdS(NsûÓб¸µµÊý¾Ý£¬Ö±½Ó´Ódb¼ÓÔØÊý¾Ý!i(RR.t PyMongoMaint GetUserCtrlDBtreadGameWorldDataR7(t
serverData((sdD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\DB\DBDataMgr.pyR·s  tcCs)|stƒ}ntjƒj|ƒdS(N(RMRYRZtsaveGameWorldData(R@((sdD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\DB\DBDataMgr.pyR¾s cCsFtjƒtƒ}|jƒ}tjdt|ƒt|ƒfƒ|S(NsGetSavePyData!! id = %s-%s(tPlayerActFamilyGCZt OnSavePyDatat GetDBDataMgrt GetSaveDataRR.tidR(t pyGameDataMgrtresult((sdD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\DB\DBDataMgr.pyRMÅs
 
     #cCsUtƒ}tjdt|ƒt|ƒfƒ|j||ƒ}tjƒtt    _
|S(NsLoadPyGameData!!id = %s %s( RaRR.RcRt LoadGameDataR_t OnLoadPyDataRRRC(t
gameBuffertposRd((sdD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\DB\DBDataMgr.pyR7Ïs     #
    tPyGameDataManagercBs#eZd„Zd„Zd„ZRS(cCsmtjƒ|_tjƒ|_tjƒ|_tjƒ|_tj    ƒ|_    t
j ƒ|_ t j ƒ|_ dS(N(t DBEventTrigt EventTrigMgrtDBPlayerViewCachetPlayerViewCacheMgrR t BillboardMgrtDBMailtMailMgrR    t    FamilyMgrt    DBGameRect
GameRecMgrt
DBFuncTeamt FuncTeamMgr(tself((sdD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\DB\DBDataMgr.pyt__init__ÜscCsd}||jjƒ7}||jjƒ7}||jjƒ7}||jjƒ7}||jjƒ7}||jjƒ7}||jjƒ7}|S(NR](RlRbRnRoRqRrRtRv(Rwtbuff((sdD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\DB\DBDataMgr.pyRbæscCs¸t|ƒ}|jj|||ƒ}|jj|||ƒ}|jj|||ƒ}|jj|||ƒ}|jj|||ƒ}|jj|||ƒ}|jj|||ƒ}|S(N(    RRlR7RnRoRqRrRtRv(RwRhRitdataslen((sdD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\DB\DBDataMgr.pyRfñs (t__name__t
__module__RxRbRf(((sdD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\DB\DBDataMgr.pyRjÛs    
     cCs(tj}|s$tƒ}|t_n|S(N(Rtg_pyGameDataManagerRj(Rd((sdD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\DB\DBDataMgr.pyRaüs
         cCstƒ}|jS(N(RaRl(t    dbDataMgr((sdD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\DB\DBDataMgr.pytGetEventTrigMgrs    cCstƒ}|jS(N(RaRn(R~((sdD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\DB\DBDataMgr.pytGetPlayerViewCacheMgr    s    cCstƒ}|jS(N(RaRr(R~((sdD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\DB\DBDataMgr.pyt GetFamilyMgrs    cCs tƒjƒS(N(RtGetFamilyActionMgr(((sdD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\DB\DBDataMgr.pyR‚scCstƒ}|jS(N(RaRq(R~((sdD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\DB\DBDataMgr.pyt
GetMailMgrs    cCstƒ}|jS(N(RaRo(R~((sdD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\DB\DBDataMgr.pytGetBillboardMgrs    cCstƒ}|jS(N(RaRt(R~((sdD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\DB\DBDataMgr.pyt GetGameRecMgr!s    cCstƒ}|jS(N(RaRv(R~((sdD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\DB\DBDataMgr.pytGetFuncTeamMgr&s    (+R5R/RKRRRYRmR_RkR RuRsR    RpRERR-RRQRGRRR
R)RRRRXRRRMR7tobjectRjRaRR€RR‚RƒR„R…R†(((sdD:\SG_ServerCode\ServerPython\ZoneServerGroup\map1_8G\MapServer\MapServerData\Script\DB\DBDataMgr.pyt<module>sP                                    ! 7              
     !