6.2 KiB
Deploying bots in production
Usually, work on a bot starts on a laptop. At some point, you'll want to deploy your bot in a production environment, so that it'll stay up regardless of what's happening with your laptop. There are several options for doing so:
- The simplest is running
zulip-run-botinside ascreensession on a server. This works, but if your server reboots, you'll need to manually restart it, so we don't recommend it. - Using
supervisordor a similar tool for managing a production process withzulip-run-bot. This consumes a bit of resources (since you need a persistent process running), but otherwise works great. - Using the Zulip Botserver, which is a simple Flask server for running a bot in production, and connecting that to Zulip's outgoing webhooks feature. This can be deployed in environments like Heroko's free tier without running a persistent process.
Zulip Botserver
The Zulip Botserver is for people who want to
- run bots in production.
- run multiple bots at once.
The Zulip Botserver is a Python (Flask) server that implements Zulip's Outgoing Webhooks API. You can of course write your own servers using the Outgoing Webhooks API, but the Botserver is designed to make it easy for a novice Python programmer to write a new bot and deploy it in production.
Installing the Zulip Botserver
Install the zulip_botserver PyPI package using pip:
pip install zulip_botserver
Running a bot using the Zulip Botserver
-
Construct the URL for your bot, which will be of the form:
http://<hostname>:<port>where the
hostnameis the hostname you'll be running the bot server on, andportis the port for it (the recommended default is5002). -
Register new bot users on the Zulip server's web interface.
- Log in to the Zulip server.
- Navigate to Settings () -> Your bots -> Add a new bot. Select Outgoing webhook for bot type, fill out the form (using the URL from above) and click on Create bot.
- A new bot user should appear in the Active bots panel.
-
Download the
zuliprcfile for your bot from the Active Bots panel, using the download button. -
Run the Botserver, where
helloworldis the name of the bot you want to run:zulip-botserver --config-file <path_to_zuliprc> --bot-name=helloworldYou can specify the port number and various other options; run
zulip-botserver --helpto see how to do this. -
Congrats, everything is set up! Test your Botserver like you would test a normal bot.
Running multiple bots using the Zulip Botserver
The Zulip Botserver also supports running multiple bots from a single Botserver process. You can do this with the following procedure.
-
Download the
botserverrcfrom theyour-botssettings page, using the "Download config of all active outgoing webhook bots in Zulip Botserver format." option at the top. -
Open the
botserverrc. It should contain one or more sections that look like this:[] email=foo-bot@hostname key=dOHHlyqgpt5g0tVuVl6NHxDLlc9eFRX4 site=http://hostname token=aQVQmSd6j6IHphJ9m1jhgHdbnhl5ZcsYEach section contains the configuration for an outgoing webhook bot. For each bot, enter the name of the bot you want to run in the square brackets
[]. For example, if we wantfoo-bot@hostnameto run thehelloworldbot, our new section would look like this:[helloworld] email=foo-bot@hostname key=dOHHlyqgpt5g0tVuVl6NHxDLlc9eFRX4 site=http://hostname token=aQVQmSd6j6IHphJ9m1jhgHdbnhl5ZcsYEach section contains the configuration for an outgoing webhook bot. For each bot, enter the name of the bot you want to run in the square brackets
[]. For example, if we wantfoo-bot@hostnameto run thehelloworldbot, our new section would look like this:[helloworld] email=foo-bot@hostname key=dOHHlyqgpt5g0tVuVl6NHxDLlc9eFRX4 site=http://hostname -
Run the Zulip Botserver by passing the
botserverrcto it. The command format is:zulip-botserver --config-file <path_to_botserverrc>If omitted,
hostnamedefaults to127.0.0.1andportto5002.
Running Zulip Botserver with supervisord
supervisord is a popular tool for running services in production. It helps ensure the service starts on boot, manages log files, restarts the service if it crashes, etc. This section documents how to run the Zulip Botserver using supervisord.
Running the Zulip Botserver with supervisord works almost like running it manually.
-
Install supervisord via your package manager; e.g. on Debian/Ubuntu:
sudo apt-get install supervisor -
Configure supervisord. supervisord stores its configuration in
/etc/supervisor/conf.d.-
Do one of the following:
-
Download the sample config file and store it in
/etc/supervisor/conf.d/zulip-botserver.conf. -
Copy the following section into your existing supervisord config file.
[program:zulip-botserver] command=zulip-botserver --config-file=<path/to/your/botserverrc> --hostname <address> --port <port> startsecs=3 stdout_logfile=/var/log/zulip-botserver.log ; all output of your Botserver will be logged here redirect_stderr=true
-
-
Edit the
<>sections according to your preferences.
-
-
Update supervisord to read the configuration file:
supervisorctl reread supervisorctl update(or you can use
/etc/init.d/supervisord restart, but this is less disruptive if you're using supervisord for other services as well). -
Test if your setup is successful:
supervisorctl statusThe output should include a line similar to this:
zulip-botserver RUNNING pid 28154, uptime 0:00:27
The standard output of the Botserver will be logged to the path in your supervisord configuration.