2015-09-27

After the initial setup of cPanel server the server is not very secure and there are many things that can be done to secure your server.

In this tutorial we will go over some steps that include few software installation and web server security settings modification.

The collection of these easy steps is a results of years of experience in maintenance and management of linux servers.

1) Updates & Installation

Update cPanel to the latest version from the WHM interface:

Navigate to: Home » cPanel » Upgrade to Latest Version

Next, install the Apache mod_security with EasyApache:

Navigate to: Home » Software » EasyApache (Apache Update)

On step 4 check the “Mod Security” option and click the “Save and Build” button.

Next, login to the cPanel server as root via SSH and run OS update, then install some softwares from ConfigServer:

2) Use The Security Advisors

If your cPanel version is 11.42+ and CSF is installed on your server there is two Security Advisors on your server that will check the security level of your server and will suggest recommendations on how fix the security issues.

For cPanel Security Advisor navigate to:

Home » Security Center » Security Advisor

For ConfigServer Firewall Security Advisor navigate to:

Home » Plugins » ConfigServer Security & Firewall » Check Server Security

* Follow all the recommendations and make the necessary changes to fix your server security issues.

We recommend to run the Security Advisors at least once a month.

3) Web Server Security & Firewall (ModSecurity)

Our choice for Mod Security rules is the Comodo Web Application Firewall (CWAF) agent. The cPanel\WHM plugin automate the installation & configuration of CWAF on the server and the deployment of periodically published predefined firewall rules set updates.

1) To get access to Comodo Mod Security rules and CWAF free sign up is needed:https://waf.comodo.com

2) To download the comodo client agent login to the web administration console and click the “Download latest installer” link (top right of the screen) “cwaf_client_install.sh”.

3) Copy the agent setup file to a local directory in the server E.g. /root

4) Run the installation script as root via SSH:

Follow the instructions in the setup wizard!

Next edit mod_security conf file and include the CWAF Rules.

And add this line:

The file should look like this:

5) Now login to WHM as root and navigate to:

Home » Plugins » Comodo WAF

At the “Main” tab you can run updates if needed,

At the “Catalog” tab you can set or unset rules for all vhosts or for a singel domain.

6) Restart Apache

7) Set new Apache configuration:

Home » Service Configuration » Apache Configuration » Global Configuration

Change to:

Then clicking on “Save”

8) Set new PHP configuration:

Home » Service Configuration » PHP Configuration Editor

Select the “Advanced Mode” and set the following settings:

9) Restart Apache

10) Enable failure detection of repeated Apache mod_security rule triggers

Navigate to:

Home » Plugins » ConfigServer Security & Firewall » Firewall Configuration

And set the number of failures between 3 and 5 by changing the value:

LF_MODSEC = 3

4) Tweaks

a) Install and config “tmpwatch”

Edit the tmpwatch cron file:

The file should look like this:

b) Disable Compilers for all accounts from:

Home » Security Center » Compiler Access

c) Disable Anonymous FTP & Logins with root

Home » Service Configuration » FTP Server Configuration

d) eXploit Scanner

The eXploit Scanner is the best tool out there for detecting malicious code on the server and for real time detection while files are uploaded to the server.

eXploit Scanner detecting malicious code uploaded real time and deny the upload and blocks the IP address from which the file is upload.

1) Install ClamAV:

Home » cPanel » Manage Plugins

Select “clamavconnector” and Seve.

2) The “eXploit Scanner” is not free, but worth every cent. Buy license at:

http://configserver.com/cp/cxs.html

3) Once you received the confirmation email of the activation of the license you can start the installation of the eXploit Scanner plugin:

4) Enable the pure-ftp upload script:

5) Edit the config files and comment any exiting line with # in this files:

Edit cxscgi.sh file:

6) Create Cron jobs via the UI from:

Home » Plugins » ConfigServer eXploit Scanner

Click on “Edit Cron Jobs” and add the command:

/usr/sbin/cxs –mail root –exp –vir -I /etc/cxs/cxs.ignore -X /etc/cxs/cxs.xtra -Q /usr/suspicious_files –options mMOLfSGchexdnwWZDRPu –qoptions Mexv -Z –sum -S 1000000 -F 10000 -C /var/clamd -T 2 –MD5 -B –allusers

Add the auto update cron command:

/usr/sbin/cxs –upgrade –quiet

Create the cxs suspicious files folder:

mkdir /usr/suspicious_files

* Enable detection of repeated cxs and mod_security rules trigger. This option will block the user IP address if cxs or ModSecurity triger is detected.

Navigate to:

Home » Plugins » ConfigServer Security & Firewall » Firewall Configuration

And set: LF_CXS = 1

* The files “/etc/cxs/cxs.ignore” and “/etc/cxs/cxs.xtra” are used to include or exclude files from scanning by the file name, regular expression match or md5sum match.

For more information go to: http://configserver.com/cp/cxsdemo/cxs_help.html

Finally we finished securing your server!

Enjoy.

IMPORTANT NOTE!

* Know that security is not optimization. It will take more resources from the server!

* This guide is not a complete solution for server security. Only the main first steps in the process of securing your server are covered!

Show more