Skip to content

Commit

Permalink
добавил руководство по настройке виртуальной машины в среде VirtualBox
Browse files Browse the repository at this point in the history
  • Loading branch information
Qandra-Si committed Mar 9, 2024
1 parent 9901e97 commit e85b533
Show file tree
Hide file tree
Showing 21 changed files with 234 additions and 0 deletions.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
117 changes: 117 additions & 0 deletions docs/en/simulation_vm.md
Original file line number Diff line number Diff line change
Expand Up @@ -71,3 +71,120 @@ The steps to enable virtualization differ from manufacturer to manufacturer, but
### Configuring virtual machine in the VirtualBox environment
Hereafter, a *laptop* will be understood as the *main system* in which the virtual machine is being created.
1. Import the virtual machine archive into the virtualization environment.
* use the menu item **Open in VirtualBox** or double-click on the downloaded `clover-devel.ova` file:
![Open dialog with clover-devel.ova selected](../assets/simulation_setup_vm/01_vbox_import_ova.png)
* wait for the virtual machine import procedure to complete;
* after the import is completed, the downloaded `clover-devel.ova` file can be deleted.
2. Open the virtual machine settings window and change the settings to best match the capabilities of the laptop:
* increase the amount of RAM allocated to the virtual machine (recommended size is above 8GB):
![Increasing avaliable memory](../assets/simulation_setup_vm/02_vbox_setup_memory.png)
* increase the number of available processor cores (it is recommended to allocate half of the processor cores from the available number in the laptop):
![Increasing CPU cores](../assets/simulation_setup_vm/03_vbox_setup_cpu.png)
* enable all available additional hardware acceleration features supported by your laptop:
![Enabling CPU virtualization](../assets/simulation_setup_vm/04_vbox_setup_vtx.png)
* disable remote access to the virtual machine if you plan to use it on a laptop and not on the server:
![Disabling remote desktop access](../assets/simulation_setup_vm/05_vbox_setup_rdp.png)
* select the type of graphics controller `VMSVGA` (pay attention to the warning prompts at the bottom of the window, a different type of graphics controller may be recommended for use on your laptop):
![Setup video subsystem](../assets/simulation_setup_vm/06_vbox_setup_video.png)
* disable "3D acceleration" in the same tab of the settings window (the lightweight XFCE graphical shell in the virtual machine does not use 3D acceleration, and when 3D acceleration is enabled, some laptops experience "slowness" in operation);
* add an optical disk drive, in the new window specify the path to `VBoxGuestAdditions.iso` to the file (in Windows, you can find this file in the directory `C:\Program files\Oracle\VirtualBox`, and on Linux, look for it in the directory `/usr/share/virtualbox`, if it is not there, then see the instructions below):
![Setup CD-ROM drive](../assets/simulation_setup_vm/07_vbox_setup_cdrom.png)
```bash
# установка VBoxGuestAdditions.iso в Linux
sudo apt install virtualbox-guest-additions-iso
# поиск места расположения .iso файла
# обычно это /usr/share/virtualbox/VBoxGuestAdditions.iso
dpkg -L virtualbox-guest-additions-iso | grep VBoxGuestAdditions.iso
```
![Choose VBoxGuestAdditions.iso](../assets/simulation_setup_vm/08_vbox_setup_cdrom_guestadds.png)
* confirm file path selection, make sure that the new CD drive is in the list of devices:
![Attached VBoxGuestAdditions.iso](../assets/simulation_setup_vm/09_vbox_setup_cdrom_attached.png)
* for more information about contents of the add-on disc, see [this link](https://docs.oracle.com/en/virtualization/virtualbox/7.0/user/guestadditions.html);
* close the settings window by saving the changes using the "OK" button.
3. Start the virtual machine. Install the extensions for VirtualBox so that you can use the *clipboard* and work with files using the *shared folder* mode.
* after starting the virtual machine, make sure that in the "Devices | Optical discs" check the box opposite `VBoxGuestAdditions.iso` installed;
* open the file manager in the virtual machine and find the "Devices" group on the top right, click on `VBox_GA_7.0.12`:
![Install Guest Additions](../assets/simulation_setup_vm/10_vbox_coex_guestadd_install.png)
* in the list of files that appears, click on an empty space (not on the icon), select "Open terminal here", enter the command `sudo ./autorun.sh `:
![Building Guest Additions](../assets/simulation_setup_vm/11_vbox_coex_guestadd_build.png)
* a new window will appear in which the necessary drivers and programs for working with the clipboard and shared folders will be builded;
* wait for the completion of the program' building, when the inscription "Press Return to close this window..." appears, press Enter, the window will close;
* add the Linux user of the virtual machine to the group that is allowed to share files, to do this, enter the command `sudo adduser $USER vboxsf`:
![Building Guest Additions](../assets/simulation_setup_vm/11_vbox_coex_guestadd_build.png)
* the changes will require restarting the virtual machine, turn it off using the `sudo shutdown now` command;
* after shutting down the virtual machine in the VirtualBox program window, go back to its settings and enable the shared clipboard and Drag'n'Drop function (optional):
![Enabling clipboard and drag'n'drop](../assets/simulation_setup_vm/13_vbox_setup_clipboard.png)
* close the settings window by saving the changes using the "OK" button.
4. Start the virtual machine. Make sure that the functions of the VirtualBox add-ons are working.
* in the "View" menu, the "Screen integration mode" will be available to you, when you change the size of the virtual machine window, its resolution will adjust to the size of the window, so that you can work in Gazebo with large display resolutions;
* check the functionality of the *clipboard* content sharing function both when copying text from a virtual machine and from a laptop to a virtual machine;
* check the functionality of the Drag'n'Drop function by dragging a file from the laptop to the desktop of the virtual machine (*attention! if you are using Windows on a laptop, dragging files may cause crashes in the virtual machine, in which case it is recommended to disable this feature*);
* in the virtual machine menu "Devices | Shared Folders | Configure Shared Folders" add a new folder by selecting the path on the laptop (*attention! it is recommended to use folders with only Latin characters, for example `/home/galina/Workspace` or `c:\Users\galina\Documents`*):
![Setup shared folder](../assets/simulation_setup_vm/14_vbox_setup_sharedfolder.png)
* in the folder settings specify "Auto-connect" and "Create a permanent folder";
* close the settings window by saving the changes using the "OK" button.
* open the file manager, find a new folder in the upper Devices group, which will have a prefix `sf_`, for example `sf_galina`, create an empty file, make sure that the file appears in the laptop's file system:
![Working in shared folder](../assets/simulation_setup_vm/15_vbox_setup_sharedfolder_test.png)
* if any of the listed items does not work, repeat the steps listed in section 3 by re-installing and configuring the VirtualBox extensions.
5. Configure networking in the virtual machine. Changing the network mode in VirtualBox is possible in real time, you can choose any suitable option. See below for a list of options from which you can choose the one that will be most convenient for you in your work:
* **Connection type: NAT** - default mode. In this mode, your laptop creates a separate local network for the virtual machine, from which it can connect to the network (for example, download something from the Internet), but network nodes in the opposite direction will not be able to connect to the server on the virtual machine (for example, Raspberry Pi **will not be able** to connect to [clever-show](https://clover.coex.tech/ru/clever-show.html) server). The network IP address that the virtual machine will receive will be from the range generated by your laptop, for example `10.0.2.15'. This mode is identical to the conditions created by home routers, when your home computer can access the Internet, but computers from the Internet will not be able to access your computer on their own initiative (this feature must be configured and allowed).
* **Connection type: Network Bridge**. In this mode, the virtual machine connects to the network through your laptop *transparently*. Along with the choice of connection type, you are also asked to choose the name of the network interface related to the network of which the virtual machine will become a part. In this mode, the virtual machine will receive a network IP address related to your chosen network, for example, if your home router distributed addresses in the range `192.168.0.xxx`, then connecting the virtual machine to the router's network it would receive an address such as `192.168.0.100`. In this mode, inside the selected network, you are allowed to connect to any network node, and other nodes have the ability to connect to your virtual machine (for example, Raspberry Pi **will be able to** connect to [clever-show](https://clover.coex.tech/ru/clever-show.html) server).
To change the network type, go to the "Devices | Network | Configure network" menu item. Select the connection option that suits you, if necessary, select the name of the network connection, confirm the change using the "OK" button. To make changes to the network, select the menu item "Devices | Network | Connect the network cable", wait for the "Disconnected" notification to appear in the VM. Then select the "Devices | Network | Connect the network cable" menu item again, wait for the "Connection Established" notification to appear in the VM.
For example, switch the network to the "Network Bridge" mode by selecting the network interface corresponding to your WiFi adapter (by performing the above-recommended manipulation of reconnecting the "network cable"). Connect your laptop to a WiFi network with internet access.
![VirtualBox bridging through wlan0](../assets/simulation_setup_vm/16_vbox_network_bridge_wlan0.png)
Make sure that the address of the virtual machine is actually received inside a WiFi network with Internet access, and the Internet is available in the virtual machine.
```bash
ip a
ping ya.ru
```

![VirtualBox bridging into internet](../assets/simulation_setup_vm/17_vbox_network_internet.png)

In the screenshot above, the IP address of the virtual machine is the address `192.168.2.195` and it has Internet access because the server `ya.ru` is pinging.

Then [connect to Raspberry Pi via Wi-Fi](wi fi.md), repeat the above recommended manipulation of switching the "network cable".

```bash
ip a
ping 192.168.11.1
ssh [email protected]
```

![VirtualBox bridging into internet](../assets/simulation_setup_vm/18_vbox_network_clover.png)

In the screenshot above, the IP address of the virtual machine is the address `192.168.11.160`, it pings the Raspberry Pi with the address `192.168.11.1`, and can login into the microcomputer [via SSH](ssh.md). *There will be no Internet access on this virtual machine, because both it and the laptop have disconnected from the WiFi network with Internet access*. Without disconnecting from the Clover WiFi network, scan the network nodes connected to the network:

```bash
sudo nmap -sP -PR -T3 192.168.11.0/24
ip a
```

![Network scanning from VirtualBox](../assets/simulation_setup_vm/19_vbox_network_scan.png)

In the screenshot above, nodes have been found on the network:

* `192.168.11.1` - Raspberry Pi microcomputer;
* `192.168.11.117` - laptop with an Intel network adapter;
* `192.168.11.160` - the `clover-dev` virtual machine from which the scan was performed.

If all the checks listed above have been passed, then your virtual machine running in the VirtualBox environment is ready to work.

Loading

0 comments on commit e85b533

Please sign in to comment.