Jump to content

[Interlude] Automatic Restart!


Recommended Posts

  • 2 years later...

OK now some changes made by myself for l2jfrozen pack. first for announces in Shutdown.java add this code on place:
 

_seconds = _secondsShut;
_minutes = _seconds / 60;
_hours = _seconds / 3600;
// 30 min, 20 min, 10 min, 5 min, 2 min, 1 min announces
				
+ if (_seconds == 1800 || _seconds == 1200 || _seconds == 600 || _seconds == 300 || _seconds == 120 || _seconds == 60)
+ {
+ _an.announceToAll("Server is " + MODE_TEXT[_shutdownMode] + " after " + _minutes + " minute(s)!");				
+ }
				
// announce only every minute after 10 minutes left and every second after 20 seconds

After that modified code to save before autorestarting:

 

public void autoRestart(int time)
{
     _secondsShut = time;
     _instance._shutdownMode = GM_RESTART;
      countdown();
        LOGGER.warn("Auto Restart countdown is over. " + MODE_TEXT[_shutdownMode] + " NOW!");
        saveData();
	Runtime.getRuntime().halt(2);
}

Now will show restarting, not SIGTERM.

After that - modified Restart.java
 

/*
* This program is free software: you can redistribute it and/or modify it under
* the terms of the GNU General Public License as published by the Free Software
* Foundation, either version 3 of the License, or (at your option) any later
* version.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
* details.
*
* You should have received a copy of the GNU General Public License along with
* this program. If not, see <http://www.gnu.org/licenses/>.
*/
package com.l2jfrozen.gameserver;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.net.InetAddress;
import java.net.UnknownHostException;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.logging.LogManager;

import org.apache.log4j.Logger;
import org.apache.log4j.PropertyConfigurator;

import com.l2jfrozen.Config;
import com.l2jfrozen.gameserver.thread.ThreadPoolManager;

/*

import java.util.Calendar;
import java.util.logging.Logger;
*/

/**
* This Config for Auto Restart GameServer
* Initialize class getInstance()
* Set Time in Config File
* Thank You L2JServer | L2JRussia
*
* @author L2JRussia
*
*/
public class Restart
{
        //Variaveis globais
        private static Restart _instance = null;
        protected static final Logger _log = Logger.getLogger(Restart.class.getName());
        private Calendar NextRestart;
        private SimpleDateFormat format = new SimpleDateFormat("HH:mm");

        //Singleton
        public static Restart getInstance()
        {
                if(_instance == null)
                        _instance = new Restart();
                return _instance;
        }

        public String getRestartNextTime()
        {
        if(NextRestart.getTime() != null)
                return format.format(NextRestart.getTime());
                else
                        return "Erro";
        }

        //Connstrutor
        private Restart()
        {
      //:D
        }

        public void StartCalculationOfNextRestartTime()
        {
_log.info("########################################");
_log.info("#[Restart System]: System activated... #");
_log.info("########################################");
                try
                {
                        Calendar currentTime = Calendar.getInstance();
                        Calendar testStartTime = null;
                        long flush2 = 0,timeL = 0;
                        int count = 0;

                        for (String timeOfDay : Config.RESTART_INTERVAL_BY_TIME_OF_DAY)
                        {
                                testStartTime = Calendar.getInstance();
                                testStartTime.setLenient(true);
                                String[] splitTimeOfDay = timeOfDay.split(":");
                                testStartTime.set(Calendar.HOUR_OF_DAY, Integer.parseInt(splitTimeOfDay[0]));
                                testStartTime.set(Calendar.MINUTE, Integer.parseInt(splitTimeOfDay[1]));
                                testStartTime.set(Calendar.SECOND, 00);
                                //Verifica a validade to tempo
                                if (testStartTime.getTimeInMillis() < currentTime.getTimeInMillis())
                                {
                                        testStartTime.add(Calendar.DAY_OF_MONTH, 1);
                                }

                                //TimeL Recebe o quanto falta de milisegundos para o restart
                                timeL = testStartTime.getTimeInMillis() - currentTime.getTimeInMillis();

                                //Verifica qual horario sera o proximo restart
                                if(count == 0){
                                flush2 = timeL;
                                NextRestart = testStartTime;
                                }

                                if(timeL <  flush2){
                                flush2 = timeL;
                                NextRestart = testStartTime;
                                }

                                count ++;
                        }
                        _log.info("[AutoRestart]: Next Restart Time: " + NextRestart.getTime().toString());
            ThreadPoolManager.getInstance().scheduleGeneral(new StartRestartTask(), flush2);
                }
                catch (Exception e)
	                {
	                    System.out.println("[AutoRestart]: The restart automated server presented error in load restarts period config !");
	                }
	        }
	
	        class StartRestartTask implements Runnable
	        {
	                public void run()
	                {
	          _log.info("Start automated restart GameServer.");
	          Shutdown.getInstance().autoRestart(Config.RESTART_SECONDS);
	                }
					
	        }
	}

After that modified GameServer.java code: 

	Util.printSection("Restart Manager");
        if(Config.RESTART_BY_TIME_OF_DAY)
                Restart.getInstance().StartCalculationOfNextRestartTime();
        else
                LOGGER.info("# Auto Restart System is Disabled #");
      
        System.gc();

Aaand at last to work config code must be put into l2jfrozen.properties config file in config/functions folder.

All other codes are working perfectly. This is just small fix and Iam writing these codes with little changes.

Link to comment
Share on other sites

  • 3 years later...
49 minutes ago, xrhstos1994 said:

any people have this code for acis pack ?

scripts.xml there is already automatic restart on aCis 

  • Like 1
Link to comment
Share on other sites

  • 1 year 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

    • ENGLISH As you know, we have always profiled in the development of Java emulators, we continue to do our favorite thing, and now we have the opportunity to provide you with services in the field of private development of L2 assemblies Essence, Classic and High Five, which we have been doing in recent years, we have not been working on basic builds for a long time and work only on contracts for the world's best projects. These are the best builds we can offer, we have test servers and we can show them to you on the test, and if you are very good at gameplay, you will see a big difference in the quality and detail of the official content compared to the basic builds. These are the best top solutions in the world, which are currently used to implement the largest projects in the world. We guarantee 100% implementation of all official content. If you have any questions about testing, discussions, etc., please contact our studio and we will discuss everything. At the moment, you can get acquainted with the preliminary information and prices for Private L2 contracts here: Private Server packs L2 Essence 464, 447, 388, 362, 286 protocols Private server packs L2Classic Private server pack High Five РУССКИЙ --------------------------------------------- Как вы знаете мы всегда профилировались на разработке в сфере Java эмуляторов, мы продолжаем заниматься своим любимым делом, и сейчас у нас появилась возможность предоставлять вам услуги в сфере приватных разработок L2 сборок Essence, Classic и High Five, которыми мы занимаемся последние годы, мы уже давно не работаем над базовыми сборками и работаем только на контрактах для лучших мировых проектов. Это лучшие сборки, которые мы можем предложить, у нас есть тестовые сервера, и мы можем показать их вам на тесте, и если вы очень хорошо разбираетесь в игровом процессе, вы увидите большую разницу в качестве и детализации официального контента по сравнению с базовыми сборками. Это лучшие топовые решения в мире, которые на данный момент используются для реализации крупнейших проектов в мире. Мы даем гарантии - 100% реализации всего официального контента. По вопросам тестирования, обсуждений и тд - пишите по контактам нашей студии и мы все обсудим. На данный момент вы можете ознакомиться с предварительной информацией и ценами на Приватные контракты L2 тут: Приватные Сборки L2 Essence 464, 447, 388, 362, 286 protocols Приватные Сборки L2Classic Приватная Сборка High Five -------------------------------------------------------------- Contacts: Telegram: https://t.me/L2scripts Whatsapp, Viber: +1 (916) 226 1910 С уважением, Администрация !
    • I can sell it. If you are interested just pm.
    • Its really not that hard to setup a server on a vps.
    • its AAC features... izi check add new acc here and later go to system folder and find last file with new date... have data.dat in system ? 
  • Topics

×
×
  • Create New...