Skip to main content

Auto Nginx Installation

Project description

Auto Nginx Installation Script

This script is designed to install Nginx on modern Ubuntu, other Debian-based systems might also work.

Supported Modules

Supported Flavors

  • Vanilla
  • OpenResty

Go to discussions to request more modules.

Installation

pip install -U nginx-install

or

git clone https://github.com/VermiIIi0n/nginx_install.git
cd nginx_install
pip install -U poetry
poetry install

Quick Start

Create a config.yaml, use any action as the first argument, it won't actually run if config.yaml is not found.

nginx-install uninstall --dry ## creates a config.yaml file and quits

Edit your config.yaml and run the following command to install Nginx:

nginx-install install

To uninstall Nginx, use the following command:

nginx-install uninstall

Usage

Installed by pip

nginx-install { prepare | build | install | uninstall | clean } [build_dir]

When you first run the script, you will be asked to create a config.yaml under the current directory. You may not want to run as root when creating the config.yaml file. You can also specify the file using the -c/--config option.

The first positional argument is the action to be performed.

The second positional argument is optional and is used to specify the build directory. If not specified, the default build directory is used.

When running the script for real business, you will be prompted to run as root, because the script needs to install packages and create directories.

To just build the Nginx binary, use the following command:

nginx-install build ./build  # Or any other build directory

To just install without building, use the following command:

nginx-install install --no-build ./build  # Or any other build directory

To build and install Nginx, use the following command:

nginx-install install  # Here the build directory is in a tmp dir

build and plain install both delete the previous build directory and create a new one.

Currently only partial support for cross-compiling. If your target system is the same as the build system, you can copy the build directory to the target system and run install --no-build there.

Change -march in config.yaml if your are installing on systems with different CPU

By default, core installer will use -march=native flag, this may cause problems on other systems.

Check your -march by running gcc -march=native -Q --help=target | grep march on your target system and change -march in config.yaml accordingly.

Installed by git clone

If you cloned the repository, use the following command to run the script:

poetry run `which python` nginx_install <...>

Dry Run

Use --dry to run the script in dry-run mode. In this mode, the script will not change anything outside of build_dir but will print the commands to be executed.

nginx-install --dry build

no root should be required if you have access to the build directory.

Configuration

The config.yaml file is used to specify the version of Nginx to be installed, the modules to be included, and the build options.

Use -c/--config to specify the path of the config.yaml file. By default, it is config.yaml under the current directory.

If not specified, the script will search for the ./config.yaml file, and if not found, it will ask you to create one.

If -q/--quiet is specified, the script will not ask you to create one and will exit with an error if not found.

Useful options in config.yaml:

  • version: The version of Nginx to be installed. Can be stable, mainline, latest, or a simple spec version (e.g. 1.21.3, ^1.24.0, <=1.26.0).
  • core.flavor: Can be vanilla and openresty
  • pymodule_paths: A list of paths to Python modules. Convenient for adding custom Installer classes.

Customization

You can easily add your own modules to modify the installation of Nginx (e.g. add custom modules, change build options, etc.).

All Installer classes are descendants of the BaseInstaller class.

Every Installer class has 5 async methods corresponding to the 5 stages of the installation process:

  • prepare
  • build
  • install
  • uninstall
  • clean

They all accept a special context parameter, which contains useful information about the installation process. You must override these methods in inherited classes.

During installation running, installers go through prepare, build, install and clean stages. During uninstallation running, installers go through uninstall and clean stages.

A special Installer called core represents the core binary installer of Nginx. In every stage, the core installer methods are called first, and then the methods of other installers are called. The order of the other installers is random. This is done to reduce build time.

You can access core through the context parameter. Parameters like Nginx configure options are stored in core and can be modified.

Context

The context parameter is a dictionary containing the following attributes:

  • build_dir: The build directory.
  • cfg: The Config object from the config.yaml file.
  • core: The NginxInstaller object.
  • verbose: A boolean value indicating whether to print verbose information.
  • quiet: A boolean value indicating whether to print nothing unless an error occurs.
  • dry_run: A boolean value indicating whether to run the script in dry-run mode. You should respect this value in your custom installers. Don't actually change anything if dry_run is True.
  • user: The user who started the script.
  • client: A httpx.AsyncClient object. You can use it to download files from the internet.
  • logger: You can use it to log information.
  • progress: A rich.progress.Progress object. You can use it to show a progress bar.
  • run_cmd: An async function to run shell commands. You should use it to run shell commands in your custom installers. When dry_run is True, it will only print the command to be executed.
  • download: An async function to download files from the internet. You should use it to download files in your custom installers. It automatically shows a progress bar when downloading files.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

nginx_install-0.1.11.tar.gz (21.0 kB view details)

Uploaded Source

Built Distribution

nginx_install-0.1.11-py3-none-any.whl (26.3 kB view details)

Uploaded Python 3

File details

Details for the file nginx_install-0.1.11.tar.gz.

File metadata

  • Download URL: nginx_install-0.1.11.tar.gz
  • Upload date:
  • Size: 21.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.0 CPython/3.12.4

File hashes

Hashes for nginx_install-0.1.11.tar.gz
Algorithm Hash digest
SHA256 ca57c8178192d74d3a8ed9ecb4891cdbafef3fe1ec82ec313a674fc3d1a54f3f
MD5 a950082fc81348d44c70ff11a4795515
BLAKE2b-256 11ec25373284c8d85813880423c43e15cad5c1ccfe62f2eaf58b8d17013e0a36

See more details on using hashes here.

File details

Details for the file nginx_install-0.1.11-py3-none-any.whl.

File metadata

File hashes

Hashes for nginx_install-0.1.11-py3-none-any.whl
Algorithm Hash digest
SHA256 d5f4c30b2b987b35d799b9644d5d6e55ce4dd76962a8f23c28fa91491d14180b
MD5 bb1c5a956c7eca0cde32b427028cd27c
BLAKE2b-256 b8c0c3a3bff9d988823613946f0abcc89879cab4044d0e4ac0a31aa6a631cebd

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page