123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198 |
- .. _installation docker:
- ================
- Docker Container
- ================
- .. _ENTRYPOINT: https://docs.docker.com/engine/reference/builder/#entrypoint
- .. _searxng/searxng @dockerhub: https://hub.docker.com/r/searxng/searxng
- .. _searxng-docker: https://github.com/searxng/searxng-docker
- .. _[caddy]: https://hub.docker.com/_/caddy
- .. _Redis: https://redis.io/
- ----
- .. sidebar:: info
- - `searxng/searxng @dockerhub`_
- - :origin:`Dockerfile`
- - `Docker overview <https://docs.docker.com/get-started/overview>`_
- - `Docker Cheat Sheet <https://docs.docker.com/get-started/docker_cheatsheet.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`
- **If you intend to create a public instance using Docker, use our well maintained
- docker container**
- - `searxng/searxng @dockerhub`_.
- .. sidebar:: hint
- The rest of this article is of interest only to those who want to create and
- maintain their own Docker images.
- The sources are hosted at searxng-docker_ and the container includes:
- - a HTTPS reverse proxy `[caddy]`_ and
- - a Redis_ DB
- The `default SearXNG setup <https://github.com/searxng/searxng-docker/blob/master/searxng/settings.yml>`_
- of this container:
- - enables :ref:`limiter <limiter>` to protect against bots
- - enables :ref:`image proxy <image_proxy>` for better privacy
- - enables :ref:`cache busting <static_use_hash>` to save bandwidth
- ----
- Get Docker
- ==========
- If you plan to build and maintain a docker image by yourself, make sure you have
- `Docker installed <https://docs.docker.com/get-docker/>`_. 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):
- .. code:: sh
- $ sudo usermod -a -G docker $USER
- searxng/searxng
- ===============
- .. sidebar:: ``docker run``
- - `-\-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``
- 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/>`_:
- .. code:: sh
- $ mkdir my-instance
- $ cd my-instance
- $ export PORT=8080
- $ docker pull searxng/searxng
- $ docker run --rm \
- -d -p ${PORT}:8080 \
- -v "${PWD}/searxng:/etc/searxng" \
- -e "BASE_URL=http://localhost:$PORT/" \
- -e "INSTANCE_NAME=my-instance" \
- searxng/searxng
- 2f998.... # container's ID
- The environment variables UWSGI_WORKERS and UWSGI_THREADS overwrite the default
- number of UWSGI processes and UWSGI threads specified in `/etc/searxng/uwsgi.ini`.
- Open your WEB browser and visit the URL:
- .. code:: sh
- $ xdg-open "http://localhost:$PORT"
- Inside ``${PWD}/searxng``, you will find ``settings.yml`` and ``uwsgi.ini``. You
- can modify these files according to your needs and restart the Docker image.
- .. code:: sh
- $ 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
- stopped. To get rid of a container use ``container rm``:
- .. code:: sh
- $ 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
- This might remove all docker items, not only those from SearXNG.
- If you won't use docker anymore and want to get rid of all containers & 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
- - `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>`_
- 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
- ===============
- It's also possible to build SearXNG from the embedded :origin:`Dockerfile`::
- $ git clone https://github.com/searxng/searxng.git
- $ cd searxng
- $ 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
|