| 
									
										
										
										
											2021-04-29 14:33:35 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-02 19:00:19 +01:00
										 |  |  | .. _installation docker:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ===================
 | 
					
						
							|  |  |  | Docker installation
 | 
					
						
							|  |  |  | ===================
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-29 14:33:35 +02:00
										 |  |  | .. _ENTRYPOINT: https://docs.docker.com/engine/reference/builder/#entrypoint
 | 
					
						
							|  |  |  | .. _searxng-docker: https://github.com/searxng/searxng-docker
 | 
					
						
							|  |  |  | .. _[filtron]: https://hub.docker.com/r/dalf/filtron
 | 
					
						
							|  |  |  | .. _[morty]: https://hub.docker.com/r/dalf/morty
 | 
					
						
							|  |  |  | .. _[caddy]: https://hub.docker.com/_/caddy
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. sidebar:: info
 | 
					
						
							| 
									
										
										
										
											2020-03-02 19:00:19 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-29 14:33:35 +02:00
										 |  |  |    - :origin:`Dockerfile`
 | 
					
						
							|  |  |  |    - `searxng/searxng @dockerhub <https://hub.docker.com/r/searxng/searxng>`_
 | 
					
						
							|  |  |  |    - `Docker overview <https://docs.docker.com/get-started/overview>`_
 | 
					
						
							|  |  |  |    - `Docker Cheat Sheet <https://www.docker.com/sites/default/files/d8/2019-09/docker-cheat-sheet.pdf>`_
 | 
					
						
							|  |  |  |    - `Alpine Linux <https://alpinelinux.org>`_ `(wiki) <https://en.wikipedia.org/wiki/Alpine_Linux>`__ `apt packages <https://pkgs.alpinelinux.org/packages>`_
 | 
					
						
							|  |  |  |    - Alpine's ``/bin/sh`` is :man:`dash`
 | 
					
						
							| 
									
										
										
										
											2020-07-22 14:58:04 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-29 14:33:35 +02:00
										 |  |  | .. tip::
 | 
					
						
							| 
									
										
										
										
											2020-07-22 14:58:04 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-29 14:33:35 +02:00
										 |  |  |    If you intend to create a public instance using Docker, use our well
 | 
					
						
							|  |  |  |    maintained searxng-docker_ image which includes
 | 
					
						
							| 
									
										
										
										
											2020-07-22 14:58:04 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-29 14:33:35 +02:00
										 |  |  |    - :ref:`protection <searx filtron>` `[filtron]`_,
 | 
					
						
							|  |  |  |    - a :ref:`result proxy <searx morty>` `[morty]`_ and
 | 
					
						
							|  |  |  |    - a HTTPS reverse proxy `[caddy]`_.
 | 
					
						
							| 
									
										
										
										
											2020-07-22 14:58:04 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-29 14:33:35 +02:00
										 |  |  | Make sure you have `installed Docker <https://docs.docker.com/get-docker/>`_ and
 | 
					
						
							|  |  |  | on Linux, don't forget to add your user to the docker group (log out and log
 | 
					
						
							|  |  |  | back in so that your group membership is re-evaluated):
 | 
					
						
							| 
									
										
										
										
											2020-03-02 19:00:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | .. code:: sh
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-29 14:33:35 +02:00
										 |  |  |    $ sudo usermod -a -G docker $USER
 | 
					
						
							| 
									
										
										
										
											2020-03-02 19:00:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-29 14:33:35 +02:00
										 |  |  | searxng/searxng
 | 
					
						
							|  |  |  | ===============
 | 
					
						
							| 
									
										
										
										
											2020-07-22 14:58:04 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-29 14:33:35 +02:00
										 |  |  | .. sidebar:: ``docker run``
 | 
					
						
							| 
									
										
										
										
											2020-07-22 14:58:04 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-29 14:33:35 +02:00
										 |  |  |    - `-\-rm  <https://docs.docker.com/engine/reference/run/#clean-up---rm>`__
 | 
					
						
							|  |  |  |      automatically clean up when container exits
 | 
					
						
							|  |  |  |    - `-d <https://docs.docker.com/engine/reference/run/#detached--d>`__ start
 | 
					
						
							|  |  |  |      detached container
 | 
					
						
							|  |  |  |    - `-v <https://docs.docker.com/engine/reference/run/#volume-shared-filesystems>`__
 | 
					
						
							|  |  |  |      mount volume ``HOST:CONTAINER``
 | 
					
						
							| 
									
										
										
										
											2020-07-22 14:58:04 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-29 14:33:35 +02:00
										 |  |  | The docker image is based on :origin:`Dockerfile` and available from
 | 
					
						
							|  |  |  | `searxng/searxng @dockerhub`_.  Using the docker image is quite easy, for
 | 
					
						
							|  |  |  | instance you can pull the `searxng/searxng @dockerhub`_ image and deploy a local
 | 
					
						
							|  |  |  | instance using `docker run <https://docs.docker.com/engine/reference/run/>`_:
 | 
					
						
							| 
									
										
										
										
											2020-07-22 14:58:04 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | .. code:: sh
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-29 14:33:35 +02:00
										 |  |  |    $ mkdir my-instance
 | 
					
						
							|  |  |  |    $ cd my-instance
 | 
					
						
							|  |  |  |    $ export PORT=8080
 | 
					
						
							|  |  |  |    $ docker pull searxng/searxng
 | 
					
						
							|  |  |  |    $ docker run --rm \
 | 
					
						
							|  |  |  |                 -d -p ${PORT}:8080 \
 | 
					
						
							|  |  |  |                 -v "${PWD}/searx:/etc/searx" \
 | 
					
						
							|  |  |  |                 -e "BASE_URL=http://localhost:$PORT/" \
 | 
					
						
							|  |  |  |                 -e "INSTANCE_NAME=my-instance" \
 | 
					
						
							|  |  |  |                 searxng/searxng
 | 
					
						
							|  |  |  |    2f998.... # container's ID
 | 
					
						
							| 
									
										
										
										
											2020-07-22 14:58:04 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-29 14:33:35 +02:00
										 |  |  | Open your WEB browser and visit the URL:
 | 
					
						
							| 
									
										
										
										
											2020-07-22 14:58:04 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-29 14:33:35 +02:00
										 |  |  | .. code:: sh
 | 
					
						
							| 
									
										
										
										
											2020-07-22 14:58:04 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-29 14:33:35 +02:00
										 |  |  |    $ xdg-open "http://localhost:$PORT"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Inside ``${PWD}/searx``, you will find ``settings.yml`` and ``uwsgi.ini``.  You
 | 
					
						
							|  |  |  | can modify these files according to your needs and restart the Docker image.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. code:: sh
 | 
					
						
							| 
									
										
										
										
											2020-07-22 14:58:04 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-29 14:33:35 +02:00
										 |  |  |    $ docker container restart 2f998
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Use command ``container ls`` to list running containers, add flag `-a
 | 
					
						
							|  |  |  | <https://docs.docker.com/engine/reference/commandline/container_ls>`__ to list
 | 
					
						
							|  |  |  | exited containers also.  With ``container stop`` a running container can be
 | 
					
						
							|  |  |  | stoped.  To get rid of a container use ``container rm``:
 | 
					
						
							| 
									
										
										
										
											2020-03-02 19:00:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | .. code:: sh
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-29 14:33:35 +02:00
										 |  |  |    $ docker container ls
 | 
					
						
							|  |  |  |    CONTAINER ID   IMAGE             COMMAND                  CREATED         ...
 | 
					
						
							|  |  |  |    2f998d725993   searxng/searxng   "/sbin/tini -- /usr/…"   7 minutes ago   ...
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    $ docker container stop 2f998
 | 
					
						
							|  |  |  |    $ docker container rm 2f998
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. sidebar:: Warning
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-12 08:36:56 +02:00
										 |  |  |    This might remove all docker items, not only those from SearXNG.
 | 
					
						
							| 
									
										
										
										
											2021-04-29 14:33:35 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | If you won't use docker anymore and want to get rid of all conatiners & images
 | 
					
						
							|  |  |  | use the following *prune* command:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. code:: sh
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    $ docker stop $(docker ps -aq)       # stop all containers
 | 
					
						
							|  |  |  |    $ docker system prune                # make some housekeeping
 | 
					
						
							|  |  |  |    $ docker rmi -f $(docker images -q)  # drop all images
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | shell inside container
 | 
					
						
							|  |  |  | ----------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. sidebar:: Bashism
 | 
					
						
							| 
									
										
										
										
											2020-07-22 14:58:04 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-29 14:33:35 +02:00
										 |  |  |    - `A tale of two shells: bash or dash <https://lwn.net/Articles/343924/>`_
 | 
					
						
							|  |  |  |    - `How to make bash scripts work in dash <http://mywiki.wooledge.org/Bashism>`_
 | 
					
						
							|  |  |  |    - `Checking for Bashisms  <https://dev.to/bowmanjd/writing-bash-scripts-that-are-not-only-bash-checking-for-bashisms-and-testing-with-dash-1bli>`_
 | 
					
						
							| 
									
										
										
										
											2020-07-22 14:58:04 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-29 14:33:35 +02:00
										 |  |  | Like in many other distributions, Alpine's `/bin/sh
 | 
					
						
							|  |  |  | <https://wiki.ubuntu.com/DashAsBinSh>`__ is :man:`dash`.  Dash is meant to be
 | 
					
						
							|  |  |  | `POSIX-compliant <https://pubs.opengroup.org/onlinepubs/9699919799>`__.
 | 
					
						
							|  |  |  | Compared to debian, in the Alpine image :man:`bash` is not installed.  The
 | 
					
						
							|  |  |  | :origin:`dockerfiles/docker-entrypoint.sh` script is checked *against dash*
 | 
					
						
							|  |  |  | (``make tests.shell``).
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | To open a shell inside the container:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. code:: sh
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    $ docker exec -it 2f998 sh
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Build the image
 | 
					
						
							| 
									
										
										
										
											2020-07-22 14:58:04 +02:00
										 |  |  | ===============
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-29 14:33:35 +02:00
										 |  |  | It's also possible to build SearXNG from the embedded :origin:`Dockerfile`::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    $ git clone https://github.com/searxng/searxng.git
 | 
					
						
							|  |  |  |    $ cd searx
 | 
					
						
							|  |  |  |    $ make docker.build
 | 
					
						
							|  |  |  |    ...
 | 
					
						
							|  |  |  |    Successfully built 49586c016434
 | 
					
						
							|  |  |  |    Successfully tagged searxng/searxng:latest
 | 
					
						
							|  |  |  |    Successfully tagged searxng/searxng:1.0.0-209-9c823800-dirty
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    $ docker images
 | 
					
						
							|  |  |  |    REPOSITORY        TAG                        IMAGE ID       CREATED          SIZE
 | 
					
						
							|  |  |  |    searxng/searxng   1.0.0-209-9c823800-dirty   49586c016434   13 minutes ago   308MB
 | 
					
						
							|  |  |  |    searxng/searxng   latest                     49586c016434   13 minutes ago   308MB
 | 
					
						
							|  |  |  |    alpine            3.13                       6dbb9cc54074   3 weeks ago      5.61MB
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Command line
 | 
					
						
							|  |  |  | ============
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. sidebar:: docker run
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Use flags ``-it`` for `interactive processes
 | 
					
						
							|  |  |  |    <https://docs.docker.com/engine/reference/run/#foreground>`__.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | In the :origin:`Dockerfile` the ENTRYPOINT_ is defined as
 | 
					
						
							|  |  |  | :origin:`dockerfiles/docker-entrypoint.sh`
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. code:: sh
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     docker run --rm -it searxng/searxng -h
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. program-output:: ../dockerfiles/docker-entrypoint.sh -h
 |