Installing FreeSWITCH on Ubuntu Server: A Step-by-Step Guide
Categories:
5 minute read
Introduction
FreeSWITCH is a powerful open-source communications platform widely used for VoIP, video, and chat applications. It’s designed to facilitate large-scale telecommunication systems, supporting a broad range of protocols and codecs, making it highly versatile and efficient. Setting up FreeSWITCH on an Ubuntu server offers a reliable and cost-effective way to manage and scale communications. This step-by-step guide will walk you through the process of installing FreeSWITCH on Ubuntu. Whether you’re a beginner or a seasoned system administrator, this guide will help you get FreeSWITCH up and running in no time.
System Requirements
Before starting the installation, make sure you have the following:
Ubuntu Server: This guide is compatible with Ubuntu 18.04, 20.04, and later versions.
2 GB RAM or higher: A minimum of 2 GB of RAM is recommended.
Processor: A modern multi-core processor is preferred.
Root or Sudo Access: Ensure you have administrative privileges.
Updating the Ubuntu Server
To begin, it’s important to update your Ubuntu system to ensure all packages are up to date:
sudo apt update && sudo apt upgrade -y
This command updates your package lists and installs the latest versions of all packages.
Installing Dependencies
FreeSWITCH requires a set of dependencies for a successful installation. Begin by installing these necessary packages:
sudo apt install -y build-essential git-core cmake automake autoconf libtool pkg-config \
libjpeg-dev libncurses5-dev libssl-dev libpcre3-dev libcurl4-openssl-dev libldns-dev \
libedit-dev libsqlite3-dev libopus-dev libsndfile1-dev libavformat-dev libswscale-dev \
libvpx-dev libavresample-dev libavfilter-dev libxml2-dev libxslt1-dev libmp3lame-dev \
libspeexdsp-dev libspeex-dev libogg-dev libvorbis-dev libtiff-dev libtiff5-dev libpq-dev
This command installs all required libraries and tools needed to compile and run FreeSWITCH.
Cloning the FreeSWITCH Source Code
Next, clone the FreeSWITCH repository from GitHub. This will allow you to build FreeSWITCH from the latest source:
cd /usr/local/src
sudo git clone https://github.com/signalwire/freeswitch.git
cd freeswitch
The cd
command changes the directory to where FreeSWITCH will be downloaded, and then the git clone
command retrieves the FreeSWITCH source code.
Checking Out the Latest Stable Version
FreeSWITCH has both master and stable branches. To ensure a stable installation, switch to the latest stable version:
sudo git checkout v1.10
This command switches to the latest stable release, which is currently v1.10.
Building and Compiling FreeSWITCH
With the source code downloaded, it’s time to build and compile FreeSWITCH. First, install FreeSWITCH’s core dependencies:
sudo ./bootstrap.sh -j
sudo ./configure -C
The bootstrap.sh
script prepares the FreeSWITCH environment for compilation, while configure -C
optimizes the build process.
Compiling the Source Code
Now, compile the source code using the make
command:
sudo make
sudo make install
This process may take some time depending on your system’s resources. The make
command compiles FreeSWITCH and make install
installs it onto your system.
Installing FreeSWITCH Modules
FreeSWITCH’s functionality is enhanced by its modular structure, allowing you to install only the features you need. Use the following command to install all essential modules:
sudo make all cd-sounds-install cd-moh-install
cd-sounds-install: Installs sound files for ringtones and other audio.
cd-moh-install: Installs Music on Hold files. These modules are essential for a fully operational FreeSWITCH instance.
Configuring FreeSWITCH
FreeSWITCH comes with a default configuration suitable for most basic setups. However, you may need to customize it based on your requirements.
- Navigate to the Configuration Directory:
cd /usr/local/freeswitch/conf```
<!-- wp:list {"ordered":true,"start":2} -->
<ol start="2" class="wp-block-list">* **Edit Core Configuration Files:** Use any text editor to modify the configuration files, such as `vars.xml` or `sip_profiles` for SIP settings:
```bash
sudo nano vars.xml
Adjust settings based on your network and user needs, including parameters for IP addresses, ports, and protocol settings.
Starting FreeSWITCH
Once configured, FreeSWITCH is ready to start. You can start it directly from the terminal:
/usr/local/freeswitch/bin/freeswitch
This command launches FreeSWITCH in the foreground, allowing you to see the output and check for any immediate issues.
Running FreeSWITCH in the Background
To run FreeSWITCH as a background process, use:
/usr/local/freeswitch/bin/freeswitch -nc```
The `-nc` flag runs FreeSWITCH in non-console mode, making it ideal for production servers.
## Testing the Installation
To ensure FreeSWITCH is working correctly, log in to the FreeSWITCH CLI by typing:
```bash
/usr/local/freeswitch/bin/fs_cli```
This command opens the FreeSWITCH Command Line Interface, where you can test various commands and ensure the system is functioning as expected.
Basic Test Commands
Try using the following commands within the CLI to confirm the setup:
* `status`: Displays the status of FreeSWITCH.
* `sofia status`: Shows SIP profiles and registration status.
* `reloadxml`: Reloads XML configuration files without restarting FreeSWITCH.
## Setting Up FreeSWITCH as a System Service
To simplify management, set up FreeSWITCH as a system service:
* **Create a Service File:**
```bash
sudo nano /etc/systemd/system/freeswitch.service```
<!-- wp:list {"ordered":true,"start":2} -->
<ol start="2" class="wp-block-list">* **Add Service Configuration:** Paste the following configuration into the file:
```bash
[Unit]
Description=FreeSWITCH Service
After=network.target
[Service]
Type=forking
ExecStart=/usr/local/freeswitch/bin/freeswitch -ncwait -nonat
ExecStop=/usr/local/freeswitch/bin/freeswitch -stop
User=root
Group=root
Restart=always
[Install]
WantedBy=multi-user.target```
<!-- wp:list {"ordered":true,"start":3} -->
<ol start="3" class="wp-block-list">* **Enable and Start the Service:**
```bash
sudo systemctl enable freeswitch
sudo systemctl start freeswitch
This configuration file allows you to manage FreeSWITCH with systemctl
, making it easier to control FreeSWITCH at boot.
Troubleshooting Common Installation Issues
Dependency Errors
If you encounter dependency errors, double-check that all required packages were installed in the dependencies step. Run sudo apt update
and sudo apt install
as needed to ensure all dependencies are in place.
Service Not Starting
If FreeSWITCH fails to start as a service, use journalctl -xe
to check for errors in the system logs. Adjust the configuration as needed and restart the service.
Security and Best Practices
Limit Access: Use firewalls to restrict access to your FreeSWITCH server and prevent unauthorized access.
Enable Logging: Enable detailed logging to monitor activity and troubleshoot issues.
Regular Updates: Keep FreeSWITCH and your Ubuntu server up to date to protect against security vulnerabilities.
Conclusion
FreeSWITCH offers a robust platform for VoIP and communications solutions, and installing it on an Ubuntu server is a great way to leverage its features. By following this step-by-step guide, you should have a fully functional FreeSWITCH instance up and running. From dependencies and configuration to troubleshooting, this guide provides everything you need to set up FreeSWITCH successfully. With this setup, you’ll be well-equipped to handle VoIP and communication needs efficiently and securely.