Plesk 11 to VM – Part 2: Bare server set up

Intro

In this series of best practice articles I talk about migrating websites and emails from a Plesk 11 managed server to a Virtualmin managed server. It describes in some details the steps involved in doing it remedy the pitfalls and other things I came across whilst doing it. Note that this documentation is address to people with medium expertise in linux/system administration.

Hardware

A fresh install of a super fast multi-core web server with sufficient RAM and [Hardware] RAID 1 partitioned as follow:

  • / = 12GB
  • /swap => RAMx2 (recommended) however I set it to RAMx1 as the RAM rarely “swaps”.
  • /var = 1/2 of the rest of the space
  • /home = 1/2 of the rest of the space.

As I have a few websites to run, a 250GB HDD was my choice, so /var and /home are about 100GB each which gives me more than enough space for the moment, bearing in mind that one can always increase this easily by swapping bigger RAID mirrors one after the other followed by a quick partition resize.

Partitions allocation

I chose to split /var and /home from / because:

  1. /home will contain all the websites and emails
  2. /var usually contains log files, firewall, partition, users information etc.
  3. /var will contain an image backup of /home and /

Backup

The RAID 1 disk setup pretty much solves the “disk failure” challenge, but not data loss due to human error (or otherwise). So a solid backup strategy is essential. My plans are currently to have an image snapshot made of the bare server before adding websites, to do this I have been quite impressed by the backup products from Idera, more particularly “Server Backup” which is free with some disabled features (like remote backups management), however I feel it might be a little too much for me, I really need a simpler interface to use, that is why I was initially interested in their “Hot Copy” product, which I haven’t tested yet. With Hot copy, I would take a snap shot of /home on /var and vice versa which I would then upload to a backup server. Simple and neat. Please note that Idera (now R1soft) does not distribute hot copy any more.

Providing that Hot Copy does not interfere with the OS too much (I like the OS to remain “as is” to avoid conflicts (like Plesk has recently given me with Emails refusing to be send using Qmail, only Postfix worked, one of the reason I give up on Plesk. Too much interfering).

Initial Steps

The very first thing to do on a brand new server is:

      1. Check that the IP address [range] is not Blacklisted for sending spam
      2. Set the hostname (/etc/hosts and /etc/sysconfig/network) and Reverse (PTR) pointer accordingly (the PTR must be set by your provider on their DNS servers)
      3. Install rkhunter and run it with
        rkhunter -c --update --propupd

      4. Change SSH port and activate passwordless authentication
      5. Install Virtualmin (best way is to download the install.sh with wget, make it executable chmod +x install.sh and run it ./install.sh) and customise the Directoryindex directive and the Primary Default Website you may also do additional customisation outlined here (page to be created)
Terminal window with install.sh in progress
Terminal window with install.sh in progress
  • Install Configserver’s csf and use their security checker to harden the appliance
  • install hotcopy  no longer available 🙁
  • change the root email account to send all server notices to your current email address (Webmin > Servers > Postfix… > Mail aliases > root -> your email (*and enable account also).
  •  Non essential installs (but recommended)

    In addition to the above minimum installs. Here are a few more things that, I reckon is a good idea to have:

    screen

    Screen is a great app when working with ssh, it allows you to close your terminal window without losing your remote session, screen “attaches” terminal window to your terminal and “detaches” itself when you close your window (or your office internet connection drops for whatever reason), this is particularly useful when you don’t want to leave your terminal opened when a long process is being run (like a backup etc.).

    tree

    tree is used by one of my perl scripts to do fast, recursive line replacements in files within a directory.

    Use yum to install any additional applications, like:

    yum install screen tree

    Server stats – Munin

    I used to have HotSaNIC on my previous dedicated, however since this application is over 10 years old now, it’s a little arduous to install. After having tested two alternatives, namely Nagios and Munin, I went for Munin.

    Munin is exactly like Hot Sanic but with more graphs than you can shake a stick at. However installing Munin on Centos 6 is not a straight forward thing, an additional (epel) repository the must be added.

    cd ~
    wget http://dl.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm
    rpm -Uvh ~/epel-release-6-8.noarch.rpm
    yum install munin munin-node

    Important!: The Epel repository must be disabled after the install otherwise Virtualmin updates incompatible packages resulting in some application no longer working

    To disable the epel repository, edit /etc/yum.repos.d/epel.repo and change enabled=0 to 1 under the [epel] section:

    [epel]
    ....
    enabled=0 #(was 1)
    ...

    Normally Munin installs everything pretty much as it should, all I had to do is create a username login and password (below the username is Munin, but it could be anything, like admin, joe etc.):

    htpasswd -c /etc/munin/munin-htpasswd Munin

    The default location for the Munin graphs are under /var/www/html/ (VM default), to enable access to this folder, this httpd.conf hack must be done. Otherwise the munin.conf must be changed accordingly.

    Start Munin and at boot

    Start munin manually:

    service munin-node start

    Munin does not start at boot by default, this is why it must be enabled with:

    chkconfig munin-node on

    After  5 minutes, pages will populate the /var/www/html/munin directory, that is 5 minutes by 5 minutes information about the server from the moment you start it. Forever.

    A graph zoomed right in at the beginning of the monitoring session

    Post install snags

    Once all the above is installed it’s time to run some tests. To this end it is best to create a virtual server to check all is working as it should, in my case, it almost always involves the hostname and email (Postfix) service.

    Issue 1: Setting a hostname up

    The most important aspect of a web server, yet the bit that always catches everyone with little experience in the field. In a brand new server, the hostname can be anything the Sysadmin has decided to use by default for its server pool install. So it must be changed.

    The command to check the current hostname is:

    # hostname
    somename

    Where “somename” is the current name of the host that needs changing

    To set a new hostname and make it coherent for the appliance, two files must be edited:

        • /etc/hosts
        • /etc/sysconfig/network

    /etc/hosts

    The default entries in /etc/hosts are usually:

    127.0.0.1   localhost.localdomain localhost4 localhost4.localdomain4
    ::1         localhost.localdomain localhost6 localhost6.localdomain6

    A third line must be added with the hostname and IP address (i.e. hostname = some.domain.net & IP = 111.222.001.111):

    127.0.0.1   localhost.localdomain localhost4 localhost4.localdomain4
    ::1         localhost.localdomain localhost6 localhost6.localdomain6
    111.222.001.111 some.domain.net

    /etc/sysconfig/network

    The other file is /etc/sysconfig/network which should look like:

    NETWORKING=yes
    HOSTNAME="some.domain.net"

    Where “some.domain.net” is your Fully Qualified Domain Name (FQDN)

    Addendum: The above is not required for Ubuntu distros.

    Ubuntu and SMTP/Postfix

    For this type of distro. edit /etc/postfix/main.cf and change the myhostname to the correct FQDN as above.

    The above will not be taken in consideration immediately but after a reboot (and also restart/reload Postfix configuration, for Ubuntu), to avoid rebooting and set the hostname immediately simply type:

    hostname some.domain.net

    Issue 2: Postfix and SMTP

    I always have trouble with emails, it’s a total mystery to me as to why it should be so much of a pain in the backside to get working. There’re almost always problems with email service! (at least for me).

    Summary of possible problems

    In my latest install here are the errors reported by Virtualmin I encountered:

        1. postfix: fatal: parameter inet_interfaces: no local interface found for {IP address here}
        2. The procmail command /usr/bin/procmail is owned by group mail, when it should be owned by root. Email may not be properly delivered or checked (….)
        3. The sending of emails via SMTP (SSLTLS/plain password on port 587) was timing out.
        4. Automatic BCCing of outgoing email cannot be enabled unless a BCC map is defined in the Postfix Mailserver module, or manually in the Postfix configuration file. Otherwise it must be turned off on the module configuration page.

    Below are the lines that needed replaced (or added) to sort issue 1 to 3 – stop postfix first!:

    Note that a backup of any files before editing is RECOMMENDED. In my case I did a hotcopy first :-).

    For /etc/postfix/main.cf:

    inet_interfaces = localhost 
    changed to >>
    inet_interfaces = all
    ---
    mailbox_command = /some/where/procmail 
    changed to >>
    mailbox_command = /usr/bin/procmail-wrapper -o -a $DOMAIN -d $LOGNAME
    
    Added:
    ======
    smtpd_sasl_auth_enable = yes
    broken_sasl_auth_clients = yes
    smtpd_recipient_restrictions = permit_mynetworks permit_sasl_authenticated reject_unauth_destination
    mailbox_size_limit = 0
    allow_percent_hack = no

    For /etc/postfix/master.cf:

    smtp      inet  n       -       n       -       -       smtpd
    changed to >>
    smtp  inet    n       -       n       -       -       smtpd -o smtpd_sasl_auth_enable=yes
    ---
    Added :
    =======
    submission    inet    n       -       n       -       -       smtpd -o smtpd_sasl_auth_enable=yes

    Note: the above provided for info only, no responsibility held in any events, I had tried just about everything when I recalled that I luckily had a fully operational VPS from which I simply copied the master.cf and main.cf without forgetting to change the “mydestination” option to the correct hostname, it did the trick.

    Below is the changes made to fix issue 4:

    Automatic BCCing of outgoing email cannot be enabled unless a BCC map is defined in the Postfix Mailserver module, or manually in the Postfix configuration file. Otherwise it must be turned off on the module configuration page.

    In VM Go to Webmin > Servers > Postfix Mail Server > BCC Mapping and set the Sender BCC as follow (mine was “No Map Set”):

    bccmapping

    Once all is set as it should a nice message from VM:

    .. your system is now ready for use by Virtualmin.

    Optional security and administration steps to harden server

        • Enable passwordless SSH
        • Change Webmin default port (10000) to a different one (here is set to 5555) make sure it does not clash with a port already in use!
    changewebminport

        • Set root email alias to forward system emails to your admin email of sort, when set, all root emails, firewall , schedules etc.. will sent to the email provided, quite handy to keep tab on the server activity.
    postfixrootemailalias

        • Restrict Webmin access to specific IP addresses
    webminipaccesscontrol

    One thought on “Plesk 11 to VM – Part 2: Bare server set up”

    Comments are closed.