Jump to content

Recommended Posts

Posted

I know how to do basic MySQL backups and have some scripts that I have used in the past. But I am having trouble with an old machine that I decided to setup as a server. None of the modern software I used to use works with the XP 32bit system. I hav elost my license for Navicat so I have been trying to find a way with MySQL GUI tools (the older versions of MySQL Workbench). I have tried to type out the manual commands for - mysqld but I am not getting expected results.

 

So I am in a bit of a situation because I want to format the HDD and take off Win 32 and put on a system that can operate with more than 4GB RAM and run overall better. Before I can do that I need an effective way to backup the entire L2GLS, L2JGS, L2GCS  databases and make sure that I can dump each table in a separate file so I can then put them back into their respective folders when I want to run the default database installation file.

 

The Tables must be separate SQL files for two main reasons, the PC doesn't have the computing power or memory to process a full database dump of the Game Server and secondly as I mentioned above, it makes it easier to install the backed up files on the new Operating System. Please provide authentic solutions as I have read many articles but non clearly stipulate how to backup a database table by table for each database.

Posted

What's the problem with mysqldump ? And be serious, if your computer can handle a MySQL server, it got the power to backup it... Simply crashes all third-party softwares (antivirus, etc) to faster the operation and avoid external read/write accesses.

 

http://webcheatsheet.com/sql/mysql_backup_restore.php

https://dev.mysql.com/doc/refman/5.7/en/mysqldump.html

 

Once you got your backup, nothing stops you to open it and query it wherever you want.

Posted

My game server has a 5 min approx. I had to even increase the timeout parameters for many things including the java timeout parameters. Also it has only 4GB Ram and Celeron CPU but win xp is seeing 3.4GB RAM. It's slow and when I used regular SQL dump it puts everything in one file (eventually). But when so much data is in one file it causes it load into memory and that is when the PC hangs. I can't import large SQL's on this system. Which is why I need to find a thinner system that can optimise more memory.  Those links don't help me:

 

shell> mysqldump [options] db_name [tbl_name ...] Need to manually know the name of every table and run it individually for each table
shell> mysqldump [options] --databases db_name ... dumps entire database in one SQL
shell> mysqldump [options] --all-databases ..... dumps each database into a single SQL

 

is there are command for example C:\mysql\bin mysqld uname psswrd dbase "tables" and auto dump for each table in database?

Posted (edited)

http://dba.stackexchange.com/questions/9306/how-do-you-mysqldump-specific-tables ?

 

It's not like all tables are useful to keep, until you use prehistoric pack and got everything on sql instead of xml, and you edited every single table yourself. Still, 4g is far enough (even a Vista uses something like 1.5g, which leave you with 2.2g left), so I don't know how you handle or admin your computer, but it's plain wrong.

 

PS : http://stackoverflow.com/questions/3669121/dump-all-mysql-tables-into-separate-files-automagically

Edited by Tryskell
Posted

On Tales when database is very big, backup might take several minutes. Server is managing automatic backup during middle of the night(when amount of players is low) and during server restart.

Code: http://pastebin.com/ZE72CB1F

It surely will give errors at first, ConfigHolder will be the reason.

Posted

Well I exported the entire database as an sql which I could not read back into the server if i needed to restore the database. So I was lucky that the new OS and the installation accepted the backup SQL's. Everything is running better except some script issues. But my initial question remains unanswered and from a technical point of view would like to know if the only way is to develop some kind of custom script to perform the backup.

Posted (edited)

Well I exported the entire database as an sql which I could not read back into the server if i needed to restore the database. So I was lucky that the new OS and the installation accepted the backup SQL's. Everything is running better except some script issues. But my initial question remains unanswered and from a technical point of view would like to know if the only way is to develop some kind of custom script to perform the backup.

This is just an example of a .bat script, you have to change your mysql folder and login/gameserver databases names and path, then add a task in Windows task scheduler at whatever interval suit you and it will do the backup automatically.

@echo off
Set FDate=%Date:~-10,10%
Set Fdate=%FDate:/=-%
MD C:\backup\%FDate%
MD C:\backup\%FDate%\yourlogindb
MD C:\backup\%FDate%\yourgameserverdb

copy /y C:\mysql\DATA\yourlogindb\* C:\backup\%FDate%\logindb
copy /y C:\mysql\DATA\yourgameserverdb\* C:\backup\%FDate%\gameserverdb

Edited by thanosdk
  • 2 years later...

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.



  • Posts

    • hello, i want to wtt my charracter in l2elmorelab 1x harbor for 1.5kkk adena in l2reborn 10x new. Or if you interested tell me your offer. :)) Clean Mail 30 lvl Cleric Naked   Updated.
    • package ai.npc.NFWalker; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.Random; import l2r.gameserver.enums.CtrlIntention; import l2r.gameserver.model.Location; import l2r.gameserver.model.actor.L2Npc; import l2r.gameserver.model.quest.Quest; import l2r.gameserver.network.clientpackets.Say2; import l2r.gameserver.network.serverpackets.NpcSay; public class NFWalkerAI extends Quest { private static final int WALKER_NPC_ID = 20116; private final Map<String, Route> routes = new HashMap<>(); private final Map<Integer, Integer> npcIndexes = new HashMap<>(); private final Map<Integer, Boolean> npcReverse = new HashMap<>(); private final Map<Integer, String> npcCurrentRoute = new HashMap<>(); public NFWalkerAI() { super(-1, NFWalkerAI.class.getSimpleName(), "ai/npc/NFWalker"); loadRoutes(); addSpawnId(WALKER_NPC_ID); } private void loadRoutes() { // Route 1 Data Route route1 = new Route("route1"); route1.addPoint(new RoutePoint(0, 149363, 172341, -941, 0, false, "")); route1.addPoint(new RoutePoint(1, 148568, 172328, -980, 5, true, "Puff")); route1.addPoint(new RoutePoint(2, 148536, 172792, -980, 0, false, "")); // Route 2 Data Route route2 = new Route("route2"); route2.addPoint(new RoutePoint(0, 149363, 172341, -941, 0, false, "")); route2.addPoint(new RoutePoint(1, 150248, 172328, -980, 5, true, "Rise my children! Bring me the servants of the god! Let them be offered to our god Bifrons!")); route2.addPoint(new RoutePoint(2, 150248, 172776, -980, 0, false, "")); // Add routes to the map routes.put("route1", route1); routes.put("route2", route2); } @Override public String onSpawn(L2Npc npc) { if (npc.getId() == WALKER_NPC_ID) { selectInitialRouteForNpc(npc); } return super.onSpawn(npc); } @Override public String onAdvEvent(String event, L2Npc npc, l2r.gameserver.model.actor.instance.L2PcInstance player) { if (event.equalsIgnoreCase("move")) { moveNpc(npc); } else if (event.equalsIgnoreCase("check_reached")) { checkIfReached(npc); } return null; } private void moveNpc(L2Npc npc) { String routeName = npcCurrentRoute.get(npc.getObjectId()); Route route = routes.get(routeName); Integer pointIndex = npcIndexes.get(npc.getObjectId()); if (route != null && pointIndex != null) { RoutePoint point = route.getPoints().get(pointIndex); if (point.isRun()) { npc.setRunning(); } else { npc.setWalking(); } if (!point.getChat().isEmpty()) { npc.broadcastPacket(new NpcSay(npc.getObjectId(), Say2.NPC_ALL, npc.getId(), point.getChat())); } npc.getAI().setIntention(CtrlIntention.AI_INTENTION_MOVE_TO, new Location(point.getX(), point.getY(), point.getZ())); // Log movement intention System.out.println("NPC " + npc.getObjectId() + " moving to " + point.getX() + ", " + point.getY() + ", " + point.getZ()); // Schedule a check to see if the NPC has reached its destination startQuestTimer("check_reached", 1000, npc, null); } } private void checkIfReached(L2Npc npc) { String routeName = npcCurrentRoute.get(npc.getObjectId()); Route route = routes.get(routeName); Integer pointIndex = npcIndexes.get(npc.getObjectId()); if (route != null && pointIndex != null) { RoutePoint point = route.getPoints().get(pointIndex); Location currentLocation = npc.getLocation(); Location targetLocation = new Location(point.getX(), point.getY(), point.getZ()); // Check if the NPC has reached the target location if (currentLocation.equals(targetLocation)) { // Log that the NPC has reached the target System.out.println("NPC " + npc.getObjectId() + " reached target " + targetLocation); // Schedule the next movement startQuestTimer("move", point.getDelay() * 1000, npc, null); if (!npcReverse.get(npc.getObjectId())) { pointIndex++; if (pointIndex >= route.getPoints().size()) { npcReverse.put(npc.getObjectId(), true); pointIndex = route.getPoints().size() - 1; } } else { pointIndex--; if (pointIndex < 0) { npcReverse.put(npc.getObjectId(), false); pointIndex = 0; // Choose a new route after completing the current one in both directions switchRouteForNpc(npc); return; } } npcIndexes.put(npc.getObjectId(), pointIndex); } else { // Check again after 1 second startQuestTimer("check_reached", 1000, npc, null); } } } private void selectInitialRouteForNpc(L2Npc npc) { // Randomly select either route1 or route2 String selectedRouteName = "route" + (new Random().nextInt(2) + 1); npcCurrentRoute.put(npc.getObjectId(), selectedRouteName); npcIndexes.put(npc.getObjectId(), 0); npcReverse.put(npc.getObjectId(), false); startQuestTimer("move", 5000, npc, null); // Log initial route selection System.out.println("NPC " + npc.getObjectId() + " selected initial route " + selectedRouteName); } private void switchRouteForNpc(L2Npc npc) { String currentRoute = npcCurrentRoute.get(npc.getObjectId()); String newRoute = currentRoute.equals("route1") ? "route2" : "route1"; npcCurrentRoute.put(npc.getObjectId(), newRoute); npcIndexes.put(npc.getObjectId(), 0); npcReverse.put(npc.getObjectId(), false); startQuestTimer("move", 5000, npc, null); // Log route switching System.out.println("NPC " + npc.getObjectId() + " switched to route " + newRoute); } private static class Route { private List<RoutePoint> points = new ArrayList<>(); public Route(String name) { } public void addPoint(RoutePoint point) { points.add(point); } public List<RoutePoint> getPoints() { return points; } } private static class RoutePoint { private int id; private int x, y, z, delay; private boolean run; private String chat; public RoutePoint(int id, int x, int y, int z, int delay, boolean run, String chat) { this.id = id; this.x = x; this.y = y; this.z = z; this.delay = delay; this.run = run; this.chat = chat; } public int getId() { return id; } public int getX() { return x; } public int getY() { return y; } public int getZ() { return z; } public int getDelay() { return delay; } public boolean isRun() { return run; } public String getChat() { return chat; } } } I looking for help, with this, the npc not start to move. Im trying to create, an NPC wich have multiple walk routes basic logic is  random pick a route complite the route  like Route 1 start form zero (0 -> 1 -> 2(or more) -> 1 -> 0) When the npc return to 0, the script should pic the other route and start again.  And if there is a message like point 1 here     "route1.addPoint(new RoutePoint(1, 148568, 172328, -980, 5, true, "Puff"));" The npc should display the chat message. Currently my problem is the npc not moving, but if I manage it to start moving its randomly move between the route 1 and 2 set of coordinates. Currently for me its  a nightmare. I hope anyone can help somhow.
    • We are certainly not an ambulance, but we will definitely cure you of blacklists and empty pockets. Live freely with SX! Each of you will receive a trial version of SX to familiarize yourself with the product, all you have to do is post in this thread
    • qual e o valor pra atualizar o java da soucer ?
  • Topics

×
×
  • Create New...