en
Language
  • en
  • cs
  • hu
  • it
  • es
  • fr
  • de
  • ru

Easy virtual machine (VM)

Introduction

This documentation is for virtual machines (VM) provided by Easy Software for Clients who bought Server solution. It is valid for VMs generated after March 1st 2022.

It may also serve as inspiration of your own server environment, but in such case there are no guarantees due to the variety of possible components and technologies you may be using.

The VM is configured just for small sites (cca 10 simultanously working users). VM is almost production ready but REQUIRES experienced administrator to install VM in your environment, set up backuping, monitoring, networking, security policies etc. Easy Software can not take responsibility for running of this VM in your dedicated environment, the VM is an example how the application can be hosted.
This README addresses "Application", which can be substituted by either "Easy Project" or "Easy Redmine".

First steps

Because the VM was generated at a certain point in time, it is possible that some components may have already released some patches or security fixes by the time you are deploying it.
That is why you should always start with a backup followed by update of the OS. It will install the latest security fixes and update possibly outdated components.

VM description

OS is Debian in 64-bit edition.

The important defaults are:

  • OS is available by SSH via port 22
  • Firewall is not set (it is up to system administrators)
  • The disk is ~100 GB
    • /boot 512M
    • /30G
    • /home 60G
    • swap 4G
    • to increase disk, use the available LVM
  • Application listens on HTTPS but with self-signed certificate, so you have to replace it ASAP (more details below)
  • Application is running in /home/easy/[application_name]/current.

Linux login:

  • username: easy
  • password: e4syPwd-

Please change it ASAP. To do so run command passwd in terminal

Mysql login:
Simply use command mysql your_app_name (all dots or dashes in application name should be replaced with underlines. Example: your-app-name should be your_app_name)

Application login:
Default login (in case of "clean" database) is:

  • username: admin
  • password: admin

The default login for the VM with the demo data is: 

  • username: manager
  • password: easy848

In case of database from your Cloud application, passwords remain as you had them.

Structure of the application's home

.
├── backups                 # backup script save data there
└── $APP_NAME
    ├── application.pid           
    ├── application.sock    # nginx uses this socket
    ├── config
    │   ├──                 # pregenerated application configurations  
    │   ├──                 # (database, mailing, secrets, app server, etc...)
    │   └── ...
    ├── current
    │   ├── config                 # all application configurations
    │   │    ├── configuration.yml # set up outgoing mail configuration here
    │   │    ├── database.yml      # database access configured here
    │   │    └── ...
    │   ├── files                  # persistent application data
    │   ├── log                    # application logs
    │   ├── public                 # static files
    │   └── version                # application version
    └── public_html -> /home/easy/$APP_NAME/current

Restarting the application is simply via "systemctl restart puma@[application_name]" as sudo

Customer responsibilities

The VM runs on the latest recomended version of Debian. The system requires common maintenance like:

  • regular updates
  • resource monitoring (free space, memory usage, load, ...)
  • data backups to an independent disk
  • security policies

Updates

Do security updates of the system frequently. We recommend to do it at least once per week. Before update please be sure that latest backup is available and working.

Official documentation how to run only security updates https://wiki.debian.org/UnattendedUpgrades

Resource monitoring

Easy Software has good experience with Prometheus. Therefore, the node_exporter is a part of the VM since the 1.3. 2022.

The official very basic documentation for Node Exporter and Prometheus is at https://prometheus.io/docs/guides/node-exporter/ The best quickstart grafana dashboard is at https://grafana.com/grafana/dashboards/1860

Depending on your usage you should tune the VM resource settings, for example increase amount of RAM or number of cores provided to VM. All these configurations should be regularly done by your virtual environment administrator.

Node exporter listens on port 9100.

Disable node_exporter

node_exporter could by disabled by running:

systemctl stop node_exporter.service
systemctl disable node_exporter.service
systemctl mask node_exporter.service

It prevents to start node exporter after next reboot...

If you need full environment support from Easy Software (security and performance optimizations, backuping, monitoring, etc), we recommend to transfer to our Cloud solutions.

Data backups

The preconfigured backuping that is present in the VM is a working example, that needs to be fit to your infrastructure and has to be monitored. Please keep in mind, that a proper backup should be:

  • checked after backup process finished (check at least the size of the backup)
  • kept in a safe place
  • distant from the running environment (at least in a different city)
  • restored once in a while to test your ability to perform recovery

The application stores data in two places, so don't forget to backup both of them.

DB

Database backup can be very easily done incorrectly. The best and the most secure way how to do backups of mysql database is via database dump as you can see in the example script. It makes version independent backups, that could be restored whole or allows you to get only part of the old data.

Example:

mysqldump --add-drop-tables --routines --triggers --flush-logs $DATABASE_NAME > path/to/file_where_db_will_be_stored.sql

Copying files from /var/lib/mysql is an INCORRECT way of saving DB backups.

Files

Every uploaded file/attachment in the application is stored in /home/easy/$APP_NAME/current/files. The whole content of this directory should be backed up. In this case, you can simply copy the contents.

Security policies

The VM contains SSH keys for Easy Software engineers in home/easy/.ssh/authorized_keys. Also, the rules for the iptables firewall in /etc/iptables allow access of an Easy Software IP address.

Both of these policies are meant for eventual remote support by our staff on your request. The access policies are fully under your control.

Automatic tasks

All automatic tasks are scheduled by CRON and Sidekiq, which starts scheduled jobs every 5m. We recommend don't to run these jobs in shorter intervals due to their high performance requirements. To make any changes, you can edit them by running command below under user easy

crontab -e

Detailed documentation for cron
https://www.easyredmine.com/resources/redmine-installation/common-troubles/cron-not-working-helpdesk-emails-alerts-repeating-tasks-etc-are-not-automatically-processed

Migrate data to this VM

How to import older Application or Redmine data (SOURCE) into VM (TARGET). This works in most cases, but this procedure may not work in case you use 3rd party plugins in your source Redmine instance.

1. from your (SOURCE) create MySQL dump file:

mysqldump --opt easy > backup.sql

2. transfer backup.sql into (TARGET)

3. go to Application folder on (TARGET)

cd /home/easy/[application_name]/current

4. recreate (TARGET) database

bundle exec rake db:drop db:create RAILS_ENV=production DISABLE_DATABASE_ENVIRONMENT_CHECK=1

5. import backup.sql

mysql [db_name] < backup.sql

6. transfer attachments and other files from (SOURCE)[redmine]/files into (TARGET)/home/easy/[application_name]/current/files

7. run:

bundle exec rake easyproject:install RAILS_ENV=production

8. restart application

sudo systemctl restart puma@[application_name]

Troubleshooting

Missing sidekiq

On some of the machines sidekiq@.service file is not added. Please check /etc/systemd/system folder if sidekiq@.service file is presented. If not - please add it. It should contain the next:


[Unit]
Description=SIDEKIQ service for %i
After=redis.service
PartOf=puma@%i.service unicorn@%i.service

[Service]
Type=simple
PIDFile=/home/easy/%i/sidekiq.pid

Environment=RAILS_ENV=production
Environment=MALLOC_ARENA_MAX=2

User=easy
Group=www-data
WorkingDirectory=/home/easy/%i/public_html

ExecStart=/usr/local/rvm/bin/rvm default do bundle exec sidekiq -e production
ExecReload=/bin/kill -s TSTP $MAINPID

Restart=always

[Install]
WantedBy=multi-user.target puma@%i.service unicorn@%i.service

After file is created run

sudo systemctl daemon-reload

restart puma

MYSQL Backups are targeted to wrong database

To fix this issue please open file /usr/local/bin/mysql-backups.sh and replace DB name "easy" to app DB (usually it's the same as app name but all dashes and dots should be replaced with underlines)

Try Easy Project in 30 days free trial

Full features, SSL protected, daily backups, in your geolocation