Add cloud hosting instructions, updated Dockerfile
@ -21,6 +21,10 @@ This tool aims to allow multiple users to work on the same scene over the networ
|
|||||||
|
|
||||||
See the [documentation](https://multi-user.readthedocs.io/en/latest/) for details.
|
See the [documentation](https://multi-user.readthedocs.io/en/latest/) for details.
|
||||||
|
|
||||||
|
## Troubleshooting
|
||||||
|
|
||||||
|
See the [troubleshooting guide](https://multi-user.readthedocs.io/en/latest/getting_started/troubleshooting.html) for tips on the most common issues.
|
||||||
|
|
||||||
## Current development status
|
## Current development status
|
||||||
|
|
||||||
Currently, not all data-block are supported for replication over the wire. The following list summarizes the status for each ones.
|
Currently, not all data-block are supported for replication over the wire. The following list summarizes the status for each ones.
|
||||||
|
@ -19,7 +19,7 @@ import sys
|
|||||||
|
|
||||||
project = 'multi-user'
|
project = 'multi-user'
|
||||||
copyright = '2020, Swann Martinez'
|
copyright = '2020, Swann Martinez'
|
||||||
author = 'Swann Martinez'
|
author = 'Swann Martinez, with contributions from Poochy'
|
||||||
|
|
||||||
# The full version, including alpha/beta/rc tags
|
# The full version, including alpha/beta/rc tags
|
||||||
release = '0.1.0'
|
release = '0.1.0'
|
||||||
|
@ -8,4 +8,5 @@ Getting started
|
|||||||
|
|
||||||
install
|
install
|
||||||
quickstart
|
quickstart
|
||||||
|
troubleshooting
|
||||||
glossary
|
glossary
|
||||||
|
@ -5,10 +5,10 @@ Quick start
|
|||||||
===========
|
===========
|
||||||
|
|
||||||
.. hint::
|
.. hint::
|
||||||
*All session related settings are located under: `View3D -> Sidebar -> Multiuser panel`*
|
*All session-related settings are located under: `View3D -> Sidebar -> Multiuser panel`*
|
||||||
|
|
||||||
The multi-user is based on a session management system.
|
The multi-user addon provides a session management system.
|
||||||
In this this guide you will quickly learn how to use the collaborative session system in three part:
|
In this guide, you will quickly learn how to use the collaborative session management system in three parts:
|
||||||
|
|
||||||
- :ref:`how-to-host`
|
- :ref:`how-to-host`
|
||||||
- :ref:`how-to-join`
|
- :ref:`how-to-join`
|
||||||
@ -19,22 +19,22 @@ In this this guide you will quickly learn how to use the collaborative session s
|
|||||||
How to host a session
|
How to host a session
|
||||||
=====================
|
=====================
|
||||||
|
|
||||||
The multi-user add-on rely on a Client-Server architecture.
|
The multi-user add-on relies on a Client-Server architecture.
|
||||||
The server is the heart of the collaborative session,
|
The server is the heart of the collaborative session.
|
||||||
it will allow each users to communicate with each others.
|
It is what allows user's blender instances to communicate with each other.
|
||||||
In simple terms, *Hosting a session* means *run a local server and connect the local client to it*.
|
In simple terms, *Hosting a session* means *run a local server and connect the local client to it*.
|
||||||
When I said **local server** I mean accessible from the LAN (Local Area Network).
|
When I say **local server** I mean a server which is accessible from the LAN (Local Area Network) without requiring an internet connection.
|
||||||
|
|
||||||
However sometime you will need to host a session over the internet,
|
However, there are times when you will need to host a session over the internet.
|
||||||
in this case I strongly recommand you to read the :ref:`internet-guide` tutorial.
|
In this case, I strongly recommend that you read the :ref:`internet-guide` tutorial.
|
||||||
|
|
||||||
.. _user-info:
|
.. _user-info:
|
||||||
|
|
||||||
-----------------------------
|
--------------------------------
|
||||||
1. Fill your user information
|
1. Fill in your user information
|
||||||
-----------------------------
|
--------------------------------
|
||||||
|
|
||||||
The **User Info** panel (See image below) allow you to constomize your online identity.
|
The **User Info** panel (See image below) allows you to customise your online identity.
|
||||||
|
|
||||||
.. figure:: img/quickstart_user_info.png
|
.. figure:: img/quickstart_user_info.png
|
||||||
:align: center
|
:align: center
|
||||||
@ -42,38 +42,38 @@ The **User Info** panel (See image below) allow you to constomize your online id
|
|||||||
User info panel
|
User info panel
|
||||||
|
|
||||||
|
|
||||||
Let's fill those tow field:
|
Let's fill those two fields:
|
||||||
|
|
||||||
- **name**: your online name.
|
- **name**: your online name.
|
||||||
- **color**: a color used to represent you into other user workspace(see image below).
|
- **color**: a color used to represent you in other user's workspaces(see image below).
|
||||||
|
|
||||||
|
|
||||||
During online sessions, other users will see your selected object and camera hilghlited in your profile color.
|
During online sessions, other users will see your selected object and camera highlighted in your profile color.
|
||||||
|
|
||||||
.. _user-representation:
|
.. _user-representation:
|
||||||
|
|
||||||
.. figure:: img/quickstart_user_representation.png
|
.. figure:: img/quickstart_user_representation.png
|
||||||
:align: center
|
:align: center
|
||||||
|
|
||||||
User viewport representation
|
User viewport representation aka 'User Presence'
|
||||||
|
|
||||||
--------------------
|
---------------------
|
||||||
2. Set up the network
|
2. Set up the network
|
||||||
--------------------
|
---------------------
|
||||||
|
|
||||||
When the hosting process will start, the multi-user addon will lauch a local server instance.
|
When the hosting process starts, the multi-user addon will launch a local server instance.
|
||||||
In the nerwork panel select **HOST**.
|
In the network panel, select **HOST**.
|
||||||
The **Host sub-panel** (see image below) allow you to configure the server according to:
|
The **Host sub-panel** (see image below) allows you to configure the server according to:
|
||||||
|
|
||||||
* **Port**: Port on wich the server is listening.
|
* **Port**: Port on which the server is listening.
|
||||||
* **Start from**: The session initialisation method.
|
* **Start from**: The session initialisation method.
|
||||||
|
|
||||||
* **current scenes**: Start with the current blendfile datas.
|
* **current scenes**: Start with the data loaded in the current blend file.
|
||||||
* **an empty scene**: Clear a data and start over.
|
* **an empty scene**: Clear the blend file's data and start over.
|
||||||
|
|
||||||
.. danger::
|
.. danger::
|
||||||
By starting from an empty, all of the blend data will be removed !
|
By starting from an empty scene, all of the blend data will be removed!
|
||||||
Ensure to save your existing work before launching the session.
|
Be sure to save your existing work before launching the session.
|
||||||
|
|
||||||
* **Admin password**: The session administration password.
|
* **Admin password**: The session administration password.
|
||||||
|
|
||||||
@ -84,16 +84,16 @@ The **Host sub-panel** (see image below) allow you to configure the server accor
|
|||||||
Host network panel
|
Host network panel
|
||||||
|
|
||||||
|
|
||||||
.. note:: Additionnal configuration setting can be found in the :ref:`advanced` section.
|
.. note:: Additional configuration setting can be found in the :ref:`advanced` section.
|
||||||
|
|
||||||
Once everything is setup you can hit the **HOST** button to launch the session !
|
Once everything is set up, you can hit the **HOST** button to launch the session!
|
||||||
|
|
||||||
It will do two things:
|
This will do two things:
|
||||||
|
|
||||||
* Start a local server
|
* Start a local server
|
||||||
* Connect you to it as an :ref:`admin`
|
* Connect you to it as an :ref:`admin`
|
||||||
|
|
||||||
During online session, various actions are available to you, go to :ref:`how-to-manage` section to
|
During an online session, various actions are available to you, go to :ref:`how-to-manage` section to
|
||||||
learn more about them.
|
learn more about them.
|
||||||
|
|
||||||
.. _how-to-join:
|
.. _how-to-join:
|
||||||
@ -101,12 +101,12 @@ learn more about them.
|
|||||||
How to join a session
|
How to join a session
|
||||||
=====================
|
=====================
|
||||||
|
|
||||||
This section describe how join a launched session.
|
This section describes how join a launched session.
|
||||||
Before starting make sure that you have access to the session ip and port.
|
Before starting make sure that you have access to the session IP address and port number.
|
||||||
|
|
||||||
-----------------------------
|
--------------------------------
|
||||||
1. Fill your user information
|
1. Fill in your user information
|
||||||
-----------------------------
|
--------------------------------
|
||||||
|
|
||||||
Follow the user-info_ section for this step.
|
Follow the user-info_ section for this step.
|
||||||
|
|
||||||
@ -114,9 +114,9 @@ Follow the user-info_ section for this step.
|
|||||||
2. Network setup
|
2. Network setup
|
||||||
----------------
|
----------------
|
||||||
|
|
||||||
In the nerwork panel select **JOIN**.
|
In the network panel, select **JOIN**.
|
||||||
The **join sub-panel** (see image below) allow you configure the client to join a
|
The **join sub-panel** (see image below) allows you to configure your client to join a
|
||||||
collaborative session.
|
collaborative session which is already hosted.
|
||||||
|
|
||||||
.. figure:: img/quickstart_join.png
|
.. figure:: img/quickstart_join.png
|
||||||
:align: center
|
:align: center
|
||||||
@ -124,32 +124,32 @@ collaborative session.
|
|||||||
|
|
||||||
Connection panel
|
Connection panel
|
||||||
|
|
||||||
Fill those field with your information:
|
Fill in the fields with your information:
|
||||||
|
|
||||||
- **IP**: the host ip.
|
- **IP**: the host's IP address.
|
||||||
- **Port**: the host port.
|
- **Port**: the host's port number.
|
||||||
- **Connect as admin**: connect you with **admin rights** (see :ref:`admin` ) to the session.
|
- **Connect as admin**: connect yourself with **admin rights** (see :ref:`admin` ) to the session.
|
||||||
|
|
||||||
.. Maybe something more explicit here
|
.. Maybe something more explicit here
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
Additionnal configuration setting can be found in the :ref:`advanced` section.
|
Additional configuration settings can be found in the :ref:`advanced` section.
|
||||||
|
|
||||||
Once you've set every field, hit the button **CONNECT** to join the session !
|
Once you've configured every field, hit the button **CONNECT** to join the session !
|
||||||
When the :ref:`session-status` is **ONLINE** you are online and ready to start to collaborate.
|
When the :ref:`session-status` is **ONLINE** you are online and ready to start co-creating.
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
On the **dedicated server** startup, the session status will get you to the **LOBBY** waiting a admin to start it.
|
When starting a **dedicated server**, the session status screen will take you to the **LOBBY**, awaiting an admin to start the session.
|
||||||
|
|
||||||
If the session status is set to **LOBBY** and you are a regular user, you need to wait that an admin launch it.
|
If the session status is set to **LOBBY** and you are a regular user, you need to wait for the admin to launch the scene.
|
||||||
If you are the admin, you just need to init the repository to start the session (see image below).
|
If you are the admin, you just need to initialise the repository to start the session (see image below).
|
||||||
|
|
||||||
.. figure:: img/quickstart_session_init.png
|
.. figure:: img/quickstart_session_init.png
|
||||||
:align: center
|
:align: center
|
||||||
|
|
||||||
Session initialisation for dedicated server
|
Session initialisation for dedicated server
|
||||||
|
|
||||||
During online session, various actions are available to you, go to :ref:`how-to-manage` section to
|
During an online session, various actions are available to you. Go to :ref:`how-to-manage` to
|
||||||
learn more about them.
|
learn more about them.
|
||||||
|
|
||||||
.. _how-to-manage:
|
.. _how-to-manage:
|
||||||
@ -157,17 +157,17 @@ learn more about them.
|
|||||||
How to manage a session
|
How to manage a session
|
||||||
=======================
|
=======================
|
||||||
|
|
||||||
The collaboration quality directly depend on the communication quality. This section describes
|
The quality of a collaborative session directly depends on the quality of the network connection, and the communication between the users. This section describes
|
||||||
various tools made in an effort to ease the communication between the different session users.
|
various tools which have been made in an effort to ease the communication between your fellow creators.
|
||||||
Feel free to suggest any idea for communication tools `here <https://gitlab.com/slumber/multi-user/-/issues/75>`_ .
|
Feel free to suggest any ideas for communication tools `here <https://gitlab.com/slumber/multi-user/-/issues/75>`_ .
|
||||||
|
|
||||||
---------------------------
|
---------------------------
|
||||||
Change replication behavior
|
Change replication behavior
|
||||||
---------------------------
|
---------------------------
|
||||||
|
|
||||||
During a session, the multi-user will replicate your modifications to other instances.
|
During a session, multi-user will replicate all of your local modifications to the scene, to all other users' blender instances.
|
||||||
In order to avoid annoying other users when you are experimenting, some of those modifications can be ignored via
|
In order to avoid annoying other users when you are experimenting, you can flag some of your local modifications to be ignored via
|
||||||
various flags present at the top of the panel (see red area in the image bellow). Those flags are explained in the :ref:`replication` section.
|
various flags present at the top of the panel (see red area in the image below). Those flags are explained in the :ref:`replication` section.
|
||||||
|
|
||||||
.. figure:: img/quickstart_replication.png
|
.. figure:: img/quickstart_replication.png
|
||||||
:align: center
|
:align: center
|
||||||
@ -178,32 +178,31 @@ various flags present at the top of the panel (see red area in the image bellow)
|
|||||||
Monitor online users
|
Monitor online users
|
||||||
--------------------
|
--------------------
|
||||||
|
|
||||||
One of the most vital tool is the **Online user panel**. It list all connected
|
One of the most vital tools is the **Online user panel**. It lists all connected
|
||||||
users information's including yours such as :
|
users' information including your own:
|
||||||
|
|
||||||
* **Role** : if user is an admin or a regular user.
|
* **Role** : if a user is an admin or a regular user.
|
||||||
* **Location**: Where the user is actually working.
|
* **Location**: Where the user is actually working.
|
||||||
* **Frame**: When (in frame) the user working.
|
* **Frame**: When (on which frame) the user is working.
|
||||||
* **Ping**: user connection delay in milliseconds
|
* **Ping**: user's connection delay in milliseconds
|
||||||
|
|
||||||
.. figure:: img/quickstart_users.png
|
.. figure:: img/quickstart_users.png
|
||||||
:align: center
|
:align: center
|
||||||
|
|
||||||
Online user panel
|
Online user panel
|
||||||
|
|
||||||
By selecting a user in the list you'll have access to different user related **actions**.
|
By selecting a user in the list you'll have access to different users' related **actions**.
|
||||||
Those operators allow you reach the selected user state in tow different dimensions: **SPACE** and **TIME**.
|
Those operators allow you to experience the selected user's state in two different dimensions: **SPACE** and **TIME**.
|
||||||
|
|
||||||
Snapping in space
|
Snapping in space
|
||||||
----------------
|
-----------------
|
||||||
|
|
||||||
The **CAMERA button** (Also called **snap view** operator) allow you to snap on
|
The **CAMERA button** (Also called **snap view** operator) allow you to snap to
|
||||||
the user viewpoint. To disable the snap, click back on the button. This action
|
the user's viewpoint. To disable the snap, click on the button once again. This action
|
||||||
served different purposes such as easing the review process, working together on
|
serves different purposes such as easing the review process, and working together on a large or populated world.
|
||||||
wide world.
|
|
||||||
|
|
||||||
.. hint::
|
.. hint::
|
||||||
If the target user is localized on another scene, the **snap view** operator will send you to his scene.
|
If the target user is located in another scene, the **snap view** operator will send you to their scene.
|
||||||
|
|
||||||
.. figure:: img/quickstart_snap_view.gif
|
.. figure:: img/quickstart_snap_view.gif
|
||||||
:align: center
|
:align: center
|
||||||
@ -211,11 +210,11 @@ wide world.
|
|||||||
Snap view in action
|
Snap view in action
|
||||||
|
|
||||||
Snapping in time
|
Snapping in time
|
||||||
---------------
|
----------------
|
||||||
|
|
||||||
The **CLOCK button** (Also called **snap time** operator) allow you to snap on
|
The **CLOCK button** (Also called **snap time** operator) allows you to snap to
|
||||||
the user time (current frame). To disable the snap, click back on the button.
|
the user's time (current frame). To disable the snap, click on the button once again.
|
||||||
This action is built to help various actors to work on the same temporality
|
This action helps various multiple creators to work in the same time-frame
|
||||||
(for instance multiple animators).
|
(for instance multiple animators).
|
||||||
|
|
||||||
.. figure:: img/quickstart_snap_time.gif
|
.. figure:: img/quickstart_snap_time.gif
|
||||||
@ -230,14 +229,14 @@ Kick a user
|
|||||||
.. warning:: Only available for :ref:`admin` !
|
.. warning:: Only available for :ref:`admin` !
|
||||||
|
|
||||||
|
|
||||||
The **CROSS button** (Also called **kick** operator) allow the admin to kick the selected user. On the target user side, the session will properly disconnect.
|
The **CROSS button** (Also called **kick** operator) allows the administrator to kick the selected user. This can be helpful if a user is acting unruly, but more importantly, if they are experiencing a high ping which is slowing down the scene. Meanwhile, in the target user's world, the session will properly disconnect.
|
||||||
|
|
||||||
|
|
||||||
Change users display
|
Change users display
|
||||||
--------------------
|
--------------------
|
||||||
|
|
||||||
Presence is the multi-user module responsible for users display. During the session,
|
Presence is the multi-user module responsible for displaying user presence. During the session,
|
||||||
it draw users related information in your viewport such as:
|
it draw users' related information in your viewport such as:
|
||||||
|
|
||||||
* Username
|
* Username
|
||||||
* User point of view
|
* User point of view
|
||||||
@ -248,10 +247,10 @@ it draw users related information in your viewport such as:
|
|||||||
|
|
||||||
Presence show flags
|
Presence show flags
|
||||||
|
|
||||||
The presence overlay panel (see image above) allow you to enable/disable
|
The presence overlay panel (see image above) allows you to enable/disable
|
||||||
various drawn parts via the following flags:
|
various drawn parts via the following flags:
|
||||||
|
|
||||||
- **Show session statut**: display the session status in the viewport
|
- **Show session status**: display the session status in the viewport
|
||||||
|
|
||||||
.. figure:: img/quickstart_status.png
|
.. figure:: img/quickstart_status.png
|
||||||
:align: center
|
:align: center
|
||||||
@ -259,8 +258,8 @@ various drawn parts via the following flags:
|
|||||||
- **Text scale**: session status text size
|
- **Text scale**: session status text size
|
||||||
- **Vertical/Horizontal position**: session position in the viewport
|
- **Vertical/Horizontal position**: session position in the viewport
|
||||||
|
|
||||||
- **Show selected objects**: display other users current selection
|
- **Show selected objects**: display other users' current selections
|
||||||
- **Show users**: display users current viewpoint
|
- **Show users**: display users' current viewpoint
|
||||||
- **Show different scenes**: display users working on other scenes
|
- **Show different scenes**: display users working on other scenes
|
||||||
|
|
||||||
|
|
||||||
@ -269,40 +268,40 @@ various drawn parts via the following flags:
|
|||||||
Manage data
|
Manage data
|
||||||
-----------
|
-----------
|
||||||
|
|
||||||
In order to understand replication data managment, a quick introduction to the multi-user data workflow is required.
|
In order to understand replication data managment, a quick introduction to the multi-user data workflow is in order.
|
||||||
First thing to know: until now, the addon rely on a data-based replication. In simple words, it means that it replicate
|
The first thing to know: until now, the addon relies on data-based replication. In simple words, it means that it replicates
|
||||||
user's action results.
|
the resultant output of a user's actions.
|
||||||
To replicate datablocks between clients the multi-user rely on what tends to be a distributed architecture:
|
To replicate datablocks between clients, multi-user relies on a standard distributed architecture:
|
||||||
|
|
||||||
- The server store the "master" version of the work.
|
- The server stores the "master" version of the work.
|
||||||
- Each client have a local version of the work.
|
- Each client has a local version of the work.
|
||||||
|
|
||||||
When an artist modified something in the scene, here is what is happening in the background:
|
When an artist modifies something in the scene, here is what is happening in the background:
|
||||||
|
|
||||||
1. Modified data are **COMMITTED** to the local repository.
|
1. Modified data are **COMMITTED** to the local repository.
|
||||||
2. Once committed locally, they are **PUSHED** to the server
|
2. Once committed locally, they are **PUSHED** to the server
|
||||||
3. As soon as the server is getting updates, they are stored locally and pushed to every other clients
|
3. As soon as the server receives updates, they are stored locally and pushed to every other client
|
||||||
|
|
||||||
At the top of this data management system, a right management system prevent
|
At the top of this data management system, a rights management system prevents
|
||||||
multiple users from modifying same data at same time. A datablock may belong to
|
multiple users from modifying the same data at the same time. A datablock may belong to
|
||||||
a connected user or be under :ref:`common-right<**COMMON**>` rights.
|
a connected user or be under :ref:`common-right<**COMMON**>` rights.
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
In a near future, the right management system will support roles to allow multiple users to
|
In a near future, the rights management system will support roles to allow multiple users to
|
||||||
work on different aspect of the same datablock.
|
work on different aspects of the same datablock.
|
||||||
|
|
||||||
The Repository panel (see image below) allow you to monitor, change datablock states and right manually.
|
The Repository panel (see image below) allows you to monitor, change datablock states and rights manually.
|
||||||
|
|
||||||
.. figure:: img/quickstart_properties.png
|
.. figure:: img/quickstart_properties.png
|
||||||
:align: center
|
:align: center
|
||||||
|
|
||||||
Repository panel
|
Repository panel
|
||||||
|
|
||||||
The **show only owned** flag allow you to see which datablocks you are currently modifying.
|
The **show only owned** flag allows you to see which datablocks you are currently modifying.
|
||||||
|
|
||||||
.. warning::
|
.. warning::
|
||||||
If you are editing a datablock not listed with this fag enabled, it means that you do
|
If you are editing a datablock not listed with this flag enabled, it means that you have not been granted the rights to modify it.
|
||||||
not have right granted to modify it. So it won't be updated to other client !
|
So, it won't be updated to other clients!
|
||||||
|
|
||||||
Here is a quick list of available actions:
|
Here is a quick list of available actions:
|
||||||
|
|
||||||
@ -342,12 +341,12 @@ Network
|
|||||||
Advanced network settings
|
Advanced network settings
|
||||||
|
|
||||||
**IPC Port** is the port used for Inter Process Communication. This port is used
|
**IPC Port** is the port used for Inter Process Communication. This port is used
|
||||||
by the multi-users subprocesses to communicate with each others. If different instances
|
by the multi-user subprocesses to communicate with each other. If different instances
|
||||||
of the multi-user are using the same IPC port it will create conflict !
|
of multi-user are using the same IPC port, this will create conflict !
|
||||||
|
|
||||||
.. note::
|
.. note::
|
||||||
You only need to modify it if you need to launch multiple clients from the same
|
You only need to modify this setting if you need to launch multiple clients from the same
|
||||||
computer(or if you try to host and join on the same computer). You should just enter a different
|
computer (or if you try to host and join from the same computer). To resolve this, you simply need to enter a different
|
||||||
**IPC port** for each blender instance.
|
**IPC port** for each blender instance.
|
||||||
|
|
||||||
**Timeout (in milliseconds)** is the maximum ping authorized before auto-disconnecting.
|
**Timeout (in milliseconds)** is the maximum ping authorized before auto-disconnecting.
|
||||||
@ -364,20 +363,20 @@ Replication
|
|||||||
|
|
||||||
Advanced replication settings
|
Advanced replication settings
|
||||||
|
|
||||||
**Synchronize render settings** (only host) enable replication of EEVEE and CYCLES render settings to match render between clients.
|
**Synchronize render settings** (only host) enable replication of EEVEE and CYCLES render settings to match renders between clients.
|
||||||
|
|
||||||
**Synchronize active camera** sync the scene active camera.
|
**Synchronize active camera** sync the scene's active camera.
|
||||||
|
|
||||||
**Edit Mode Updates** enable objects update while you are in Edit_Mode.
|
**Edit Mode Updates** enable objects to update while you are in Edit_Mode.
|
||||||
|
|
||||||
.. warning:: Edit Mode Updates kill performances with complex objects (heavy meshes, gpencil, etc...).
|
.. warning:: Edit Mode Updates kills the session's performance with complex objects (heavy meshes, gpencil, etc...).
|
||||||
|
|
||||||
**Update method** allow you to change how replication update are triggered. Until now two update methode are implemented:
|
**Update method** allows you to change how replication updates are triggered. Until now, two update methods are implemented:
|
||||||
|
|
||||||
- **Default**: Use external threads to monitor datablocks changes, slower and less accurate.
|
- **Default**: Use external threads to monitor datablocks changes. Slower and less accurate.
|
||||||
- **Despgraph ⚠️**: Use the blender dependency graph to trigger updates. Faster but experimental and unstable !
|
- **Despgraph ⚠️**: Use the blender dependency graph to trigger updates. Faster but experimental and unstable !
|
||||||
|
|
||||||
**Properties frequency gird** allow to set a custom replication frequency for each type of data-block:
|
**Properties frequency grid** set a custom replication frequency for each type of data-block:
|
||||||
|
|
||||||
- **Refresh**: pushed data update rate (in second)
|
- **Refresh**: pushed data update rate (in second)
|
||||||
- **Apply**: pulled data update rate (in second)
|
- **Apply**: pulled data update rate (in second)
|
||||||
@ -386,21 +385,21 @@ Replication
|
|||||||
Cache
|
Cache
|
||||||
-----
|
-----
|
||||||
|
|
||||||
The multi-user allows to replicate external blend dependencies such as images, movies sounds.
|
Multi-user allows you to replicate external dependencies such as images (textures, hdris, etc...), movies, and sounds.
|
||||||
On each client, those files are stored into the cache folder.
|
On each client, the files will be stored in the multi-user cache folder.
|
||||||
|
|
||||||
.. figure:: img/quickstart_advanced_cache.png
|
.. figure:: img/quickstart_advanced_cache.png
|
||||||
:align: center
|
:align: center
|
||||||
|
|
||||||
Advanced cache settings
|
Advanced cache settings
|
||||||
|
|
||||||
**cache_directory** allows to choose where cached files (images, sound, movies) will be saved.
|
**cache_directory** choose where cached files (images, sound, movies) will be saved.
|
||||||
|
|
||||||
**Clear memory filecache** will save memory space at runtime by removing the file content from memory as soon as it have been written to the disk.
|
**Clear memory filecache** will save memory space at runtime by removing the file content from memory as soon as it has been written to the disk.
|
||||||
|
|
||||||
**Clear cache** will remove all file from the cache folder.
|
**Clear cache** will remove all files from the cache folder.
|
||||||
|
|
||||||
.. warning:: Clear cash could break your scene image/movie/sound if they are used into the blend !
|
.. warning:: Clearing the cache could break your scene images/movies/sounds if they are used in a blend file! Try saving the blend file and choosing 'Pack all into blend' before clearing the cache.
|
||||||
|
|
||||||
---
|
---
|
||||||
Log
|
Log
|
||||||
@ -411,16 +410,16 @@ Log
|
|||||||
|
|
||||||
Advanced log settings
|
Advanced log settings
|
||||||
|
|
||||||
**log level** allow to set the logging level of detail. Here is the detail for each values:
|
**log level** allows you to set the level of detail captured in multi-user's logging output. Here is a brief description on the level of detail for each value of the logging parameter:
|
||||||
|
|
||||||
+-----------+-----------------------------------------------+
|
+-----------+-----------------------------------------------+
|
||||||
| Log level | Description |
|
| Log level | Description |
|
||||||
+===========+===============================================+
|
+===========+===============================================+
|
||||||
| ERROR | Shows only critical error |
|
| ERROR | Shows only critical errors |
|
||||||
+-----------+-----------------------------------------------+
|
+-----------+-----------------------------------------------+
|
||||||
| WARNING | Shows only errors (all kind) |
|
| WARNING | Shows only errors (of all kinds) |
|
||||||
+-----------+-----------------------------------------------+
|
+-----------+-----------------------------------------------+
|
||||||
| INFO | Shows only status related messages and errors |
|
| INFO | Shows only status-related messages and errors |
|
||||||
+-----------+-----------------------------------------------+
|
+-----------+-----------------------------------------------+
|
||||||
| DEBUG | Shows every possible information. |
|
| DEBUG | Shows all possible information |
|
||||||
+-----------+-----------------------------------------------+
|
+-----------+-----------------------------------------------+
|
19
docs/getting_started/troubleshooting.rst
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
.. _troubleshooting:
|
||||||
|
|
||||||
|
===============
|
||||||
|
Troubleshooting
|
||||||
|
===============
|
||||||
|
|
||||||
|
The majority of issues new users experience when first using Multi-User can be solved with a few quick checks.
|
||||||
|
|
||||||
|
- Run Blender in Administrator mode
|
||||||
|
- Update the multi-user addon to the latest version
|
||||||
|
- Make sure to allow Blender through your firewall
|
||||||
|
|
||||||
|
.. hint:: Your firewall may have additional settings like Ransomware protection, or you may need to enable both Blender and Python on private and/or public Networks
|
||||||
|
|
||||||
|
- Solve problems with your connection quality
|
||||||
|
- Minimise the use of large textures or file sizes
|
||||||
|
- Avoid using 'Undo'. Use 'delete' instead
|
||||||
|
|
||||||
|
Use the #support channel on the multi-user `discord server <https://discord.gg/aBPvGws>`_ to chat, seek help and contribute.
|
@ -1,28 +1,30 @@
|
|||||||
.. _internet-guide:
|
.. _internet-guide:
|
||||||
|
|
||||||
===================
|
=======================
|
||||||
Hosting on internet
|
Hosting on the internet
|
||||||
===================
|
=======================
|
||||||
|
|
||||||
.. warning::
|
.. warning::
|
||||||
Until now, those communications are not encrypted but are planned to be in a mid-term future (`Status <https://gitlab.com/slumber/multi-user/issues/62>`_).
|
Until now, those communications are not encrypted but are planned to be in a mid-term future (`status <https://gitlab.com/slumber/multi-user/issues/62>`_).
|
||||||
|
|
||||||
This tutorial aims to guide you to host a collaborative Session on internet.
|
This tutorial aims to guide you toward hosting a collaborative multi-user session on the internet.
|
||||||
Hosting a session can be done is several ways:
|
Hosting a session can be achieved in several ways:
|
||||||
|
|
||||||
- :ref:`host-blender`: hosting a session directly from the blender add-on panel.
|
- :ref:`host-blender`: hosting a session directly from the blender add-on panel.
|
||||||
- :ref:`host-dedicated`: hosting a session directly from the command line interface on a computer without blender.
|
- :ref:`host-dedicated`: hosting a session directly from the command line interface on a computer without blender.
|
||||||
|
- :ref:`host-cloud`: hosting a session on a dedicated cloud server such as Google Cloud's free tier.
|
||||||
|
|
||||||
|
|
||||||
.. _host-blender:
|
.. _host-blender:
|
||||||
|
|
||||||
-------------
|
--------------------
|
||||||
From blender
|
From blender
|
||||||
-------------
|
--------------------
|
||||||
By default your router doesn't allow anyone to share you connection.
|
By default your router doesn't allow anyone to share you connection.
|
||||||
In order grant server access to people from internet you have tow main option:
|
In order grant the server access to people from internet you have two main option:
|
||||||
|
|
||||||
* The :ref:`connection-sharing`: the easiest way.
|
* The :ref:`connection-sharing`: the easiest way.
|
||||||
* The :ref:`port-forwarding`: this one is the most unsecure, if you have no networking knowledge, you should definitively go to :ref:`connection-sharing`.
|
* The :ref:`port-forwarding`: this way is the most unsecure. If you have no networking knowledge, you should definitely follow :ref:`connection-sharing`.
|
||||||
|
|
||||||
.. _connection-sharing:
|
.. _connection-sharing:
|
||||||
|
|
||||||
@ -30,7 +32,7 @@ Using a connection sharing solution
|
|||||||
-----------------------------------
|
-----------------------------------
|
||||||
|
|
||||||
Many third party software like `ZEROTIER <https://www.zerotier.com/download/>`_ (Free) or `HAMACHI <https://vpn.net/>`_ (Free until 5 users) allow you to share your private network with other people.
|
Many third party software like `ZEROTIER <https://www.zerotier.com/download/>`_ (Free) or `HAMACHI <https://vpn.net/>`_ (Free until 5 users) allow you to share your private network with other people.
|
||||||
For the example I'm gonna use ZeroTier because its free and open source.
|
For the example I'm gonna use ZeroTier because it's free and open source.
|
||||||
|
|
||||||
1. Installation
|
1. Installation
|
||||||
^^^^^^^^^^^^^^^
|
^^^^^^^^^^^^^^^
|
||||||
@ -153,12 +155,12 @@ This is it for the ZeroTier network setup. Now everything should be setup to use
|
|||||||
Using port-forwarding
|
Using port-forwarding
|
||||||
---------------------
|
---------------------
|
||||||
|
|
||||||
The port forwarding method consist to configure you Network route to allow internet trafic throught specific ports.
|
The port forwarding method consists of configuring your network router to deny most traffic with a firewall, but to then allow particular internet traffic (like a multiuser connection) through the firewall on specified ports.
|
||||||
|
|
||||||
In order to know which port are used by the add-on, check the :ref:`port-setup` section.
|
In order to know which ports are used by the add-on, please check the :ref:`port-setup` section.
|
||||||
To set up port forwarding for each port you can follow this `guide <https://www.wikihow.com/Set-Up-Port-Forwarding-on-a-Router>`_ for example.
|
To set up port forwarding for each port you can follow this `guide <https://www.wikihow.com/Set-Up-Port-Forwarding-on-a-Router>`_ for example.
|
||||||
|
|
||||||
Once you have set up the network you can follow the :ref:`quickstart` guide to start using the multi-user add-on !
|
Once you have set up the network you can follow the :ref:`quickstart` guide to begin using the multi-user add-on !
|
||||||
|
|
||||||
.. _host-dedicated:
|
.. _host-dedicated:
|
||||||
|
|
||||||
@ -167,11 +169,10 @@ From the dedicated server
|
|||||||
--------------------------
|
--------------------------
|
||||||
|
|
||||||
.. warning::
|
.. warning::
|
||||||
The dedicated server is developed to run directly on internet server (like VPS). You can also
|
The dedicated server is developed to run directly on an internet server (like a VPS (Virtual Private Server)). You can also run it at home on a LAN but for internet hosting you need to follow the :ref:`port-forwarding` setup first. Please see :ref:`host-cloud` for a detailed walkthrough of cloud hosting using Google Cloud.
|
||||||
run it at home for LAN but for internet hosting you need to follow the :ref:`port-forwarding` setup first.
|
|
||||||
|
|
||||||
The dedicated server allow you to host a session with simplicity from any location.
|
The dedicated server allows you to host a session with simplicity from any location.
|
||||||
It was developed to improve internet hosting performance.
|
It was developed to improve internet hosting performance (for example poor latency).
|
||||||
|
|
||||||
The dedicated server can be run in two ways:
|
The dedicated server can be run in two ways:
|
||||||
|
|
||||||
@ -192,29 +193,28 @@ You can run the dedicated server on any platform by following these steps:
|
|||||||
|
|
||||||
.. code-block:: bash
|
.. code-block:: bash
|
||||||
|
|
||||||
python -m pip install replication==0.0.21a15
|
python -m pip install replication==0.1.13
|
||||||
|
|
||||||
4. Launch the server with:
|
4. Launch the server with:
|
||||||
|
|
||||||
.. code-block:: bash
|
.. code-block:: bash
|
||||||
|
|
||||||
replication.serve
|
replication.server
|
||||||
|
|
||||||
.. hint::
|
.. hint::
|
||||||
You can also specify a custom **port** (-p), **timeout** (-t), **admin password** (-pwd), **log level (ERROR, WARNING, INFO or DEBUG)** (-l) and **log file** (-lf) with the following optional arguments
|
You can also specify a custom **port** (-p), **timeout** (-t), **admin password** (-pwd), **log level (ERROR, WARNING, INFO or DEBUG)** (-l) and **log file** (-lf) with the following optional arguments
|
||||||
|
|
||||||
.. code-block:: bash
|
.. code-block:: bash
|
||||||
|
|
||||||
replication.serve -p 5555 -pwd admin -t 1000 -l INFO -lf server.log
|
replication.server -p 5555 -pwd admin -t 5000 -l INFO -lf server.log
|
||||||
|
|
||||||
Here, for example, a server is instantiated on port 5555, with password 'admin', a 1 second timeout, and logging enabled.
|
Here, for example, a server is instantiated on port 5555, with password 'admin', a 5 second timeout, and logging enabled.
|
||||||
|
|
||||||
As soon as the dedicated server is running, you can connect to it from blender by following :ref:`how-to-join`.
|
As soon as the dedicated server is running, you can connect to it from blender by following :ref:`how-to-join`.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
.. hint::
|
.. hint::
|
||||||
Some commands are available to enable an administrator to manage the session. Check :ref:`dedicated-management` to learn more.
|
Some server commands are available to enable administrators to manage a multi-user session. Check :ref:`dedicated-management` to learn more.
|
||||||
|
|
||||||
|
|
||||||
.. _docker:
|
.. _docker:
|
||||||
@ -231,18 +231,23 @@ Launching the dedicated server from a docker server is simple as running:
|
|||||||
-e port=5555 \
|
-e port=5555 \
|
||||||
-e log_level=DEBUG \
|
-e log_level=DEBUG \
|
||||||
-e password=admin \
|
-e password=admin \
|
||||||
-e timeout=1000 \
|
-e timeout=5000 \
|
||||||
registry.gitlab.com/slumber/multi-user/multi-user-server:0.1.0
|
registry.gitlab.com/slumber/multi-user/multi-user-server:0.2.0
|
||||||
|
|
||||||
As soon as the dedicated server is running, you can connect to it from blender by following :ref:`how-to-join`.
|
Please use the URL of the most recent container available in the `multi-user container registry <https://gitlab.com/slumber/multi-user/container_registry/1174180>`_. As soon as the dedicated server is running, you can connect to it from blender by following :ref:`how-to-join`.
|
||||||
|
|
||||||
You can check your container is running, and find its ID with:
|
You can check that your container is running, and find its ID and name with:
|
||||||
|
|
||||||
.. code-block:: bash
|
.. code-block:: bash
|
||||||
|
|
||||||
docker ps
|
docker ps
|
||||||
|
|
||||||
Logs for the server running in the docker container can be accessed by outputting the following to a log file:
|
.. _docker-logs:
|
||||||
|
|
||||||
|
Viewing logs in a docker container
|
||||||
|
-----------------------------------
|
||||||
|
|
||||||
|
Logs for the server running in a docker container can be accessed by outputting the following to a log file:
|
||||||
|
|
||||||
.. code-block:: bash
|
.. code-block:: bash
|
||||||
|
|
||||||
@ -250,6 +255,33 @@ Logs for the server running in the docker container can be accessed by outputtin
|
|||||||
|
|
||||||
.. Note:: If using WSL2 on Windows 10 (Windows Subsystem for Linux), it is preferable to run a dedicated server via regular command line approach (or the associated startup script) from within Windows - docker desktop for windows 10 usually uses the WSL2 backend where it is available.
|
.. Note:: If using WSL2 on Windows 10 (Windows Subsystem for Linux), it is preferable to run a dedicated server via regular command line approach (or the associated startup script) from within Windows - docker desktop for windows 10 usually uses the WSL2 backend where it is available.
|
||||||
|
|
||||||
|
.. This may not be true. Need to write up how to locally start a docker container from WSL2
|
||||||
|
|
||||||
|
First, you'll need to know your container ID, which you can find by running:
|
||||||
|
|
||||||
|
.. code-block:: bash
|
||||||
|
docker ps
|
||||||
|
|
||||||
|
If you're cloud-hosting with e.g. Google Cloud, your container will be the one associated with the `registry address <https://gitlab.com/slumber/multi-user/container_registry/1174180>`_ where your Docker image was located.
|
||||||
|
|
||||||
|
e.g. registry.gitlab.com/slumber/multi-user/multi-user-server:0.2.0
|
||||||
|
|
||||||
|
You can either ssh in to your server and then run
|
||||||
|
|
||||||
|
.. code-block:: bash
|
||||||
|
cat your-log-name.log
|
||||||
|
|
||||||
|
or view the docker container logs with
|
||||||
|
|
||||||
|
.. code-block:: bash
|
||||||
|
docker logs your-container-name
|
||||||
|
|
||||||
|
OR
|
||||||
|
|
||||||
|
.. code-block:: bash
|
||||||
|
docker logs your-container-id
|
||||||
|
|
||||||
|
Note, see these `notes <https://cloud.google.com/compute/docs/containers/deploying-containers?_ga=2.113663175.-1396941296.1606125558#viewing_container_logs>`_ for how to check server logs on Google Cloud.
|
||||||
|
|
||||||
.. _serverstartscripts:
|
.. _serverstartscripts:
|
||||||
|
|
||||||
@ -280,11 +312,28 @@ Dedicated server management
|
|||||||
|
|
||||||
Here is the list of available commands from the dedicated server:
|
Here is the list of available commands from the dedicated server:
|
||||||
|
|
||||||
- ``help``: Show all commands.
|
- ``help`` or ``?``: Show all commands.
|
||||||
- ``exit`` or ``Ctrl+C`` : Stop the server.
|
- ``exit`` or ``Ctrl+C`` : Stop the server.
|
||||||
- ``kick username``: kick the provided user.
|
- ``kick username``: kick the provided user.
|
||||||
- ``users``: list all online users.
|
- ``users``: list all online users.
|
||||||
|
|
||||||
|
Also, see :ref:`how-to-manage` for more details on managing a server.
|
||||||
|
|
||||||
|
.. _cloud_dockermanage:
|
||||||
|
|
||||||
|
Managing a docker server from the command line
|
||||||
|
----------------------------------------------
|
||||||
|
If you want to be able to manage a server running within a docker container, open the terminal on the host machine (or SSH in, if you are using cloud hosting), and then run
|
||||||
|
|
||||||
|
.. code-block:: bash
|
||||||
|
docker ps
|
||||||
|
|
||||||
|
to find your container id, and then
|
||||||
|
|
||||||
|
.. code-block:: bash
|
||||||
|
docker attach your-container-id
|
||||||
|
|
||||||
|
to attach to the STDOUT from the container. There, you can issue the server management commands detailed in :ref:`dedicated-management`. Type ``?`` and hit return/enter to see the available commands. Also, see :ref:`how-to-manage` for more details on managing a server.
|
||||||
|
|
||||||
.. _port-setup:
|
.. _port-setup:
|
||||||
|
|
||||||
@ -292,14 +341,14 @@ Here is the list of available commands from the dedicated server:
|
|||||||
Port setup
|
Port setup
|
||||||
----------
|
----------
|
||||||
|
|
||||||
The multi-user network architecture is based on a clients-server model. The communication protocol use four ports to communicate with client:
|
The multi-user network architecture is based on a client-server model. The communication protocol uses four ports to communicate with clients:
|
||||||
|
|
||||||
* Commands: command transmission (such as **snapshots**, **change_rights**, etc.) [given port]
|
* Commands: command transmission (such as **snapshots**, **change_rights**, etc.) [user-nominated port]
|
||||||
* Subscriber : pull data [Commands port + 1]
|
* Subscriber : pull data [Commands port + 1]
|
||||||
* Publisher : push data [Commands port + 2]
|
* Publisher : push data [Commands port + 2]
|
||||||
* TTL (time to leave) : used to ping each client [Commands port + 3]
|
* TTL (time to leave) : used to ping each client [Commands port + 3]
|
||||||
|
|
||||||
To know which ports will be used, you just have to read the port in your preference.
|
To know which ports will be used, you just have to read the port in your preferences.
|
||||||
|
|
||||||
.. figure:: img/hosting_guide_port.png
|
.. figure:: img/hosting_guide_port.png
|
||||||
:align: center
|
:align: center
|
||||||
@ -307,11 +356,309 @@ To know which ports will be used, you just have to read the port in your prefere
|
|||||||
:width: 200px
|
:width: 200px
|
||||||
|
|
||||||
Port in host settings
|
Port in host settings
|
||||||
In the picture below we have setup our port to **5555** so it will be:
|
|
||||||
|
|
||||||
* Commands: 5555 (**5555**)
|
In the picture below we have setup our port to **5555** so the four ports will be:
|
||||||
* Subscriber: 5556 (**5555** +1)
|
|
||||||
* Publisher: 5557 (**5555** +2)
|
|
||||||
* TTL: 5558 (**5555** +3)
|
|
||||||
|
|
||||||
Those four ports need to be accessible from the client otherwise it won't work at all !
|
* Commands: **5555** (5555)
|
||||||
|
* Subscriber: **5556** (5555 +1)
|
||||||
|
* Publisher: **5557** (5555 +2)
|
||||||
|
* TTL: **5558** (5555 +3)
|
||||||
|
|
||||||
|
Those four ports need to be accessible from the client otherwise multi-user won't work at all !
|
||||||
|
|
||||||
|
.. _host-cloud:
|
||||||
|
|
||||||
|
-------------------------
|
||||||
|
Cloud Hosting Walkthrough
|
||||||
|
-------------------------
|
||||||
|
|
||||||
|
The following is a walkthrough for how to set up a multi-user dedicated server instance on a cloud hosting provider - in this case, `Google Cloud <https://www.cloud.google.com>`_. Google Cloud is a powerful hosting service with a worldwide network of servers. It offers a free trial which provides free cloud hosting for 90 days, and then a free tier which runs indefinitely thereafter, so long as you stay within the `usage limits <https://cloud.google.com/free/docs/gcp-free-tier#free-tier-usage-limits>`_. ^^Thanks to community member @NotFood for the tip!
|
||||||
|
|
||||||
|
Cloud hosting is a little more complicated to set up, but it can be valuable if you are trying to host a session with multiple users scattered about planet earth. This can resolve issues with data replication or slowdowns due to poor latency of some users (high ping). This guide may seem technical, but if you follow the steps, you should be able to succeed in hosting an internet server to co-create with other multi-user creators around the world.
|
||||||
|
|
||||||
|
Setup Process
|
||||||
|
-------------
|
||||||
|
|
||||||
|
1. Sign Up for Google Cloud
|
||||||
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
Let's start by activating an account with Google Cloud. Go to https://www.cloud.google.com and click 'Get Started For Free'
|
||||||
|
|
||||||
|
.. figure:: img/hosting_guide_gcloud_1.jpg
|
||||||
|
:align: center
|
||||||
|
:width: 450px
|
||||||
|
|
||||||
|
Google will ask you to login/signup, and to set up a billing account (Don't worry. It will not be charged unless you explicitly enable billing and then run over your `free credit allowance <https://cloud.google.com/free/docs/gcp-free-tier>`_). You will need to choose a billing country (relevant for `tax purposes <https://cloud.google.com/billing/docs/resources/vat-overview>`_). You will choose your server location at a later step.
|
||||||
|
|
||||||
|
2. Enable Billing and Compute Engine API
|
||||||
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
From here on, we will mostly stick to the instructions provided `here <https://cloud.google.com/compute/docs/quickstart-linux>`_. Nevertheless, the instructions for multi-user specifically are as follows.
|
||||||
|
|
||||||
|
In order to set up a Virtual Machine (VM) to host your server, you will need to enable the billing account which was created during your signup process. From your `console <https://console.cloud.google.com/getting-started>`_, click on 'Go to Checklist' and then 'Create a Billing Account', following the prompts to choose the billing account that was created for you upon signup.
|
||||||
|
|
||||||
|
.. figure:: img/hosting_guide_gcloud_2.jpg
|
||||||
|
:align: center
|
||||||
|
:width: 300px
|
||||||
|
|
||||||
|
.. figure:: img/hosting_guide_gcloud_3.jpg
|
||||||
|
:align: center
|
||||||
|
:width: 300px
|
||||||
|
|
||||||
|
.. figure:: img/hosting_guide_gcloud_4.jpg
|
||||||
|
:align: center
|
||||||
|
:width: 300px
|
||||||
|
|
||||||
|
.. figure:: img/hosting_guide_gcloud_5.jpg
|
||||||
|
:align: center
|
||||||
|
:width: 300px
|
||||||
|
|
||||||
|
.. figure:: img/hosting_guide_gcloud_6.jpg
|
||||||
|
:align: center
|
||||||
|
:width: 300px
|
||||||
|
|
||||||
|
Now hit 'Set Account', and go back to your `console <https://console.cloud.google.com/getting-started>`_.
|
||||||
|
|
||||||
|
Now enable the Compute Engine API. Click `here <https://console.cloud.google.com/apis/api/compute.googleapis.com/overview>`_ to enable.
|
||||||
|
|
||||||
|
.. figure:: img/hosting_guide_gcloud_7.jpg
|
||||||
|
:align: center
|
||||||
|
:width: 450px
|
||||||
|
|
||||||
|
3. Create a Linux Virtual Machine Instance
|
||||||
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
Continue following the `instructions <https://cloud.google.com/compute/docs/quickstart-linux#create_a_virtual_machine_instance>`_ to create a VM instance. However, once you've finished step 2 of 'Create a virtual machine instance', use the settings and steps for multi-user as follows.
|
||||||
|
|
||||||
|
.. _server-location:
|
||||||
|
|
||||||
|
3.1 Choose a Server Location
|
||||||
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
The most important settings which you will need to choose for your specific case are the server Region and Zone. You must choose a location which will provide the best ping for all of your users.
|
||||||
|
|
||||||
|
All you need to know is that you'll probably want to choose a location near to where most of your users are located. If your users are spread out, somewhere in the middle which distributes the ping evenly to all users is best.
|
||||||
|
|
||||||
|
You can use `this map <https://cloud.google.com/about/locations/>`_ to make a rough guess of the best server location, if you know your users' locations.
|
||||||
|
|
||||||
|
.. figure:: img/hosting_guide_gcloud_9.jpg
|
||||||
|
:align: center
|
||||||
|
:width: 450px
|
||||||
|
|
||||||
|
A much better approach is to have your users run a ping test for Google Cloud's servers at https://www.gcping.com/
|
||||||
|
|
||||||
|
Have your users open this webpage from their fastest browser, and press the play button. The play button turns to a stop icon while the ping test is running. When it is complete, the play button returns. You may need to refresh your browser to get this to work. You can replay the test to add more server locations to the scan, and stop when you are satisfied that the results are consistent.
|
||||||
|
|
||||||
|
Now, gather your users' data, and work down each user's list from the top, until you find the first location which gives roughly the same ping for all users.
|
||||||
|
|
||||||
|
In general, global (using load balancing) will provide the best results, but beyond that, the US Central servers e.g. IOWA generally turn out best for a globally distributed bunch of users.
|
||||||
|
|
||||||
|
For the following example, the server which gave the most balanced, and lowest average ping between two users based in Europe and Australia was in Iowa. Salt Lake City would also be an excellent choice.
|
||||||
|
|
||||||
|
.. figure:: img/hosting_guide_gcloud_10.jpg
|
||||||
|
:align: center
|
||||||
|
:width: 450px
|
||||||
|
|
||||||
|
Left - European User | Right - Australian User
|
||||||
|
|
||||||
|
Now, input this server location in the 'Region' field for your instance, and leave the default zone which is then populated.
|
||||||
|
|
||||||
|
.. Note:: You can read `here <https://cloud.google.com/solutions/best-practices-compute-engine-region-selection>`_ for a deeper understanding about how to choose a good server location.
|
||||||
|
|
||||||
|
3.2 Configure the VM
|
||||||
|
^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
You can deploy the replication server to your VM in either of the ways mentioned at :ref:`host-dedicated`. That is, you can set it up :ref:`cmd-line` or :ref:`docker`. We will go through both options in this walkthrough. See :ref:`container_v_direct` for more details on how to choose. Deploying a container is the recommended approach.
|
||||||
|
|
||||||
|
.. _cloud-container:
|
||||||
|
|
||||||
|
Option 1 - Deploy a container
|
||||||
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
If you are familiar with Docker, you'll appreciate that it makes life a little simpler for us. While configuring your instance, you can check **Deploy a container to this VM instance** and copy in the URL of the latest docker image available from the `multi-user container registry <https://gitlab.com/slumber/multi-user/container_registry/1174180>`_ to the *Container image* field.
|
||||||
|
|
||||||
|
.. figure:: img/hosting_guide_gcloud_8b.jpg
|
||||||
|
:align: center
|
||||||
|
:width: 450px
|
||||||
|
|
||||||
|
Your configuration with Docker should look like this
|
||||||
|
|
||||||
|
Make sure to choose the amount of memory you'd like your server to be able to handle (how much memory does your blender scene require?). In this example, I've chosen 8GB of RAM.
|
||||||
|
|
||||||
|
Click on **Advanced container options** and turn on *Allocate a buffer for STDIN* and *Allocate a pseudo-TTY* just in case you want to run an interactive shell in your container.
|
||||||
|
|
||||||
|
.. _cloud-optional-parameters:
|
||||||
|
|
||||||
|
Optional server parameters
|
||||||
|
^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
The default Docker image essentially runs the equivalent of:
|
||||||
|
|
||||||
|
.. code-block:: bash
|
||||||
|
|
||||||
|
replication.server -pwd admin -p 5555 -t 5000 -l DEBUG -lf multiuser_server.log
|
||||||
|
|
||||||
|
This means the server will be launched with 'admin' as the administrator password, run on ports 5555:5558, use a timeout of 5 seconds, verbose 'DEBUG' log level, and with log files written to 'multiuser_server.log'. See :ref:`cmd-line` for a description of optional parameters.
|
||||||
|
|
||||||
|
.. Note:: If you'd like to configure different server options from the default docker configuration, you can insert your options here by expanding 'Advanced container options'
|
||||||
|
|
||||||
|
For example, I would like to launch my server with a different administrator password than the default, my own log filename, and a shorter 3-second (3000ms) timeout. I'll click *Add argument* under **Command arguments** and paste the following command with options into the "command arguments" field:
|
||||||
|
|
||||||
|
.. code-block:: bash
|
||||||
|
|
||||||
|
python3 -m replication.server -pwd supersecretpassword -p 5555 -t 3000 -l DEBUG -lf logname.log
|
||||||
|
|
||||||
|
Now, my configuration should look like this:
|
||||||
|
|
||||||
|
.. figure:: img/hosting_guide_gcloud_8c.jpg
|
||||||
|
:align: center
|
||||||
|
:width: 450px
|
||||||
|
|
||||||
|
The rest of the settings are now complete. Hit **Create** and your instance will go live. If you've taken this approach, you're already almost there! Skip to :ref:`cloud-firewall`.
|
||||||
|
|
||||||
|
.. hint:: You can find further information on configuration options `here <https://cloud.google.com/compute/docs/containers/configuring-options-to-run-containers>`_. Also, see these `notes <https://cloud.google.com/compute/docs/containers/deploying-containers?_ga=2.113663175.-1396941296.1606125558#viewing_container_logs>`_ for other options when deploying your server inside a container, including how to access the server's logs.
|
||||||
|
|
||||||
|
.. _cloud-direct:
|
||||||
|
|
||||||
|
Option 2 - Over SSH
|
||||||
|
^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
Otherwise, we can run the dedicated server ourselves from the command-line over SSH.
|
||||||
|
|
||||||
|
While creating your instance, keep the default settings mentioned in the `guide <https://cloud.google.com/compute/docs/quickstart-linux#create_a_virtual_machine_instance>`_, however at step 4, choose Debian version 10. Also, there is no need to enable HTTP so skip step 6.
|
||||||
|
|
||||||
|
.. figure:: img/hosting_guide_gcloud_8.jpg
|
||||||
|
:align: center
|
||||||
|
:width: 450px
|
||||||
|
|
||||||
|
Your configuration should look like this
|
||||||
|
|
||||||
|
Make sure to choose the amount of memory you'd like your server to be able to handle (how much memory does your blender scene require?). In this example, I've chosen 4GB of RAM.
|
||||||
|
|
||||||
|
Now, finally, click 'Create' to generate your Virtual Machine Instance.
|
||||||
|
|
||||||
|
.. _cloud-firewall:
|
||||||
|
|
||||||
|
4. Setting up Firewall and opening Ports
|
||||||
|
----------------------------------------
|
||||||
|
|
||||||
|
Now that your VM is instanced, you'll need to set up firewall rules, and open the ports required by multi-user. The documentation for VM firewalls on google cloud is `here <https://cloud.google.com/vpc/docs/using-firewalls#listing-rules-vm>`_.
|
||||||
|
|
||||||
|
First, go to the dashboard showing your `VM instances <https://console.cloud.google.com/compute/instances>`_ and note the 'External IP' address for later. This is the address of your server. Then, click 'Set up Firewall Rules'.
|
||||||
|
|
||||||
|
.. figure:: img/hosting_guide_gcloud_11.jpg
|
||||||
|
:align: center
|
||||||
|
:width: 450px
|
||||||
|
|
||||||
|
Note down your External IP
|
||||||
|
|
||||||
|
Now you will need to create two rules. One to enable communication inbound to your server (ingress), and another to enable outbound communication from your server (egress). Click 'Create Firewall'
|
||||||
|
|
||||||
|
.. figure:: img/hosting_guide_gcloud_12.jpg
|
||||||
|
:align: center
|
||||||
|
:width: 450px
|
||||||
|
|
||||||
|
Now create a rule exactly as in the image below for the outbound communication (egress).
|
||||||
|
|
||||||
|
.. figure:: img/hosting_guide_gcloud_13.jpg
|
||||||
|
:align: center
|
||||||
|
:width: 450px
|
||||||
|
|
||||||
|
Egress
|
||||||
|
|
||||||
|
.. Note:: If you set a different port number in :ref:`cloud-optional-parameters`, then use the ports indicated in :ref:`port-setup`
|
||||||
|
|
||||||
|
And another rule exactly as in the image below for the inbound communication (ingress).
|
||||||
|
|
||||||
|
.. figure:: img/hosting_guide_gcloud_14.jpg
|
||||||
|
:align: center
|
||||||
|
:width: 450px
|
||||||
|
|
||||||
|
Ingress
|
||||||
|
|
||||||
|
Finally, your firewall configuration should look like this.
|
||||||
|
|
||||||
|
.. figure:: img/hosting_guide_gcloud_15.jpg
|
||||||
|
:align: center
|
||||||
|
:width: 450px
|
||||||
|
|
||||||
|
Final Firewall Configuration
|
||||||
|
|
||||||
|
|
||||||
|
5. Install Replication Server into Virtual Machine
|
||||||
|
--------------------------------------------------
|
||||||
|
|
||||||
|
.. Note:: Skip to :ref:`initialise-server` if you've opted to launch the server by deploying a container. Your server is already live!
|
||||||
|
|
||||||
|
Now that we have set up our Virtual Machine instance, we can SSH into it, and install the Replication Server. Open the `VM Instances console <https://console.cloud.google.com/compute/instances>`_ once more, and SSH into your instance. It's easiest to use the browser terminal provided by Google Cloud (I had the best luck using the Google Chrome browser).
|
||||||
|
|
||||||
|
.. figure:: img/hosting_guide_gcloud_16.jpg
|
||||||
|
:align: center
|
||||||
|
:width: 450px
|
||||||
|
|
||||||
|
Now, a terminal window should pop up in a new browser window looking something like this:
|
||||||
|
|
||||||
|
.. figure:: img/hosting_guide_gcloud_17.jpg
|
||||||
|
:align: center
|
||||||
|
:width: 450px
|
||||||
|
|
||||||
|
Remember, you had set up the VM with Debian 10. This comes with Python 3.7.3 already installed. The only dependency missing is to set up pip3. So, run:
|
||||||
|
|
||||||
|
.. code-block:: bash
|
||||||
|
|
||||||
|
sudo apt install python3-pip
|
||||||
|
|
||||||
|
.. figure:: img/hosting_guide_gcloud_18.jpg
|
||||||
|
:align: center
|
||||||
|
:width: 450px
|
||||||
|
|
||||||
|
And now lets install the latest version of replication:
|
||||||
|
|
||||||
|
.. code-block:: bash
|
||||||
|
|
||||||
|
sudo pip3 install replication==0.1.13
|
||||||
|
|
||||||
|
6. Launch Replication Server on VM Instance
|
||||||
|
-------------------------------------------
|
||||||
|
|
||||||
|
We're finally ready to launch the server. Simply run:
|
||||||
|
|
||||||
|
.. code-block:: bash
|
||||||
|
|
||||||
|
python3 -m replication.server -p 5555 -pwd admin -t 5000 -l INFO -lf server.log
|
||||||
|
|
||||||
|
See :ref:`cmd-line` for a description of optional parameters
|
||||||
|
|
||||||
|
And your replication server is live! It should stay running in the terminal window until you close it. Copy the external IP that you noted down earlier, available `here <https://console.cloud.google.com/networking/addresses/list>`_ and now you can open Blender and connect to your server!
|
||||||
|
|
||||||
|
.. _initialise-server:
|
||||||
|
|
||||||
|
7. Initialise your Server in Blender
|
||||||
|
------------------------------------
|
||||||
|
|
||||||
|
Once in Blender, make sure your multi-user addon is updated to the latest version. Then, follow the instructions from :ref:`how-to-join` and connect as an admin user, using the password you launched the server with. Input your external IP, and make sure you're set to JOIN the server. Then, click CONNECT.
|
||||||
|
|
||||||
|
.. figure:: img/hosting_guide_gcloud_19.jpg
|
||||||
|
:align: center
|
||||||
|
:width: 200px
|
||||||
|
|
||||||
|
Now as the admin user, you can choose whether to initialise the server with a preloaded scene, or an empty scene
|
||||||
|
|
||||||
|
.. figure:: img/hosting_guide_gcloud_20.jpg
|
||||||
|
:align: center
|
||||||
|
:width: 200px
|
||||||
|
|
||||||
|
Press okay, and now your session is live!
|
||||||
|
|
||||||
|
If you made it this far, congratulations! You can now go ahead and share the external IP address with your friends and co-creators and have fun with real-time collaboration in Blender!
|
||||||
|
|
||||||
|
Hopefully, your cloud server setup has improved your group's overall ping readings, and you're in for a smooth and trouble-free co-creation session.
|
||||||
|
|
||||||
|
.. Note:: If you should so desire, pay attention to your credit and follow the steps `here <https://cloud.google.com/compute/docs/quickstart-linux#clean-up>`_ to close your instance at your discretion.
|
||||||
|
|
||||||
|
.. _container_v_direct:
|
||||||
|
|
||||||
|
Should I deploy a Docker Container or launch a server from Linux VM command-line?
|
||||||
|
------------------------------------------------------
|
||||||
|
|
||||||
|
- Directly from Linux VM - This approach gives you control over your session more easily. However, your server may time out once your SSH link to the server is interrupted (for example, if the admin's computer goes to sleep).
|
||||||
|
- Deploy a Docker Container - This is the recommended approach. This approach is better for leaving a session running without supervision. It can however be more complicated to manage. Use this approach if you'd like a consistent experience with other users, pulling from the most up-to-date docker image maintained by @swann in the multi-user container registry.
|
BIN
docs/tutorials/img/hosting_guide_gcloud_1.jpg
Normal file
After Width: | Height: | Size: 757 KiB |
BIN
docs/tutorials/img/hosting_guide_gcloud_10.jpg
Normal file
After Width: | Height: | Size: 214 KiB |
BIN
docs/tutorials/img/hosting_guide_gcloud_11.jpg
Normal file
After Width: | Height: | Size: 1.0 MiB |
BIN
docs/tutorials/img/hosting_guide_gcloud_12.jpg
Normal file
After Width: | Height: | Size: 97 KiB |
BIN
docs/tutorials/img/hosting_guide_gcloud_13.jpg
Normal file
After Width: | Height: | Size: 114 KiB |
BIN
docs/tutorials/img/hosting_guide_gcloud_14.jpg
Normal file
After Width: | Height: | Size: 115 KiB |
BIN
docs/tutorials/img/hosting_guide_gcloud_15.jpg
Normal file
After Width: | Height: | Size: 272 KiB |
BIN
docs/tutorials/img/hosting_guide_gcloud_16.jpg
Normal file
After Width: | Height: | Size: 162 KiB |
BIN
docs/tutorials/img/hosting_guide_gcloud_17.jpg
Normal file
After Width: | Height: | Size: 687 KiB |
BIN
docs/tutorials/img/hosting_guide_gcloud_18.jpg
Normal file
After Width: | Height: | Size: 635 KiB |
BIN
docs/tutorials/img/hosting_guide_gcloud_19.jpg
Normal file
After Width: | Height: | Size: 51 KiB |
BIN
docs/tutorials/img/hosting_guide_gcloud_2.jpg
Normal file
After Width: | Height: | Size: 804 KiB |
BIN
docs/tutorials/img/hosting_guide_gcloud_20.jpg
Normal file
After Width: | Height: | Size: 60 KiB |
BIN
docs/tutorials/img/hosting_guide_gcloud_3.jpg
Normal file
After Width: | Height: | Size: 579 KiB |
BIN
docs/tutorials/img/hosting_guide_gcloud_4.jpg
Normal file
After Width: | Height: | Size: 67 KiB |
BIN
docs/tutorials/img/hosting_guide_gcloud_5.jpg
Normal file
After Width: | Height: | Size: 102 KiB |
BIN
docs/tutorials/img/hosting_guide_gcloud_6.jpg
Normal file
After Width: | Height: | Size: 66 KiB |
BIN
docs/tutorials/img/hosting_guide_gcloud_7.jpg
Normal file
After Width: | Height: | Size: 584 KiB |
BIN
docs/tutorials/img/hosting_guide_gcloud_8.jpg
Normal file
After Width: | Height: | Size: 111 KiB |
BIN
docs/tutorials/img/hosting_guide_gcloud_8a.jpg
Normal file
After Width: | Height: | Size: 97 KiB |
BIN
docs/tutorials/img/hosting_guide_gcloud_8b.jpg
Normal file
After Width: | Height: | Size: 180 KiB |
BIN
docs/tutorials/img/hosting_guide_gcloud_8c.jpg
Normal file
After Width: | Height: | Size: 114 KiB |
BIN
docs/tutorials/img/hosting_guide_gcloud_9.jpg
Normal file
After Width: | Height: | Size: 241 KiB |
@ -77,6 +77,7 @@ The following example suggests how to contribute a feature.
|
|||||||
.. code-block:: bash
|
.. code-block:: bash
|
||||||
|
|
||||||
git checkout -b feature/yourfeaturename
|
git checkout -b feature/yourfeaturename
|
||||||
|
|
||||||
...where 'feature/' designates a feature branch, and 'yourfeaturename' is a name of your choosing
|
...where 'feature/' designates a feature branch, and 'yourfeaturename' is a name of your choosing
|
||||||
|
|
||||||
9. Add and commit your changes, including a commit message:
|
9. Add and commit your changes, including a commit message:
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
# Download base image debian jessie
|
# Download base image debian jessie
|
||||||
FROM python:slim
|
FROM python:slim
|
||||||
|
|
||||||
ARG replication_version=0.0.21
|
ARG replication_version=0.1.13
|
||||||
ARG version=0.1.1
|
ARG version=0.1.1
|
||||||
|
|
||||||
# Infos
|
# Infos
|
||||||
@ -13,12 +13,13 @@ LABEL description="Blender multi-user addon \
|
|||||||
# Argument
|
# Argument
|
||||||
ENV password='admin'
|
ENV password='admin'
|
||||||
ENV port=5555
|
ENV port=5555
|
||||||
ENV timeout=3000
|
ENV timeout=5000
|
||||||
ENV log_level=INFO
|
ENV log_level=DEBUG
|
||||||
ENV log_file="multiuser_server.log"
|
ENV log_file="multiuser_server.log"
|
||||||
|
|
||||||
#Install replication
|
#Install replication
|
||||||
RUN pip install replication==$replication_version
|
RUN pip install replication==$replication_version
|
||||||
|
|
||||||
# Run the server with parameters
|
# Run the server with parameters
|
||||||
CMD replication.serve -pwd ${password} -p ${port} -t ${timeout} -l ${log_level} -lf ${log_file}
|
ENTRYPOINT ["/bin/sh", "-c"]
|
||||||
|
CMD ["python3 -m replication.server -pwd ${password} -p ${port} -t ${timeout} -l ${log_level} -lf ${log_file}"]
|