Mirror/README.md

74 lines
5.4 KiB
Markdown
Raw Normal View History

2020-01-14 10:45:52 +00:00
![Mirror Logo](https://i.imgur.com/ikP9eYs.png)
2018-09-25 11:37:56 +00:00
2020-01-18 22:00:50 +00:00
[![Download](https://img.shields.io/badge/asset_store-brightgreen.svg)](https://assetstore.unity.com/packages/tools/network/mirror-129321)
2019-09-25 03:42:02 +00:00
[![Documentation](https://img.shields.io/badge/documentation-brightgreen.svg)](https://mirror-networking.com/docs)
2019-11-28 15:24:12 +00:00
[![Video Tutorial](https://img.shields.io/badge/video_tutorial-brightgreen.svg)](https://www.youtube.com/playlist?list=PLkx8oFug638oBYF5EOwsSS-gOVBXj1dkP)
2018-11-13 19:55:15 +00:00
[![Forum](https://img.shields.io/badge/forum-brightgreen.svg)](https://forum.unity.com/threads/mirror-networking-for-unity-aka-hlapi-community-edition.425437/)
[![Build status](https://img.shields.io/appveyor/ci/vis2k73562/hlapi-community-edition/Mirror.svg)](https://ci.appveyor.com/project/vis2k73562/hlapi-community-edition/branch/mirror)
2020-03-01 16:42:38 +00:00
[![Coverage](https://sonarcloud.io/api/project_badges/measure?project=vis2k_Mirror&metric=coverage)](https://sonarcloud.io/dashboard?id=vis2k_Mirror)
2018-08-04 13:03:53 +00:00
[![Discord](https://img.shields.io/discord/343440455738064897.svg)](https://discordapp.com/invite/N9QVxbM)
[![release](https://img.shields.io/github/release/vis2k/Mirror.svg)](https://github.com/vis2k/Mirror/releases/latest)
2020-03-01 16:42:38 +00:00
2018-08-28 10:43:21 +00:00
Mirror is a **high level** Networking API for Unity, built on top of the **low level** [Telepathy](https://github.com/vis2k/Telepathy) library.
2019-09-22 03:43:06 +00:00
Mirror is built [and tested](https://www.youtube.com/watch?v=mDCNff1S9ZU) for **MMO Scale** Networking by the developers of [uMMORPG](https://assetstore.unity.com/packages/templates/systems/ummorpg-51212), [uSurvival](https://assetstore.unity.com/packages/templates/systems/usurvival-95015) and [Cubica](https://cubica.net).
2019-05-14 11:45:56 +00:00
Mirror is optimized for **ease of use** and **probability of success**. Projects that use Mirror are small, concise and maintainable. uMMORPG was possible with <6000 lines of code. We needed a networking library that allows us to [launch our games](https://mirror-networking.com/showcase/), period.
2018-08-28 10:43:21 +00:00
With Mirror, the **Server & Client are ONE** project _(hence the name)_. Instead of having one code base for the server and one for the client, we simply use the same code for both of them.
2018-08-28 13:29:31 +00:00
* `[Server]` / `[Client]` tags can be used for the server-only and client-only parts.
2020-06-02 14:42:50 +00:00
* `[Command]`'s are used for Client->Server, and `[ClientRpc]` / `[TargetRpc]` for Server->Client communication.
* `[SyncVar]`'s and `SyncList`'s are used to automatically synchronize state.
2018-08-28 13:27:31 +00:00
What previously required **10.000** lines of code, now takes **1.000** lines of code. Therein lies the **magic of Mirror**.
2018-08-28 10:43:21 +00:00
_Note: Mirror is based on Unity's abandoned UNET Networking system. We fixed it up and pushed it to MMO Scale._
2018-10-08 15:11:50 +00:00
## Documentation
2019-09-25 03:42:02 +00:00
Check out our [Documentation](https://mirror-networking.com/docs/).
2019-03-16 09:38:43 +00:00
2019-09-25 03:42:02 +00:00
If you are migrating from UNET, then please check out our [Migration Guide](https://mirror-networking.com/docs/General/Migration.html). Don't panic, it's very easy and won't take more than 5 minutes.
## Installation
2019-09-22 03:43:06 +00:00
We **recommend** to download the most **stable Mirror version** from the [Asset Store](https://assetstore.unity.com/packages/tools/network/mirror-129321)!
2019-03-16 09:45:40 +00:00
For the latest improvements, [Download Mirror](https://github.com/vis2k/Mirror/releases) directly from this repository and extract it in your Assets folder.
2019-03-16 09:40:26 +00:00
## Examples
We included several smaller example projects in Mirror.
2020-04-02 08:43:43 +00:00
For a fully polished, complete project example, consider [uMMORPG](https://assetstore.unity.com/packages/templates/systems/ummorpg-components-edition-159401) or [uSurvival](https://assetstore.unity.com/packages/templates/systems/usurvival-95015).
2019-03-16 09:48:59 +00:00
## Transports
2019-03-16 09:48:48 +00:00
Mirror supports many different low level networking transports:
* (built in) https://github.com/vis2k/Telepathy (Telepathy)
* (built in) Unity's LLAPI
2019-03-16 09:49:44 +00:00
* (built in) https://github.com/ninjasource/Ninja.WebSockets (Websockets)
2019-12-31 09:40:47 +00:00
* https://mirror-networking.com/apathy/ (Apathy)
2019-03-16 09:48:48 +00:00
* https://github.com/Raystorms/FizzySteamyMirror/ (SteamNetwork)
2018-11-09 14:50:35 +00:00
* https://github.com/SoftwareGuy/Ignorance/ (ENet)
2019-03-16 09:48:48 +00:00
* https://github.com/MichalPetryka/LiteNetLib4Mirror (LiteNetLib)
2018-11-09 14:50:35 +00:00
2019-03-16 09:50:57 +00:00
## Donations & Priority Support
2019-12-24 12:33:31 +00:00
Please support [Mirror on GitHub](https://github.com/sponsors/vis2k). Priority support included!
2018-10-08 15:11:50 +00:00
## Benchmarks
2018-08-28 10:43:21 +00:00
* Telepathy [1000 connections](https://github.com/vis2k/Telepathy) test
2019-02-17 18:12:40 +00:00
* [uMMORPG 480 CCU worst case test](https://youtu.be/mDCNff1S9ZU) (everyone broadcasting to everyone else)
2018-08-28 10:43:21 +00:00
* [uSurvival 122 CCU worst case test](https://docs.google.com/document/d/e/2PACX-1vT28FcGXYlbG8gwi8DhD914n7K-wCAE8qhfetPkSli96ikc1Td3zJO1IiwVhfPVtKUHF0l3N7ZkM5GU/pub#h.pwbvffnwcewe)
2019-03-16 10:03:03 +00:00
## The Mirror Mantra
2019-03-16 10:25:45 +00:00
> _“Would you tell me, please, which way I ought to go from here?”_<br/>
> _“That depends a good deal on where you want to get to,"_ said the Cat.<br/>
> _"I dont much care where—“_ said Alice.<br/>
> _“Then it doesnt matter which way you go,”_ said the Cat.<br/>
2019-03-16 10:26:57 +00:00
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;- Alice in Wonderland _(Lewis Carroll)_
As Indie Developers, **our #1 goal** for Mirror is **Ease of Use**.
2018-06-07 13:40:15 +00:00
2019-03-16 10:23:25 +00:00
If you want to contribute, always follow the [KISS](https://en.wikipedia.org/wiki/KISS_principle) principle. Everything needs to be **as simple as possible**. As result, the code will be stable, easy to understand, easy to modify and easy to maintain 5 years from now when our games are still running.
2019-03-16 10:03:03 +00:00
2019-03-16 21:11:15 +00:00
Pull Requests for bug fixes are always highly appreciated. New features will be considered very carefully and will only be merged if they are the most simple solution to the given problem.