Crossbox Server PDF
Crossbox Server PDF
Crossbox Server PDF
Requirements
Quick Installation
Options in Details
Admin Area
Command Line Tools
Performance Tuning
Uninstall
Requirements
Standalone Version
1 CPU or vCPU
512 MB of RAM
5GB of Disk Space
Don't forget to plan out the disk space which will be used to store
emails, attachments, files and other storable objects by the users.
RedHat/CentOS/CloudLinux 6+
Ubuntu 12.04+
Debian 7+
Fedora 13+
OpenSUSE 11.3+
ArchLinux
Slackware
MySQL
Exim
Dovecot
MailScanner
ClamAV
CSF
Firewalld
UFW
Solr
This effectively reduces the total memory needed for CrossBox to run to
just 512 MB of RAM, when used alongside the control panel.
However, you can still use CrossBox with any control panel due to its plug and
play nature but some functions are not automated and may require a manual
action.
Software Dependencies
You don't need to install any new software dependencies for
CrossBox to work as it uses its own packages and libraries which are
prebuilt and shipped with CrossBox.
This means that we will not install any software via your system's package
manager (like yum, apt-get, pacman, etc) and will never interfere with
other software you may already have running on the server.
Other Dependencies
Hostname
Make sure that before installing CrossBox your server has a resolvable
hostname.
We recommend that the server has a valid PTR (Reverse DNS) record that
matches the server's hostname.
A valid PTR record is important for good e-mail delivery.
Most VPS/Dedicated server providers allow you to edit a PTR record via the
control panel they provide.
Root user
A root user account and SSH access are required to install a CrossBox
Server.
Home Directory
Let's start
Are you ready to get started?
Continue to Quick Installation Guide and have CrossBox up and running in
under 5 minutes.
Quick Installation
Intro
We know that you're excited about installing CrossBox, but first please make sure
that you checked out the Requirements before you start with the installation.
Sign Up
To install CrossBox you need to have a valid CrossBox.io account and an active
license. You can create an account with a 30-day free trial license here .
After a successful login, you'll find the URL that you can now use to start the
installation via your web browser:
STEP TWO
Open your favorite web browser and paste the URL you
copied
STEP THREE
After accepting the End User License Agreement and selecting a license,
installing CrossBox is as easy as filling in some basic details.
Almost everything is already pre-populated for you and the entire process takes
about five minutes or often less, depending on your server's performance.
Detailed Help
If you're not sure what to enter in a certain field during the installation, just click
on the "Learn more" link which is displayed beneath it:
STEP FOUR
After you click the " Install" button, CrossBox will start setting everything up. You
can track the progress in real-time as shown below:
STEP FIVE
After the installation finishes successfully, you'll see a link which leads you to your CrossBox
App.
Options in Details
Server
Tweaking CrossBox Server to fit your needs is as easy as enabling and disabling
features with a simple checkbox click. CrossBox will auto-detect if some kind of a
control panel is already installed on the server and will auto-adjust itself. Here we
have listed all the options and associated help descriptions.
Hostname
CrossBox will try to automatically resolve a hostname of the server it's
being installed onto.
However, make sure that before installing CrossBox you have a valid PTR
(Reverse DNS) record that matches your hostname and that your hostname can
be successfully resolved.
Public IP Address
You can skip this option if you're installing CrossBox on port 80 (HTTP) and
port 443 (HTTPS), or you don't mind accessing CrossBox via a port in the
URL.
If you are installing CrossBox on a port different from 80 or 443, you can reverse
proxy via a domain that you enter here. This is useful if you have something like
a website already running on ports 80 and 443, but you still want to access
CrossBox without entering a port in the URL.
However, if you don't like having a port in your CrossBox URL, you may enter a
domain (or a subdomain) from which you can reverse proxy to CrossBox. In the
above example, you would install CrossBox on server.my-domain.com:1703 and
then you would reverse proxy from some-domain.com to server.my-
domain.com:1703. By entering some-domain.com as a Reverse Proxy URL, you
are telling CrossBox to allow connections coming in from some-domain.com. This
will give you the ability to access CrossBox without entering a port and just by
visiting HTTP(S)://some-domain.com.
CrossBox by default runs only an SSL version. The following configuration will:
# HTTP
<VirtualHost *:80>
ServerName some-domain.com
# Redirect any HTTP request to HTTPS
RewriteEngine On
RewriteCond %{HTTPS} off
RewriteRule (.*) https://%{SERVER_NAME}/$1 [R,L]
</VirtualHost>
# HTTPS
<VirtualHost *:443>
ServerName some-domain.com
SSLEngine on
SSLCertificateFile /path/to/your/certificate.crt
SSLCertificateKeyFile /path/to/your/certificate.private_key
SSLCertificateChainFile /path/to/your/certificate/chainfile.crt
# Reverse proxy configuration
<Location />
ProxyPass http://127.0.0.1:1703/
ProxyPassReverse http://127.0.0.1:1703/
</Location>
</VirtualHost>
Make sure you modify ServerName, certificate parts, and CrossBox port to match
your own installation. Note that some-domain.com is the domain you are reverse
proxying from.
It is also possible but not advisable to do a reverse proxy from a .htaccess file by
using mod_rewrite:
RewriteEngine on
RewriteRule (.*) https://127.0.0.1:1703/$1 [P,L]
server {
listen 80;
server_name some-domain.com;
charset utf-8;
# Redirect any HTTP request to HTTPS
return 301 https://some-domain.com$request_uri;
}
server {
listen 443;
server_name some-domain.com;
charset utf-8;
ssl on;
ssl_certificate /path/to/your/certificate.pem;
ssl_certificate_key /path/to/your/privkey.pem;
# Reverse proxy configuration
location / {
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-Proto https;
proxy_set_header X-Forwarded-For $remote_addr;
proxy_set_header X-Forwarded-Host $remote_addr;
proxy_pass https://127.0.0.1:1703;
}
}
App Port
Enter a Port number that CrossBox will bind to and listen on. If you are using the
server only for CrossBox, and you don't have anything else running on ports 80
and 443, you can safely use those. If, however, these ports are already taken, you
can enter a custom Port number. In the case when you have to use ports
different from 80 and 443, but you still want to access CrossBox without entering
a port in the URL, you can do so by making a Reverse Proxy URL.
You will not be in able to change the App Port after the installation.
WebSocket Port
WebSocket service serves as message passing between the server and various
connected clients. The default WebSocket Port is 8349.
You will not be in able to change the WebSocket port after the installation.
SSL
We strongly recommend that you enable the SSL feature. Not only it will help
protect data being sent over the network from prying eyes, it is also needed for
audio and video calls to work. It is very easy to set up and you have four options
to choose from:
TURN/STUN Server
CrossBox uses Coturn as a fast and reliable TURN/STUN server. It is responsible
for streaming audio and video data during the CrossBox audio/video conference
and for relaying media traffic when persons attending the call can't reach each
other directly via a peer-to-peer protocol. This is most often the case when the
person is behind a corporate firewall.
Overall, enabling a TURN/STUN server will greatly improve the quality of audio
and video calls. The CrossBox Installer will give you the ability to choose if you
wish to enable TURN/STUN integration and will also allow you to decide where it
should be hosted. You can choose to install it on the same server as CrossBox or
you can enter an external server to offload audio and video streaming to a
separate machine in the case you have thousands of concurrent calls being
made.
If you plan on having more than 50 people streaming audio and video at
the same time, please make sure that you allocate enough CPU/Network
resources for your TURN/STUN server. The other approach would be to
offload media streaming to a Coturn server hosted on another machine, by
choosing "Use external coturn server" and filling in Host and SSL Host
fields.
Coturn Port
Enter an SSL port that Coturn will use. The default Coturn SSL port is 5349.
Updates
CrossBox has a built-in update system that keeps your installation up to date and
automatically updates CrossBox when new updates are available.
Application Limits
Max Number of Workers
Max number of CPU cores that the application will utilize. Depending on the
application traffic/usage you can specify a maximum number of workers based on
the number of cores your server has.
CrossBox Administration
Admin Username
The default is "admin".
Admin Password
This password should be very complex.
MySQL
Use CrossBox MySQL database
Enable if you don't have a MySQL server already running on the server. If you
enable this feature, CrossBox will use its own MariaDB server for storing users'
data. Otherwise, it will try to connect to a MySQL server already running on the
system and use that server for storing data.
Mail
Enable mail server integration
CrossBox has two ways of integrating with a mail server:
1. Use the mail server already running on the machine (when installing on a
cPanel/Plesk server)
2. Automatically install and set up a CrossBox mail server (when installing a
bare metal/standalone version)
In the first case, the installer will try to find locally available IMAP/SMTP servers
and use those for everything related to email.
In the second case, you'll be able to enable or disable following mail server
features:
Features
Google Analytics
To track App usage in real time you need to enter a valid Google Analytics
Tracking ID in UA-XXXXX-Y format.
Branding
Branding is a great way to white label CrossBox as your own product or service.
You can give it a custom name, upload your own logo and change the color
scheme to best match your brand. Also, branding addon allows you to have a
fully branded CrossBox Client Apps (Web, Desktop, Android & iOS).
App Name
Enter a custom name for the application.
App Description
Enter a custom Application slogan or a motto. This is usually shown beneath the
App Name.
Default Language
Choose a default language for the App. If you want to add your own language,
you can do so by translating a language file and sending it back to us. We will
then ship it with the next App update.
Theme
Lets you brand the App with your own color scheme. Apart from that, you can
also upload your own App logo. Image for the logo should be in a PNG format
with 1024x1024 px dimensions. CrossBox will then use that image to create logo
versions of different dimensions used throughout the application.
Push Notifications
This enables push notifications for your branded CrossBox Android and iOS Apps.
They keep your end users up to date with new emails, chats, calls, files, and
reminders.
When using FCM, you need to obtain FCM Sender ID and FCM Key.
Please follow this blog post to find out how to obtain these.
If, however, you must use GCM, then you'll need to fill in GCM Sender ID and
GCM Key. To obtain these, please start here.
We do not recommend using APNs, use FCM instead. If you insist on using APNs,
then you'll need to obtain APNs certificate as explained in "Generate an APNs
client TLS certificate" and then upload it by using "Upload APNs Certificate"
upload box during the installation.
Admin Area
Intro
CrossBox features a simple to use administration interface which is used for
managing a CrossBox server.
Replace hostname and port with those you specified during the
installation.
Replace area in the URL if you chose a custom Admin Area URL during the
installation.
Adding a Domain
When using CrossBox for cPanel or Plesk, this is already automated with
hooks. When a new cPanel/Plesk user is created, the domain being created
is automatically added to CrossBox if the cPanel/Plesk user has CrossBox
enabled.
Simply log in to your CrossBox Admin Area and manually add domains that you
wish to have CrossBox enabled.
An account is a Linux user which you wish to associate with the domain.
A name is domain's name.
After you click Save, the domain you specified will be allowed to use
CrossBox.
When submitted, the form will also output DNS records for DKIM, SPF, and
DMARC. Make sure you add these to your domain's DNS zone to maximize
e-mail deliverability.
This feature is only available in the standalone version.
Make sure that the domain you are creating has MX records pointing to
an IP address of the server which is running CrossBox.
When using CrossBox for cPanel or Plesk, this is already automated with
hooks. When a cPanel/Plesk user creates a new e-mail address, the e-mail
address which is being created is automatically added to CrossBox if the
cPanel/Plesk user has CrossBox enabled.
If you are using CrossBox with a control panel which is not officially
supported, you can skip this step. This is possible because CrossBox will auto
create a CrossBox Account when a user logs in with an e-mail
address/password combination which is recognized as a correct one by a local
mail server.
After you click Save, the CrossBox user you specified will be created along
with a fully functional e-mail address.
This feature is only available in the standalone version.
Managing a Server
To manage a CrossBox Server login to your Admin Area, pick a server you wish to
manage and click "Manage".
Easy to use Admin Interface lets you stay in full control over:
Domains
Users
Devices
System Accounts
Changing Server's Settings
To change the CrossBox Server Options, login to your Admin Area, pick a server
you wish to modify and click "Settings".
crossbox stop|start|restart|status
Updating
crossbox update
crossbox update-slaves
Perform a manual update of CrossBox slave servers, provided that the command
is run from the master server.
Logs
Displays all logs in real time. If it's too verbose, try using crossbox <service> log.
--paths
displays locations of log files on the system
--lines
defines a number of "last lines" to display for each log file
Service Specific
You can also specify several <services> by separating multiple services from the
list below with a comma:
redis
mysqld
exim
dovecot
opendkim
rspamd
freshclam
clamd
turnserver
uwsgi
webserver
Medic
crossbox medic
CrossBox Medic will collect all the relevant CrossBox logs from your server, send
them to us and give you a unique key which you can reference when requesting
support.
Utility
crossbox info
Allows you to view WebSocket and task queue statuses. This will also show you
how many users are connected to the server.
crossbox change-admin-password
crossbox change-admin-email
Imports cPanel RoundCube contacts to CrossBox (useful for users migrating away
from Roundcube).
crossbox changelog
Debugging
You can enable the debug mode if you are faced with a bug and you want to find
out more about what the application is doing.
Use unsafe mode only when you don't see anything indicating a problem. When
using the unsafe debug mode the application may leak information, so use it with
care.
NOTE: Changing the debug mode will restart all CrossBox services.
Performance Tuning
CrossBox Server
Max Number of Workers
Increase the number of workers by setting Max Number of Workers to your total
CPU count. This will allow CrossBox to utilize a multi-core processing. For
example, if you have a server with 8 CPUs, set this to 8.
Remember that each worker also allocates 70-100 MB of RAM. Multiply this by a
number of workers and you'll get the total amount of additional RAM which the
change of this setting will require.
Linux Server
For a high-performance system trying to serve thousands of concurrent network
clients, default Linux kernel parameters are often too low. Consider making
following changes
Increase max open files to 100,000 from the default (typically 1024). In Linux,
every open network socket requires a file descriptor. Increasing this limit will
ensure that lingering TIME_WAIT sockets and other consumers of file descriptors
don’t impact our ability to handle lots of concurrent requests.
Decrease the time that sockets stay in the TIME_WAIT state by
lowering tcp_fin_timeout from its default of 60 seconds to 10. You can lower this
even further, but too low, and you can run into socket close errors in networks
with lots of jitter. We will also set tcp_tw_reuse to tell the kernel it can reuse
sockets in the TIME_WAIT state.
Increase the port range for ephemeral (outgoing) ports, by lowering the
minimum port to 10000 (normally 32768), and raising the maximum port to
65000 (normally 61000). Important: This means you can’t have server
software that attempts to bind to a port above 9999! If you need to bind to a
higher port, say 10075, just modify this port range appropriately.
Increase the read/write TCP buffers ( tcp_rmem and tcp_wmem ) to allow for larger
window sizes. This enables more data to be transferred without ACKs,
increasing throughput. We won’t tune the total TCP memory ( tcp_mem ), since
this is automatically tuned based on available memory by Linux.
Decrease the VM swappiness parameter, which discourages the kernel from
swapping memory to disk. By default, Linux attempts to swap out idle
processes fairly aggressively, which is counterproductive for long-running
server processes that desire low latency.
Increase the TCP congestion window, and disable reverting to TCP slow start
after the connection is idle. By default, TCP starts with a single small segment,
gradually increasing it by one each time. This results in unnecessary slowness
that impacts the start of every request – which is especially bad for HTTP.
Kernel Parameters
To start, edit /etc/sysctl.conf and add these lines:
# /etc/sysctl.conf
# Increase system file descriptor limit
fs.file-max = 100000
Since some of these settings can be cached by networking services, it’s best to
reboot to apply them properly ( sysctl -p does not work reliably).
# /etc/security/limits.conf
# allow all users to open 100000 files
# alternatively, replace * with an explicit username
* soft nofile 100000
* hard nofile 100000
# /etc/ssh/sshd_config
# ensure we consult pam
UsePAM yes
You can confirm these settings have taken effect by opening a new ssh
connection to the box and checking ulimit :
ulimit -n
100000
route
default via 10.248.77.193 dev eth0 proto kernel
10.248.77.192/26 dev eth0 proto kernel scope link src 10.248.77.212
Copy that line, and paste it back to the ip route change command,
adding initcwnd 10 to the end to increase the congestion window:
route change default via 10.248.77.193 dev eth0 proto kernel initcwnd 10
To make this persistent across reboots, you’ll need to add a few lines of bash like
the following to a startup script somewhere. Often the easiest candidate is just
pasting these lines into /etc/rc.local :
Hardware
More CPUs means more concurrency
More than 4GB of RAM is often not required, even with high concurrency
Faster Disk means faster IO, therefore we always recommend having an SSD
Uninstall
Simply run the command cd /root/crossbox-installer && uninstall.sh
Steps:
4. Final warnings
You have decided to uninstall crossbox from this machine and all it's users data
and databases along with /home/crossbox. This action is not reversable. Are you
sure you want to proceed? y/n (n)
This will be final prompt-able warning, after this you will still have 10
seconds to cancel the action by entering CTRL+C and sending interrupt
signal to the script