installation.rst 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528
  1. Installation
  2. ============
  3. - `Basic Setup <#basic-setup>`_
  4. - `Configuration <#configuration>`_
  5. - `Deploying <#deploying>`_
  6. - `Deploying to PythonAnywhere <#deploying-to-pythonanywhere>`_
  7. Basic Setup
  8. -----------
  9. We recommend installing FlaskBB in an isolated Python environment. This can be
  10. achieved with `virtualenv`_. In our little guide we will use a wrapper around
  11. virtualenv - the `virtualenvwrapper`_. In addition to virtualenv, we will also
  12. use the package manager `pip`_ to install the dependencies for FlaskBB.
  13. Virtualenv Setup
  14. ~~~~~~~~~~~~~~~~
  15. **Linux:** The easiest way to install `virtualenv`_ and
  16. `virtualenvwrapper`_ is, to use the package manager on your system (if you
  17. are running Linux) to install them.
  18. **Windows:** Take a look at the `flask`_ documentation (then skip ahead to dependencies).
  19. For example, on archlinux you can install them with::
  20. $ sudo pacman -S python2-virtualenvwrapper
  21. or, on macOS, you can install them with::
  22. $ sudo pip install virtualenvwrapper
  23. It's sufficient to just install the virtualenvwrapper because it depends on
  24. virtualenv and the package manager will resolve all the dependencies for you.
  25. After that, you can create your virtualenv with::
  26. $ mkvirtualenv -a /path/to/flaskbb -p $(which python2) flaskbb
  27. This will create a virtualenv named ``flaskbb`` using the python interpreter in
  28. version 2 and it will set your project directory to ``/path/to/flaskbb``.
  29. This comes handy when typing ``workon flaskbb`` as it will change your
  30. current directory automatically to ``/path/to/flaskbb``.
  31. To deactivate it you just have to type ``deactivate`` and if you want to work
  32. on it again, just type ``workon flaskbb``.
  33. It is also possible to use ``virtualenv`` without the ``virtualenvwrapper``.
  34. For this you have to use the ``virtualenv`` command and pass the name
  35. of the virtualenv as an argument. In our example, the name of
  36. the virtualenv is ``.venv``.
  37. ::
  38. $ virtualenv .venv
  39. and finally activate it
  40. ::
  41. $ source .venv/bin/activate
  42. If you want to know more about those isolated python environments, checkout
  43. the `virtualenv`_ and `virtualenvwrapper`_ docs.
  44. Dependencies
  45. ~~~~~~~~~~~~
  46. Now that you have set up your environment, you are ready to install the
  47. dependencies.
  48. ::
  49. $ pip install -r requirements.txt
  50. Alternatively, you can use the `make` command to install the dependencies.
  51. ::
  52. $ make dependencies
  53. The development process requires a few extra dependencies which can be
  54. installed with the provided ``requirements-dev.txt`` file.
  55. ::
  56. $ pip install -r requirements-dev.txt
  57. Optional Dependencies
  58. ~~~~~~~~~~~~~~~~~~~~~
  59. We have one optional dependency, redis (the python package is installed
  60. automatically).
  61. If you want to use it, make sure that a redis-server is running.
  62. Redis will be used as the default result and caching backend for
  63. celery (celery is a task queue which FlaskBB uses to send non blocking emails).
  64. The feature for tracking the `online guests` and `online users` do also
  65. require redis (although `online users` works without redis as well).
  66. To install redis, just use your distributions package manager. For Arch Linux
  67. this is `pacman` and for Debian/Ubuntu based systems this is `apt-get`.
  68. ::
  69. # Installing redis using 'pacman':
  70. $ sudo pacman -S redis
  71. # Installing redis using 'apt-get':
  72. $ sudo apt-get install redis-server
  73. # Check if redis is already running.
  74. $ systemctl status redis
  75. # If not, start it.
  76. $ sudo systemctl start redis
  77. # Optional: Lets start redis everytime you boot your machine
  78. $ sudo systemctl enable redis
  79. Configuration
  80. -------------
  81. Production
  82. ~~~~~~~~~~
  83. FlaskBB already sets some sane defaults, so you shouldn't have to change much.
  84. To make this whole process a little bit easier for you, we have created
  85. a little wizard which will ask you some questions and with the answers
  86. you provide it will generate a configuration for you. You can of course
  87. further adjust the generated configuration.
  88. The setup wizard can be started with::
  89. flaskbb makeconfig
  90. These are the only settings you have to make sure to setup accordingly if
  91. you want to run FlaskBB in production:
  92. - ``SERVER_NAME = "example.org"``
  93. - ``PREFERRED_URL_SCHEME = "https"``
  94. - ``SQLALCHEMY_DATABASE_URI = 'sqlite:///path/to/flaskbb.sqlite'``
  95. - ``SECRET_KEY = "secret key"``
  96. - ``WTF_CSRF_SECRET_KEY = "secret key"``
  97. By default it will try to save the configuration file with the name flaskbb.cfg in FlaskBB’s root folder.
  98. Finally to get going – fire up FlaskBB!
  99. ::
  100. flaskbb --config flaskbb.cfg run
  101. [+] Using config from: /path/to/flaskbb/flaskbb.cfg
  102. * Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)
  103. Development
  104. ~~~~~~~~~~~
  105. To get started with development you have to generate a development
  106. configuration first. You can use the CLI for this,
  107. as explained in `Configuration <#configuration>`_::
  108. flaskbb makeconfig -d
  109. or
  110. flaskbb makeconfig --development
  111. Now you can either use ``make`` to run the development server::
  112. make run
  113. or if you like to type a little bit more, the CLI::
  114. flaskbb --config flaskbb.cfg run
  115. You can either pass an import string to the path to the (python) config file you’ve just created, or a default config object. (Most users will follow the example above, which uses the generated file).
  116. This is how you do it by using an import string. Be sure that it is importable from within FlaskBB:
  117. flaskbb --config flaskbb.configs.default.DefaultConfig run
  118. Redis
  119. ~~~~~
  120. If you have decided to use redis as well, which we highly recommend, then
  121. the following services and features can be enabled and configured to use redis.
  122. Before you can start using redis, you have to enable and configure it.
  123. This is quite easy just set ``REDIS_ENABLE`` to ``True`` and adjust the
  124. ``REDIS_URL`` if needed.
  125. ::
  126. REDIS_ENABLED = True
  127. REDIS_URL = "redis://localhost:6379" # or with a password: "redis://:password@localhost:6379"
  128. REDIS_DATABASE = 0
  129. The other services are already configured to use the ``REDIS_URL`` configuration
  130. variable.
  131. **Celery**
  132. ::
  133. CELERY_BROKER_URL = REDIS_URL
  134. CELERY_RESULT_BACKEND = REDIS_URL
  135. **Caching**
  136. ::
  137. CACHE_TYPE = "redis"
  138. CACHE_REDIS_URL = REDIS_URL
  139. **Rate Limiting**
  140. ::
  141. RATELIMIT_ENABLED = True
  142. RATELIMIT_STORAGE_URL = REDIS_URL
  143. Mail Examples
  144. ~~~~~~~~~~~~~
  145. Both methods are included in the example configs.
  146. **Google Mail**
  147. ::
  148. MAIL_SERVER = "smtp.gmail.com"
  149. MAIL_PORT = 465
  150. MAIL_USE_SSL = True
  151. MAIL_USERNAME = "your_username@gmail.com"
  152. MAIL_PASSWORD = "your_password"
  153. MAIL_DEFAULT_SENDER = ("Your Name", "your_username@gmail.com")
  154. **Local SMTP Server**
  155. ::
  156. MAIL_SERVER = "localhost"
  157. MAIL_PORT = 25
  158. MAIL_USE_SSL = False
  159. MAIL_USERNAME = ""
  160. MAIL_PASSWORD = ""
  161. MAIL_DEFAULT_SENDER = "noreply@example.org"
  162. Installation
  163. ------------
  164. **MySQL users:** Make sure that you create the database using the
  165. ``utf8`` charset::
  166. CREATE DATABASE flaskbb CHARACTER SET utf8;
  167. Even though the ``utf8mb4`` charset is prefered today
  168. (see `this <https://dba.stackexchange.com/a/152383>`_ SO answer), we have to
  169. create our database using the ``utf8`` charset. A good explanation about this
  170. issue can be found `here <https://stackoverflow.com/a/31474509>`_.
  171. For a guided install, run::
  172. $ make install
  173. or::
  174. flaskbb install
  175. During the installation process you are asked about your username,
  176. your email address and the password for your administrator user. Using the
  177. ``make install`` command is recommended as it checks that the dependencies
  178. are also installed.
  179. Upgrading
  180. ---------
  181. If the database models changed after a release, you have to run the ``upgrade``
  182. command::
  183. flaskbb db upgrade
  184. Deploying
  185. ---------
  186. This chapter will describe how to set up Supervisor + uWSGI + nginx for
  187. FlaskBB as well as document how to use the built-in WSGI server (gunicorn)
  188. that can be used in a productive environment.
  189. Supervisor
  190. ~~~~~~~~~~
  191. `Supervisor is a client/server system that allows its users to monitor and
  192. control a number of processes on UNIX-like operating systems.`
  193. To install `supervisor` on Debian, you need to fire up this command:
  194. ::
  195. $ sudo apt-get install supervisor
  196. There are two ways to configure supervisor. The first one is, you just put
  197. the configuration to the end in the ``/etc/supervisor/supervisord.conf`` file.
  198. The second way would be to create a new file in the ``/etc/supervisor/conf.d/``
  199. directory. For example, such a file could be named ``uwsgi.conf``.
  200. After you have choosen the you way you like, simply put the snippet below in the
  201. configuration file.
  202. ::
  203. [program:uwsgi]
  204. command=/usr/bin/uwsgi --emperor /etc/uwsgi/apps-enabled
  205. user=apps
  206. stopsignal=QUIT
  207. autostart=true
  208. autorestart=true
  209. redirect_stderr=true
  210. uWSGI
  211. ~~~~~
  212. `uWSGI is a web application solution with batteries included.`
  213. To get started with uWSGI, you need to install it first.
  214. You'll also need the python plugin to serve python apps.
  215. This can be done with::
  216. $ sudo apt-get install uwsgi uwsgi-plugin-python
  217. For the configuration, you need to create a file in the
  218. ``/etc/uwsgi/apps-available`` directory. In this example, I will call the
  219. file ``flaskbb.ini``. After that, you can start with configuring it.
  220. My config looks like this for `flaskbb.org` (see below). As you might have noticed, I'm
  221. using a own user for my apps whose home directory is located at `/var/apps/`.
  222. In this directory there are living all my Flask apps.
  223. ::
  224. [uwsgi]
  225. base = /var/apps/flaskbb
  226. home = /var/apps/.virtualenvs/flaskbb/
  227. pythonpath = %(base)
  228. socket = 127.0.0.1:30002
  229. module = wsgi
  230. callable = flaskbb
  231. uid = apps
  232. gid = apps
  233. logto = /var/apps/flaskbb/logs/uwsgi.log
  234. plugins = python
  235. =============== ========================== ===============
  236. **base** /path/to/flaskbb The folder where your flaskbb application lives
  237. **home** /path/to/virtualenv/folder The virtualenv folder for your flaskbb application
  238. **pythonpath** /path/to/flaskbb The same as base
  239. **socket** socket This can be either a ip or the path to a socket (don't forget to change that in your nginx config)
  240. **module** wsgi.py This is the file located in the root directory from flaskbb (where manage.py lives).
  241. **callable** flaskbb The callable is application you have created in the ``wsgi.py`` file
  242. **uid** your_user The user who should be used. **NEVER** use root!
  243. **gid** your_group The group who should be used.
  244. **logto** /path/to/log/file The path to your uwsgi logfile
  245. **plugins** python We need the python plugin
  246. =============== ========================== ===============
  247. Don't forget to create a symlink to ``/etc/uwsgi/apps-enabled``.
  248. ::
  249. ln -s /etc/uwsgi/apps-available/flaskbb /etc/uwsgi/apps-enabled/flaskbb
  250. gunicorn
  251. ~~~~~~~~
  252. `Gunicorn 'Green Unicorn' is a Python WSGI HTTP Server for UNIX.`
  253. It's a pre-fork worker model ported from Ruby's Unicorn project.
  254. The Gunicorn server is broadly compatible with various web frameworks,
  255. simply implemented, light on server resources, and fairly speedy.
  256. This is probably the easiest way to run a FlaskBB instance.
  257. Just install gunicorn via pip inside your virtualenv::
  258. pip install gunicorn
  259. FlaskBB has an built-in command to gunicorn::
  260. flaskbb start
  261. To see a full list of options either type ``flaskbb start --help`` or
  262. visit the :ref:`cli <commandline>` docs.
  263. nginx
  264. ~~~~~
  265. `nginx [engine x] is an HTTP and reverse proxy server,
  266. as well as a mail proxy server, written by Igor Sysoev.`
  267. The nginx config is pretty straightforward. Again, this is how I use it for
  268. `FlaskBB`. Just copy the snippet below and paste it to, for example
  269. ``/etc/nginx/sites-available/flaskbb``.
  270. The only thing left is, that you need to adjust the ``server_name`` to your
  271. domain and the paths in ``access_log``, ``error_log``. Also, don't forget to
  272. adjust the paths in the ``alias`` es, as well as the socket address in ``uwsgi_pass``.
  273. ::
  274. server {
  275. listen 80;
  276. server_name forums.flaskbb.org;
  277. access_log /var/log/nginx/access.forums.flaskbb.log;
  278. error_log /var/log/nginx/error.forums.flaskbb.log;
  279. location / {
  280. try_files $uri @flaskbb;
  281. }
  282. # Static files
  283. location /static {
  284. alias /var/apps/flaskbb/flaskbb/static/;
  285. }
  286. location ~ ^/_themes/([^/]+)/(.*)$ {
  287. alias /var/apps/flaskbb/flaskbb/themes/$1/static/$2;
  288. }
  289. # robots.txt
  290. location /robots.txt {
  291. alias /var/apps/flaskbb/flaskbb/static/robots.txt;
  292. }
  293. location @flaskbb {
  294. uwsgi_pass 127.0.0.1:30002;
  295. include uwsgi_params;
  296. }
  297. }
  298. If you wish to use gunicorn instead of uwsgi just replace the ``location @flaskbb``
  299. with this::
  300. location @flaskbb {
  301. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  302. proxy_set_header X-Forwarded-Proto $scheme;
  303. proxy_set_header Host $http_host;
  304. #proxy_set_header SCRIPT_NAME /forums; # This line will make flaskbb available on /forums;
  305. proxy_redirect off;
  306. proxy_buffering off;
  307. proxy_pass http://127.0.0.1:8000;
  308. }
  309. Don't forget to adjust the ``proxy_pass`` address to your socket address.
  310. Like in the `uWSGI <#uwsgi>`_ chapter, don't forget to create a symlink to
  311. ``/etc/nginx/sites-enabled/``.
  312. User Contributed Deployment Guides
  313. ----------------------------------
  314. We do not maintain these deployment guides. They have been submitted by users
  315. and we thought it is nice to include them in docs. If something is missing,
  316. or doesn't work - please open a new pull request on GitHub.
  317. Deploying to PythonAnywhere
  318. ~~~~~~~~~~~~~~~~~~~~~~~~~~~
  319. `PythonAnywhere <https://www.pythonanywhere.com/>`_ is a
  320. platform-as-a-service, which basically means they have a bunch of servers
  321. pre-configured with Python, nginx and uWSGI.
  322. You can run a low-traffic website with them for free,
  323. so it's an easy way to get quickly FlaskBB running publicly.
  324. Here's what to do:
  325. * Sign up for a PythonAnywhere account at
  326. `https://www.pythonanywhere.com/ <https://www.pythonanywhere.com/>`_.
  327. * On the "Consoles" tab, start a Bash console and install/configure
  328. FlaskBB like this
  329. ::
  330. git clone https://github.com/sh4nks/flaskbb.git
  331. cd flaskbb
  332. pip3.5 install --user -r requirements.txt
  333. pip3.5 install --user -e .
  334. flaskbb makeconfig
  335. flaskbb install
  336. * Click the PythonAnywhere logo to go back to the dashboard,
  337. then go to the "Web" tab, and click the "Add a new web app" button.
  338. * Just click "Next" on the first page.
  339. * On the next page, click "Flask"
  340. * On the next page, click "Python 3.5"
  341. * On the next page, just accept the default and click next
  342. * Wait while the website is created.
  343. * Click on the "Source code" link, and in the input that appears,
  344. replace the `mysite` at the end with `flaskbb`
  345. * Click on the "WSGI configuration file" filename,
  346. and wait for an editor to load.
  347. * Change the line that sets `project_home` to replace `mysite` with `flaskbb`
  348. again.
  349. * Change the line that says
  350. ::
  351. from flask_app import app as application
  352. to say
  353. ::
  354. from flaskbb import create_app
  355. application = create_app("/path/to/your/configuration/file")
  356. * Click the green "Save" button near the top right.
  357. * Go back to the "Web" tab.
  358. * Click the green "Reload..." button.
  359. * Click the link to visit the site -- you'll have a new FlaskBB install!
  360. .. _virtualenv: https://virtualenv.pypa.io/en/latest/installation.html
  361. .. _virtualenvwrapper: http://virtualenvwrapper.readthedocs.org/en/latest/install.html#basic-installation
  362. .. _pip: http://www.pip-installer.org/en/latest/installing.html
  363. .. _flask: http://flask.pocoo.org/docs/0.12/installation/