Skip to content

The steps i made to start up a server on a virtual machine

Notifications You must be signed in to change notification settings

chriss1245/born2beroot

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

18 Commits
 
 
 
 
 
 
 
 

Repository files navigation

Born2BeRoot

The steps I made to start up a server (based on Baigalaa's guide) on a virtual machine.

Storage limitation

There is a limitation in the size of all the folders except sgoinfre and goinfre folders. We must store our virtual machine at sgoinfre/students/login

There is also a limitation in sgoinfre. If we exceed the 15GB in sgoinfree. Your folder will be delated on the next day. So I recommend you to store the finished .vdi file in Google drive.

Operating System

We were told to choose between Cent OS and Debian I decided to choose Debian because of the community it supports it. While Cent OS is supported by the Red Hat company, Debian is more a hippie distro. In addition, Debian is one of the most popular and well stablished linux dstributions. Other distributions such as Ubuntu are Debian based.

One of the most significant differences between Debian and Cent Os is at the Linux Security Module (which handles the resources' permissions a program has). Cent Os implements SELinux whereas Debian implements AppArmor. AppArmor was designed to be more user friendly and works with profiles instead of a policy.

Installation

  • I created a new virtual machine using the latest version of Debian (11.2.0).
  • I created a boot partition of 500 MB mounted on /boot and a logical partition which will contain encrypted logical volumes in the LVMGroup.
    • Name Mount Point File System Description
      root / Ext4 The parent folder of the whole schema
      home /home Ext4 The folder where the users' information will be stored
      srv /srv Ext4 Site specific data server by the system
      tmp /tmp Ext4 Where the temporal files lie
      var /var Ext4 Contains variable files that the operating system reads and write in
      var-log /var/log Ext4 Contains the log files
      swap - Linux Swap Auxiliar storage if the RAM is full
  • I only installed ssh. Not graphical interface neither standard system utilities.

Sudo

sudo is a program tha enables a user to run commands as other user (root by default) getting access to all the privileges the other user has.

In order to install sudo it is needed to use the root user. The first thing to do is log as root and download sudo.

apt install sudo

In order to add the cmanzano user to the sudo group (so that it can run sudo)

usermod -aG sudo cmanzano

If we execute sudo -v we can check whether the user can run sudo. sudo

Now we need to stablish a strong policy for the sudo group.

sudo nano /etc/sudoers

It is recommended not to edit the suddores file. It is a good practice to edit the /etc/sudoers.d directory. There you can create more complex policies.

We have to complain with the following policies:

  • Authentication using sudo has to be limited to 3 attempts in the event of an incor- rect password.
  • A custom message of your choice has to be displayed if an error due to a wrong password occurs when using sudo.
  • Each action using sudo has to be archived, both inputs and outputs. The log file has to be saved in the /var/log/sudo/ folder.
  • The TTY mode has to be enabled for security reasons.
  • For security reasons too, the paths that can be used by sudo must be restricted. Example: /usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/snap/bin

Ufw

Ufw stands for Unclomplicated Firewall. It is a firewall xd. To install it.

sudo apt install ufw
sudo systemctl enable ufw
sudo systemctl start ufw
sudo ufw enable

To allow 4242 port:

sudo ufw allow 4242

SSH

SSH is a protocol that provides a secure way for users to connect to a computer over an insecure network (internet). We have been told to change the port (by de fault 22) to 4242 on the /etc/ssh/sshd_config file. In addition, we have to disable login as root throught ssh. In the same file we det the PermitRootLogin option to no.

In order to allow ssh connections to the virtual machine it is also needed that we enable port forwarding at the network settings. Finally we can connect from our computer's terminal by:

ssh [email protected] -p 4242

Passwords Policy

We were told:

  • Your password has to expire every 30 days. PASS_MAX_DAYS 30
  • The minimum number of days allowed before the modification of a password will be set to 2. PASS_MIN_DAYS 30
  • The user has to receive a warning message 7 days before their password expires. PASS_WARN_AGE 7

We can apply these rules by modifying the file /etc/login.defs

sudo nano /etc/login.defs
  • Your password must be at least 10 characters long. It must contain an uppercase letter and a number. Also, it must not contain more than 3 consecutive identical characters minlen=10 ucredit=-1 dcredit=-1 maxrepeat=3
  • The password must not include the name of the user. reject_username
  • The following rule does not apply to the root password: The password must have at least 7 characters that are not part of the former password. difok=7
  • Of course, your root password has to comply with this policy enforce_for_root

In order to apply the remaining requirements we need to install the libpam-pwquality packege and edit the common-password file found at the /etc/pam.d/ directory.

sudo apt install libpam-pwquality
sudo nano /etc/pam.d/common-password

Users

To add a new user we use:

sudo adduser <user>

To check agin information of the user:

sudo chage -l <user>

Groups

Groups are collections of users. You can grant privileges to a group instead of doing with each user. To create a group we execute:

sudo addgroup <group>

To add user to groups we can do by typing:

sudo adduser <user> <group>

Note:

To check whether an user belongs to a group we can do.

sudo groups <user>

Monitoring

We have to schedule a script monitoring.sh which executes a shell command to gather some information each 10 minutes.

In order to do this we are going to use the systemd.time which is a systemd functionality which allows to scheduele tasks as cron but it is more powerful. Because cron only can schedule based on the current time whereas systemd.time can schedule based on boot time and current time. For our task. We need to run monitoring.sh each 10 minutes from boot time.

In order to use systemd.timer we need three files:

  • monitoring.timer
  • monitoring.service
  • monitoring.sh

monitoring.timer will contain the scheduling information. There we are going to specify that the task has to be executed each 10 minutes. The .timer files can trigger .service files. Thus we need to have a monitoring.service file. At monitoring.service we specify which script to execute and which is the user that executes it (for permissions). Finally the script monitoring.sh will contain a script that gives a detailed information of the system.

Webserver

As an additional thing to do we were told to set up a wordpress server on lighttpd with php using mariadb as database. In order to do this we need to install the following things:

sudo apt install lighttpd mariadb-server php-cgi php-mysql wordpress

Where:

  • lighttpd: is the web server
  • php: is the backend
    • php-cgi: is a translator among php and lighttpd
    • php-mysql is a translator among php and mariadb
  • mariadb: is the database
  • wordpress: is a content management system which allows non developers to add and remove content from the web page.

In addition we need to install curl which allows us to download documents from url.

wordpress is a content management system. It is useful for adding content to the web page withot the need of programming knowledge.

sudo apt install curl

Lighttpd

Lighttpd is a daemon program. In other words, it is a program which isruns as a backgroud process. The web servers like lighttpd use by convention the port 80. We need to open it.

sudo ufw allow 80

MariaDB

MariaDB is a Relational Database Management System. It provides an SQL (Structured Query Language) interface to manage relational databases. Also it can handle users and permissions.

When we install mariadb-server we also install a script called mysql_secure_installation. We have to execute it in order to continue with the installation.

sudo mysql_secure_installation

The script will start asking you questions related with the configuration of the database. In principle you can anwser to all yes. (I answered not when they told me to change the password and changing to unix socket authentication)

By default there will be just one user: root. To access to mariadb:

sudo mariadb

To create a database:

CREATE DATABASE db42;

It is a good practice to create an specific user for the web server and giving only the required permissions intstead of using root.

CREATE DATABASE web42@localhost IDENTIFIED BY 'password';
GRANT ALL PRIVILEGES ON db42.* to 'web42'@'localhost';
FLUSH PRIVILEGES;

To exit from mariadb:

exit

Wordpress

Once installed. There will be a folder which contains the required files in order to make the lighttpd sever work. We just have to copy them to the folder that the lightttpd server reads

sudo cp -r /usr/share/wordpress/ /var/www/html/

We have to stablish a configuration file. There is already an example of it in the files we just coppied. We are going to use it:

sudo cp /var/www/html/wp-config-sample.php  /var/www/html/wp-config.php

But we still need to specify the user and the database wordpress is connecting to. We have to edit thses things in wp-config.php

define( 'DB_NAME', 'db42' );
define( 'DB_USER', 'web42' );
define( 'DB_PASSWORD', 'web42' );

Next we have to load the new configuration for lighttpd:

sudo lighty-enable-mod fastcgi
sudo lighty-enable-mod fastcgi-php
sudo service lighttpd force-reload

Finally we have to go to settings on the virtual box and enable port forwarding for the port 80 -> 80.

You can access to it by typing http://127.0.0.1:80 on your web browser.

After creating an user, you can start blogging.

Additional command you may need

Command *Description
sudo getent group List all the groups
sudo getent passwd List all the users

About

The steps i made to start up a server on a virtual machine

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages