Home Operation and Maintenance Nginx Nginx secure deployment: start with server configuration

Nginx secure deployment: start with server configuration

Jun 10, 2023 am 08:24 AM
nginx Safety deploy

Nginx is an excellent HTTP and reverse proxy server that can provide high performance, stability and scalability. To ensure the security and stability of the Nginx server, secure deployment is required. This article will start with server configuration and introduce in detail the installation, configuration, optimization and security deployment of Nginx.

  1. Server configuration

Before installing Nginx, you need to perform basic configuration of the server. It is recommended to use the Linux operating system and install the latest system updates and security patches. In addition, the server should have sufficient memory and processor power to ensure the high performance of the Nginx server.

  1. Installing Nginx

Nginx can download the latest stable version from the official website https://nginx.org/en/download.html. After the download is complete, use the following command to install:

tar -zxvf nginx-1.18.0.tar.gz
cd nginx-1.18.0
./configure
make
sudo make install
Copy after login
  1. Configuring Nginx

The main configuration file of Nginx is located in /etc/nginx/nginx.conf. When making changes, make sure to back up the original files. The following is an example of a default Nginx configuration file:

user nginx;
worker_processes auto;
error_log /var/log/nginx/error.log;
pid /run/nginx.pid;

events {
    worker_connections 1024;
}

http {
    include /etc/nginx/mime.types;
    default_type application/octet-stream;
    log_format main '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';
    access_log /var/log/nginx/access.log main;
    sendfile on;
    # ...
    server {
        listen 80 default_server;
        listen [::]:80 default_server;
        root /usr/share/nginx/html;
        index index.html;
        server_name _;
        location / {
            try_files $uri $uri/ =404;
        }
        # ...
    }
}
Copy after login

This file includes user and worker process configuration, log format, access log location, file transfer configuration and a default HTTP server block. The listen directive defines the port that the server block should listen on. Port 80 in this example is defined as the default server port. If the user accesses it using the IP address in the browser, Nginx will access the default file on the server and return it to the client.

  1. Optimize Nginx configuration

The performance of Nginx depends on many factors, including server configuration and network environment. In order to optimize the performance of Nginx, you can do the following:

  • Enable Nginx's caching function. This will speed up response times for requests for static files, such as CSS files, JavaScript files, and image files. Taking the standard HTTP caching mechanism as an example, the following is an example configuration:
http {
    proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=my_cache:10m inactive=60m;
    server {
        location ~* .(png|jpg|jpeg|gif|ico)$ {
            proxy_cache my_cache;
            proxy_pass http://backend;
        }
    }
}
Copy after login
  • Improve performance by increasing the number of worker_processes. The number of worker_processes should be equal to the number of CPU cores available on the server. For example, if the server has four CPU cores, worker_process should be set to 4.
  • Enable TCP nopush and nodelay functions. This will reduce latency and packet loss in the TCP protocol. The following is an example configuration:
http {
    sendfile on;
    tcp_nopush on;
    tcp_nodelay on;
    # ...
}
Copy after login
  1. Secure Deployment

The security of Nginx is very important. Here are some suggestions for a secure deployment:

  • Use the HTTPS protocol to encrypt data transfers, especially sensitive data transfers such as bank account information or credit card numbers. Using certificates ensures that data transmission is not tampered with or stolen during transmission.
  • Limit the request rate to protect the website from DDoS attacks. For example, use Nginx's limit_req_zone directive to set the request rate.
http {
    limit_req_zone $binary_remote_addr zone=my_zone:10m rate=1r/s;
    server {
        location / {
            limit_req zone=my_zone burst=5 nodelay;
            # ...
        }
    }
}
Copy after login
  • Limit file upload size to prevent malicious file uploads. Use Nginx's client_max_body_size directive to set file size limits.
http {
    client_max_body_size 10M;
    server {
        location /upload {
            # ...
        }
    }
}
Copy after login
  • Close unnecessary services in the system. For example, if your server does not require mail services, you should turn off mail services to reduce risk.
  • Regularly update systems and software to ensure security. Updates should be applied to servers promptly after they are released.

This article introduces the installation, configuration, optimization and safe deployment of Nginx in detail. These steps can ensure the high performance, security and stability of the Nginx server.

The above is the detailed content of Nginx secure deployment: start with server configuration. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How to configure cloud server domain name in nginx How to configure cloud server domain name in nginx Apr 14, 2025 pm 12:18 PM

How to configure an Nginx domain name on a cloud server: Create an A record pointing to the public IP address of the cloud server. Add virtual host blocks in the Nginx configuration file, specifying the listening port, domain name, and website root directory. Restart Nginx to apply the changes. Access the domain name test configuration. Other notes: Install the SSL certificate to enable HTTPS, ensure that the firewall allows port 80 traffic, and wait for DNS resolution to take effect.

How to check nginx version How to check nginx version Apr 14, 2025 am 11:57 AM

The methods that can query the Nginx version are: use the nginx -v command; view the version directive in the nginx.conf file; open the Nginx error page and view the page title.

How to start nginx server How to start nginx server Apr 14, 2025 pm 12:27 PM

Starting an Nginx server requires different steps according to different operating systems: Linux/Unix system: Install the Nginx package (for example, using apt-get or yum). Use systemctl to start an Nginx service (for example, sudo systemctl start nginx). Windows system: Download and install Windows binary files. Start Nginx using the nginx.exe executable (for example, nginx.exe -c conf\nginx.conf). No matter which operating system you use, you can access the server IP

How to check the name of the docker container How to check the name of the docker container Apr 15, 2025 pm 12:21 PM

You can query the Docker container name by following the steps: List all containers (docker ps). Filter the container list (using the grep command). Gets the container name (located in the "NAMES" column).

How to check whether nginx is started How to check whether nginx is started Apr 14, 2025 pm 01:03 PM

How to confirm whether Nginx is started: 1. Use the command line: systemctl status nginx (Linux/Unix), netstat -ano | findstr 80 (Windows); 2. Check whether port 80 is open; 3. Check the Nginx startup message in the system log; 4. Use third-party tools, such as Nagios, Zabbix, and Icinga.

How to run nginx apache How to run nginx apache Apr 14, 2025 pm 12:33 PM

To get Nginx to run Apache, you need to: 1. Install Nginx and Apache; 2. Configure the Nginx agent; 3. Start Nginx and Apache; 4. Test the configuration to ensure that you can see Apache content after accessing the domain name. In addition, you need to pay attention to other matters such as port number matching, virtual host configuration, and SSL/TLS settings.

How to create a mirror in docker How to create a mirror in docker Apr 15, 2025 am 11:27 AM

Steps to create a Docker image: Write a Dockerfile that contains the build instructions. Build the image in the terminal, using the docker build command. Tag the image and assign names and tags using the docker tag command.

How to start containers by docker How to start containers by docker Apr 15, 2025 pm 12:27 PM

Docker container startup steps: Pull the container image: Run "docker pull [mirror name]". Create a container: Use "docker create [options] [mirror name] [commands and parameters]". Start the container: Execute "docker start [Container name or ID]". Check container status: Verify that the container is running with "docker ps".

See all articles