Jump to content

[1.7.10][1.8] Tick Dynamic - Keep your server running at 20 TPS


Recommended Posts

Tick Dynamic

width=335 height=129http://mods.stjerncraft.com/tickdynamic/media/tickdynamic_1.png[/img]

Tick Dynamic is a Minecraft Forge CoreMod, which will attempt to maintain a server Ticks Per Second at 20. It does this by individually controlling how many Entities and TileEntities update each tick. As the server TPS goes down, the number of Entities and TileEntities that update each tick also goes down, to maintain a high server TPS.


Detailed description:

On a Minecraft server the world will update 20 times a second. This means that the server has 50 milliseconds to go through every active world and update the Entities, TileEntities and other tings like lighting and terrain generation.

Once your server has a lot of players, and large active bases, the server might start having problems updating everything within the given time.

This is especially true on modded server with Chunk loaders, large bases with a lot of TileEntities, and many new Monsters and other Entities.


With Tick Dynamic on your server, you will be able to define how much time each world is allowed to use, and within each world, how much time Entities and TileEntities are allowed to use.

Whenever these limits are hit, Tick Dynamic will limit the number of Entities and/or TileEntities that updates each tick for the given groups.

You essentially have a separate TPS for Entities and TileEntities in each world.


So what do you gain by maintaining a server TPS of 20, by allowing Entities and TileEntitie to update slower?

- Little to no Block lag

- Interact with TileEntities(Chests, Machines etc.) without delays

- Chunk loading and teleporting without long pauses

- No player lag when moving around

- No disconnects due to long ticks

- Generally lower ping and a more responsive server


Note however, that Tick Dynamic will not help for every case, certain events will still cause the TPS to drop, or cause noticeable lag.

Some examples for this is:

- World Generation taking a significant amount of time of a tick.

- Rapid change in time usage for a world

- One mod, or a combination of mobs, using a large amount of time on a single operation during a tick.

- World backup

However, Tick Dynamic should be able to smooth out the spikes by quite a bit.


Tick Dynamic allows a lot of control in how it will maintain that 20 TPS.

If you would have Entities run at a full 20 TPS, but you don't care about TileEntities, you can provide a larger slice of time for Entities.

If you want to give Overworld more time, you can also give it a larger slice of time than the other worlds.

Check out the Help section for full overview of the configuration options, commands and installation instructions.


Example use cases:

Default config

Just dropping Tick Dynamic into a server that is struggling with TPS due to a large amount of Entities and/or TileEntities, will in most cases help the server TPS get up to a constant 20TPS.

By default Tick Dynamic will allocate the time evenly. So if you have Overworld, The End and Nether, each world will be given ~16,66 ms.

Then within each world, Entities and TileEntities will be given ~8,33 ms to run their updates.

If either Entities or TileEntities use more than their given time, it will limit the number of updates to fit within the given time automatically.


Please note however, that if any group is not using all the time provided to it, that time will be available for other groups.

So if a world is heavy on Entities, but have few TileEntities, then more time will automatically be given to Entities.

Same for worlds, If a world uses a lot of time, and two others do not, then the active world will be given more time.


Mining/Spawner World

On many modded servers you have assigned worlds/dimensions for running machines like Quarries, as they make the world look "ugly" with a lot of holes around.

Using Tick Dynamic you have an additional reason to use specific worlds for things.

For a mining world, you can specify that the world is to be given a lower slice of time, thus at peak times when a lot of players are on, the Machines and Entities in this world will start running at a lower tickrate, before worlds like the Overworld.

Likewise, you can assign a world for Mob Spawners and Mob Farms, and give Entities a lower slice of time, without affecting the mobs in the Overworld or The End.


Planned further development:

- Per Chunk timing and limit

Instead of slowing down TileEntities or Entities globally in world, locally slow down the Entities and/or TileEntities that are using a lot of time in a chunk.


- Per user timing and limit

You know that user that seems to just live on your server, and builds large, complex and CPU intensive builds.

With this feature you will be able to set a limit on just that players Entities and TileEntities.

This feature is a bit into the future tho, as some changes are required for it to work.


The mod is currently a Minecraft Forge CoreMod, and is built for Minecraft 1.7.10, Cauldron 1.7.10 and Minecraft 1.8.

Download & Documentation: http://mods.stjerncraft.com/tickdynamic/


If you have any questions or problems, you can post them here, or on our GitHub Repository( https://github.com/wildex999/tickdynamic/issues ), and I will try to answer them =)

Link to comment
Share on other sites

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.

Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  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.


  • Create New...

Important Information

By using this site, you agree to our Terms of Use.