An XMPP server written in Go.
jackal is a free, open-source, high performance XMPP server which aims to be known for its stability, simple configuration and low resource consumption.
jackal supports the following features:
- Customizable
- Enforced SSL/TLS
- Stream compression (zlib)
- Database connectivity for storing offline messages and user settings (PostgreSQL 9.5+, BoltDB)
- Caching (Redis 6.2+)
- Clustering capabilities (etcd 3.4+)
- Expose prometheus metrics
- Cross-platform (OS X, Linux)
To start using jackal, install Go 1.19+ and run the following commands:
$ git clone git@github.com:ortuman/jackal.git
$ cd jackal
$ make install installctl
This will fetch the code and install jackal
and jackalctl
binaries into your $GOPATH/bin
path.
By default the application will try to locate service configuration at config.yaml
, but alternatively you can specify a custom configuration path either through command line.
$ jackal --config=/your-custom-path/your-config.yaml
or environment variable:
$ env JACKAL_CONFIG_FILE=/your-custom-path/your-config.yaml jackal
To make it easy to install jackal via Helm in Kubernetes a chart has been included into this repository.
After customizing your own values.yaml file run the following command to install and configure all required components under jackal
namespace.
sh ./helm/scripts/install <your_custom_values>.yaml
In turn, an active chart can be updated by running the upgrade script as follows:
sh ./helm/scripts/upgrade <your_custom_values>.yaml
On the other hand, you can also remove the jackal chart from your Kubernetes cluster by running the uninstall script:
sh ./helm/scripts/uninstall
Create a user and a database for that user:
CREATE ROLE jackal WITH LOGIN PASSWORD 'password';
CREATE DATABASE jackal;
GRANT ALL PRIVILEGES ON DATABASE jackal TO jackal;
Download lastest version of the PostgreSQL schema from jackal Github repository.
wget https://raw.githubusercontent.com/ortuman/jackal/master/sql/postgres.up.psql
Run the postgres script file to create database schema:
psql --user jackal --password -f sql/postgres.up.psql
Configure jackal to use PostgreSQL by editing the configuration file:
storage:
type: pgsql
pgsql:
host: 127.0.0.1:5432
user: jackal
password: password
database: jackal
That's it!
Your database is now ready to connect with jackal.
After completing database setup and starting jackal
service you'll have to register a new user to be able to login. To do so, you can use
jackal command-line tool to create a new user proving name and password.
make installctl && jackalctl user add <user>:<password>
The purpose of clustering is to be able to use several servers for fault-tolerance and scalability.
Since jackal
is a distributed system, it needs a distributed data store like etcd to share its state across the entire cluster.
To properly run jackal
in clustering mode make sure to add a cluster
section configuration in each of your service nodes.
Here's an example of how this section should look like:
cluster:
type: kv
kv:
type: etcd
etcd:
endpoints:
- http://<etcd-host1>:<etcd-port1>
- http://<etcd-host2>:<etcd-port2>
...
port: your-cluster-node-port # default is 14369
Note the defined port
value will be used to perform cluster node communication, so make sure is reachable within your internal network.
The purpose of the extensibility framework is to provide an interface between jackal server and third-party external modules, thus offering the possibility of extending the functionality of the service for particular use cases. Extensibility gRPC API proto files can be found at jackal proto definitions repository.
The Docker deployment framework supports easy installation and configuration of jackal server.
You need to have Docker installed on your system before you can use a jackal Docker image. See Install Docker for instructions.
Download the jackal Docker image from the official Docker Hub library with this command:
docker pull ortuman/jackal:latest
Start a new jackal Docker container with custom configuration.
docker run --name=jackal \
--mount type=bind,src=/path-on-host-machine/my-custom-config.yaml,dst=/jackal/config.yaml \
-p "5222:5222" \
-p "15280:15280" \ # used by jackalctl
-d ortuman/jackal:latest
Alternatively, and with the purpose of facilitating service mounting, you can make use of docker-compose
as follows:
docker-compose -f dockerfiles/docker-compose.yml up
This command will spin up a jackal
server along with its dependencies on a docker network and start listening for incoming connections on port 5222
.
Once up and running, don't forget to register one or more users using jackalctl
.
- RFC 6120: XMPP CORE
- RFC 6121: XMPP IM
- XEP-0004: Data Forms 2.9
- XEP-0012: Last Activity 2.0
- XEP-0030: Service Discovery 2.5rc3
- XEP-0049: Private XML Storage 1.2
- XEP-0054: vcard-temp 1.2
- XEP-0059: Result Set Management 1.0
- XEP-0092: Software Version 1.1
- XEP-0114: Jabber Component Protocol 1.6
- XEP-0115: Entity Capabilities 1.5.2
- XEP-0122: Data Forms Validation 1.0.2
- XEP-0138: Stream Compression 2.0
- XEP-0160: Best Practices for Handling Offline Messages 1.0.1
- XEP-0190: Best Practice for Closing Idle Streams 1.1
- XEP-0191: Blocking Command 1.3
- XEP-0198: Stream Management 1.6
- XEP-0199: XMPP Ping 2.0
- XEP-0202: Entity Time 2.0
- XEP-0220: Server Dialback 1.1.1
- XEP-0237: Roster Versioning 1.3
- XEP-0280: Message Carbons 0.13.3
- XEP-0297: Stanza Forwarding 1.0
- XEP-0313: Message Archive Management 1.0.1
- XEP-0368: SRV records for XMPP over TLS 1.1.0
The jackal developer community is vital to improving jackal future releases.
Contributions of all kinds are welcome: reporting issues, updating documentation, fixing bugs, improving unit tests, sharing ideas, and any other tips that may help the jackal community.
Help us keep jackal open and inclusive. Please read and follow our Code of Conduct.
jackal is licensed under the Apache 2 License. See LICENSE for the full license text.
If you have any suggestion or question:
Miguel Ángel Ortuño, JID: ortuman@jackal.im, email: ortuman@pm.me