| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515 | .. _installation apache:===================Install with apache===================.. _Apache: https://httpd.apache.org/.. _Apache Debian:    https://cwiki.apache.org/confluence/display/HTTPD/DistrosDefaultLayout#DistrosDefaultLayout-Debian,Ubuntu(Apachehttpd2.x):.. _README.Debian:    https://salsa.debian.org/apache-team/apache2/raw/master/debian/apache2.README.Debian.. _Apache Arch Linux:    https://wiki.archlinux.org/index.php/Apache_HTTP_Server.. _Apache Fedora:    https://docs.fedoraproject.org/en-US/quick-docs/getting-started-with-apache-http-server/index.html.. _Apache directives:    https://httpd.apache.org/docs/trunk/mod/directives.html.. _Getting Started:    https://httpd.apache.org/docs/current/en/getting-started.html.. _Terms Used to Describe Directives:    https://httpd.apache.org/docs/current/en/mod/directive-dict.html.. _Configuration Files:    https://httpd.apache.org/docs/current/en/configuring.html.. _ProxyPreserveHost: https://httpd.apache.org/docs/trunk/mod/mod_proxy.html#proxypreservehost.. _LoadModule:    https://httpd.apache.org/docs/2.4/mod/mod_so.html#loadmodule.. _DocumentRoot:    https://httpd.apache.org/docs/trunk/mod/core.html#documentroot.. _Location:    https://httpd.apache.org/docs/trunk/mod/core.html#location.. _uWSGI Apache support:    https://uwsgi-docs.readthedocs.io/en/latest/Apache.html.. _mod_proxy_uwsgi:    https://uwsgi-docs.readthedocs.io/en/latest/Apache.html#mod-proxy-uwsgi.. sidebar:: further read   - `Apache Arch Linux`_   - `Apache Debian`_ and `README.Debian`_   - `Apache Fedora`_   - `Apache directives`_.. contents:: Contents   :depth: 2   :local:   :backlinks: entry----**Install** :ref:`apache searx site` using :ref:`filtron.sh <filtron.sh overview>`.. code:: bash   $ sudo -H ./utils/filtron.sh apache install**Install** :ref:`apache searx site` using :ref:`morty.sh <morty.sh overview>`.. code:: bash   $ sudo -H ./utils/morty.sh apache install----The apache HTTP server======================If Apache_ is not installed, install it now. If apache_ is new to you, the`Getting Started`_, `Configuration Files`_ and `Terms Used to DescribeDirectives`_ documentation gives first orientation.  There is also a list of`Apache directives`_ *to keep in the pocket*... tabs::   .. group-tab:: Ubuntu / debian      .. code:: sh         sudo -H apt-get install apache2   .. group-tab:: Arch Linux      .. code:: sh         sudo -H pacman -S apache         sudo -H systemctl enable httpd         sudo -H systemctl start http   .. group-tab::  Fedora / RHEL      .. code:: sh         sudo -H dnf install httpd         sudo -H systemctl enable httpd         sudo -H systemctl start httpdNow at http://localhost you should see any kind of *Welcome* or *Test* page.How this default intro site is configured, depends on the linux distribution(compare `Apache directives`_)... tabs::   .. group-tab:: Ubuntu / debian      .. code:: sh         less /etc/apache2/sites-enabled/000-default.conf      In this file, there is a line setting the `DocumentRoot`_ directive:      .. code:: apache         DocumentRoot /var/www/html      And the *welcome* page is the HTML file at ``/var/www/html/index.html``.   .. group-tab:: Arch Linux      .. code:: sh         less /etc/httpd/conf/httpd.conf      In this file, there is a line setting the `DocumentRoot`_ directive:      .. code:: apache         DocumentRoot "/srv/http"         <Directory "/srv/http">             Options Indexes FollowSymLinks             AllowOverride None             Require all granted         </Directory>      The *welcome* page of Arch Linux is a page showing directory located at      ``DocumentRoot``.  This is *directory* page is generated by the Module      `mod_autoindex <https://httpd.apache.org/docs/2.4/mod/mod_autoindex.html>`_:      .. code:: apache         LoadModule autoindex_module modules/mod_autoindex.so         ...         Include conf/extra/httpd-autoindex.conf   .. group-tab::  Fedora / RHEL      .. code:: sh         less /etc/httpd/conf/httpd.conf      In this file, there is a line setting the ``DocumentRoot`` directive:      .. code:: apache          DocumentRoot "/var/www/html"          ...          <Directory "/var/www">              AllowOverride None              # Allow open access:              Require all granted          </Directory>      On fresh installations, the ``/var/www`` is empty and the *default      welcome page* is shown, the configuration is located at::        less /etc/httpd/conf.d/welcome.conf.. _apache searx site:Apache Reverse Proxy====================.. sidebar:: public to the internet?   If your searx instance is public, stop here and first install :ref:`filtron   reverse proxy <filtron.sh>` and :ref:`result proxy morty <morty.sh>`, see   :ref:`installation scripts`.  If already done, follow setup: *searx via   filtron plus morty*.To setup a Apache revers proxy you have to enable the *headers* and *proxy*modules and create a `Location`_ configuration for the searx site.  In mostdistributions you have to un-comment the lines in the main configuration file,except in :ref:`The Debian Layout`... tabs::   .. group-tab:: Ubuntu / debian      In the Apache setup, enable headers and proxy modules:      .. code:: sh         sudo -H a2enmod headers         sudo -H a2enmod proxy         sudo -H a2enmod proxy_http      In :ref:`The Debian Layout` you create a ``searx.conf`` with the      ``<Location /searx >`` directive and save this file in the *sites      available* folder at ``/etc/apache2/sites-available``.  To enable the      ``searx.conf`` use :man:`a2ensite`:      .. code:: sh         sudo -H a2ensite searx.conf   .. group-tab:: Arch Linux      In the ``/etc/httpd/conf/httpd.conf`` file, activate headers and proxy      modules (LoadModule_):      .. code:: apache	 FIXME needs test         LoadModule headers_module modules/mod_headers.so         LoadModule proxy_module modules/mod_proxy.so         LoadModule proxy_http_module modules/mod_proxy_http.so   .. group-tab::  Fedora / RHEL      In the ``/etc/httpd/conf/httpd.conf`` file, activate headers and proxy      modules (LoadModule_):      .. code:: apache	 FIXME needs test	 LoadModule headers_module modules/mod_headers.so         LoadModule proxy_module modules/mod_proxy.so         LoadModule proxy_http_module modules/mod_proxy_http.soWith ProxyPreserveHost_ the incoming Host HTTP request header is passed to theproxied host... _apache searx via filtron plus morty:.. tabs::   .. group-tab:: searx via filtron plus morty      Use this setup, if your instance is public to the internet, compare      figure: :ref:`architecture <arch public>` and :ref:`installation scripts`.      1. Configure a reverse proxy for :ref:`filtron <filtron.sh>`, listening on         *localhost 4004* (:ref:`filtron route request`):      .. code:: apache         <Location /searx >             # SetEnvIf Request_URI "/searx" dontlog             # CustomLog /dev/null combined env=dontlog             Require all granted             Order deny,allow             Deny from all             #Allow from fd00::/8 192.168.0.0/16 fe80::/10 127.0.0.0/8 ::1             Allow from all             ProxyPreserveHost On             ProxyPass http://127.0.0.1:4004             RequestHeader set X-Script-Name /searx         </Location>      2. Configure reverse proxy for :ref:`morty <searx morty>`, listening on      *localhost 3000*      .. code:: apache         ProxyPreserveHost On         <Location /morty >             # SetEnvIf Request_URI "/morty" dontlog             # CustomLog /dev/null combined env=dontlog             Require all granted             Order deny,allow             Deny from all             #Allow from fd00::/8 192.168.0.0/16 fe80::/10 127.0.0.0/8 ::1             Allow from all             ProxyPass http://127.0.0.1:3000             RequestHeader set X-Script-Name /morty         </Location>      For a fully result proxification add :ref:`morty's <searx morty>` **public      URL** to your :origin:`searx/settings.yml`:      .. code:: yaml         result_proxy:             # replace example.org with your server's public name             url : https://example.org/morty             key : !!binary "insert_your_morty_proxy_key_here"         server:             image_proxy : TrueuWSGI support=============Be warned, with this setup, your instance isn't :ref:`protected <searxfiltron>`, nevertheless it is good enough for intranet usage.  In modern Linuxdistributions, the `mod_proxy_uwsgi`_ is compiled into the *normal* apachepackage and you need to install only the :ref:`uWSGI <searx uwsgi>` package:.. tabs::   .. group-tab:: Ubuntu / debian      .. code:: sh         sudo -H apt-get install uwsgi         # Ubuntu =< 18.04         sudo -H apt-get install libapache2-mod-proxy-uwsgi   .. group-tab:: Arch Linux      .. code:: sh         sudo -H pacman -S uwsgi   .. group-tab::  Fedora / RHEL      .. code:: sh         sudo -H dnf install uwsgiThe next example shows a configuration using the `uWSGI Apache support`_ viaunix sockets and `mod_proxy_uwsgi`_.For socket communication, you have to activate ``socket =/run/uwsgi/app/searx/socket`` and comment out the ``http = 127.0.0.1:8888``configuration in your :ref:`uwsgi ini file <uwsgi configuration>`.  If notalready exists, create a folder for the unix sockets, which can be used by thesearx account (see :ref:`create searx user`):.. code:: bash   sudo -H mkdir -p /run/uwsgi/app/searx/   sudo -H chown -R searx:searx /run/uwsgi/app/searx/If the server is public; to limit access to your intranet replace ``Allow fromall`` directive and replace ``192.168.0.0/16`` with your subnet IP/class... tabs::   .. group-tab:: Ubuntu / debian      .. code:: apache	 LoadModule headers_module /usr/lib/apache2/mod_headers.so	 LoadModule proxy_module /usr/lib/apache2/modules/mod_proxy.so	 LoadModule proxy_uwsgi_module /usr/lib/apache2/modules/mod_proxy_uwsgi.so	 # SetEnvIf Request_URI /searx dontlog	 # CustomLog /dev/null combined env=dontlog	 <Location /searx>	     Require all granted	     Order deny,allow	     Deny from all	     # Allow from fd00::/8 192.168.0.0/16 fe80::/10 127.0.0.0/8 ::1	     Allow from all	     ProxyPreserveHost On	     ProxyPass unix:/run/uwsgi/app/searx/socket|uwsgi://uwsgi-uds-searx/	 </Location>   .. group-tab:: Arch Linux      .. code:: apache	 FIXME needs test         LoadModule proxy_module modules/mod_proxy.so         LoadModule proxy_uwsgi_module modules/mod_proxy_uwsgi.so         # SetEnvIf Request_URI /searx dontlog         # CustomLog /dev/null combined env=dontlog         <Location /searx>             Require all granted             Order deny,allow             Deny from all             # Allow from fd00::/8 192.168.0.0/16 fe80::/10 127.0.0.0/8 ::1             Allow from all             ProxyPreserveHost On             ProxyPass unix:/run/uwsgi/app/searx/socket|uwsgi://uwsgi-uds-searx/	 </Location>   .. group-tab::  Fedora / RHEL      .. code:: apache	 FIXME needs test	 LoadModule proxy_module modules/mod_proxy.so         LoadModule proxy_uwsgi_module modules/mod_proxy_uwsgi.so         <IfModule proxy_uwsgi_module>             # SetEnvIf Request_URI /searx dontlog             # CustomLog /dev/null combined env=dontlog             <Location /searx>                 Require all granted                 Order deny,allow                 Deny from all                 # Allow from fd00::/8 192.168.0.0/16 fe80::/10 127.0.0.0/8 ::1                 Allow from all                 ProxyPreserveHost On                 ProxyPass unix:/run/uwsgi/app/searx/socket|uwsgi://uwsgi-uds-searx/	     </Location>         </IfModule>   .. group-tab:: old mod_wsgi      We show this only for historical reasons, DON'T USE `mod_uwsgi      <https://uwsgi-docs.readthedocs.io/en/latest/Apache.html#mod-uwsgi>`_.      ANYMORE!      .. code:: apache         <IfModule mod_uwsgi.c>             # SetEnvIf Request_URI "/searx" dontlog             # CustomLog /dev/null combined env=dontlog             <Location /searx >                 Require all granted                 Options FollowSymLinks Indexes                 SetHandler uwsgi-handler                 uWSGISocket /run/uwsgi/app/searx/socket                 Order deny,allow                 Deny from all                 # Allow from fd00::/8 192.168.0.0/16 fe80::/10 127.0.0.0/8 ::1                 Allow from all             </Location>         </IfModule>.. _restart apache:Restart service===============.. tabs::   .. group-tab:: Ubuntu / debian      .. code:: sh         sudo -H systemctl restart apache2         sudo -H service uwsgi restart searx   .. group-tab:: Arch Linux      .. code:: sh         sudo -H systemctl restart httpd         sudo -H systemctl restart uwsgi@searx   .. group-tab::  Fedora / RHEL      .. code:: sh         sudo -H systemctl restart httpd         sudo -H touch /etc/uwsgi.d/searx.inidisable logs============For better privacy you can disable Apache logs.  In the examples above activateone of the lines and `restart apache`_::  # SetEnvIf Request_URI "/searx" dontlog  # CustomLog /dev/null combined env=dontlogThe ``CustomLog`` directive disable logs for the whole (virtual) server, use itwhen the URL of the service does not have a path component (``/searx``) / islocated at root (``/``)... _The Debian Layout:The Debian Layout=================Be aware that the Debian layout is quite different from the standard Apacheconfiguration.  For details look at the README.Debian_(``/usr/share/doc/apache2/README.Debian.gz``).  Some commands you should know onDebian:* :man:`apache2ctl`:  Apache HTTP server control interface* :man:`a2enmod`, :man:`a2dismod`: switch on/off modules* :man:`a2enconf`, :man:`a2disconf`: switch on/off configurations* :man:`a2ensite`, :man:`a2dissite`: switch on/off sites
 |