Nginx custom build by Hakase | GitHub : https://github.com/hakasenyang/nginx-build
Go to file
Hakase 008819315c
Update README.md
2020-10-05 21:35:23 +09:00
auto Latest update - 7584 2019-10-17 23:53:16 +09:00
conf Fix nginx.conf (Cloudflare IPs) 2020-01-27 18:34:36 +09:00
contrib Latest update - 7661 2020-05-27 20:32:16 +09:00
docs Release - v1.19.2 2020-08-29 19:52:37 +09:00
lib Submodule update, fix build error. 2020-10-05 21:34:12 +09:00
misc Release - v1.19.0 2020-05-27 20:31:46 +09:00
src Latest update - 7702 2020-08-29 19:53:01 +09:00
.gitignore Add strict-sni patch file. 2018-09-16 01:33:28 +09:00
.gitmodules Edit submodule - ngx_brotli 2020-05-02 00:02:16 +09:00
.hgtags Release - v1.19.2 2020-08-29 19:52:37 +09:00
LICENSE Add LICENSE 2018-07-02 20:28:31 +09:00
README.ko.md Remove Curve (P-224, P-521) 2019-04-18 02:01:45 +09:00
README.md Update README.md 2020-10-05 21:35:23 +09:00
auto.sh Submodule update, fix build error. 2020-10-05 21:34:12 +09:00
config.inc.example Edit config.inc.example 2020-01-22 16:58:15 +09:00

Hakase-nginx

My nginx build files.

This repository is no longer operational. Use an alternative such as tengine.

Example Web Server - https://ssl.haka.se/

Please install dependency library.

  • CentOS / Red Hat - yum install jemalloc-devel libuuid-devel libatomic libatomic_ops-devel expat-devel unzip autoconf automake libtool gd-devel libmaxminddb-devel libxslt-devel libxml2-devel gcc-c++ curl
  • Ubuntu / Debian - apt install libjemalloc-dev uuid-dev libatomic1 libatomic-ops-dev expat unzip autoconf automake libtool libgd-dev libmaxminddb-dev libxslt1-dev libxml2-dev g++ curl

How to Install?

  1. Clone this repository - git clone https://github.com/hakasenyang/nginx-build.git --recursive
  2. Install dependency library. (If you have already install it, omit it.)
  3. Edit for config.inc file. (SERVER_HEADER, Modules, ETC.)
    • If you receive the source for the first time, type the following command to set it.
    • Then modify config.inc.
    • cp config.inc.example config.inc
  4. Run sudo ./auto.sh
  5. Install systemd file (If you have already install it, omit it.)
  6. Check version and error test : nginx -v; nginx -t;
  7. Run systemctl restart nginx
  8. The END!!

Features

  • Auto SSL Cipher settings
    • The following information is preset. Do not set it yourself unless you need it.
    • ssl_protocols : TLSv1.2 TLSv1.3
    • ssl_ciphers : [TLS13+AESGCM+AES128|TLS13+CHACHA20]:TLS13+AESGCM+AES256:[EECDH+ECDSA+AESGCM+AES128|EECDH+ECDSA+CHACHA20]:EECDH+ECDSA+AESGCM+AES256:EECDH+ECDSA+AES128+SHA:EECDH+ECDSA+AES256+SHA:[EECDH+aRSA+AESGCM+AES128|EECDH+aRSA+CHACHA20]:EECDH+aRSA+AESGCM+AES256:EECDH+aRSA+AES128+SHA:EECDH+aRSA+AES256+SHA
    • ssl_prefer_server_ciphers : On
    • ssl_ecdh_curve : X25519:P-256:P-384
    • ssl_session_timeout : 64800 (< TLSv1.3)
    • ssl_session_timeout_tls13 : 172800 (TLSv1.3 only)
    • DO NOT USE ssl_dhparam. Not required.
    • Use the settings below to support older browsers. (TLS Protocol)
    • ssl_protocols : TLSv1 TLSv1.1 TLSv1.2 TLSv1.3
    • ssl_ciphers : [TLS13+AESGCM+AES128|TLS13+CHACHA20]:TLS13+AESGCM+AES256:[EECDH+ECDSA+AESGCM+AES128|EECDH+ECDSA+CHACHA20]:EECDH+ECDSA+AESGCM+AES256:EECDH+ECDSA+AES128+SHA:EECDH+ECDSA+AES256+SHA:[EECDH+aRSA+AESGCM+AES128|EECDH+aRSA+CHACHA20]:EECDH+aRSA+AESGCM+AES256:EECDH+aRSA+AES128+SHA:EECDH+aRSA+AES256+SHA:RSA+AES128+SHA:RSA+AES256+SHA:RSA+3DES
  • TLS v1.3
    • Use OpenSSL-3.0.0-alpha3-dev
    • Use OpenSSL equal preference patch (BoringSSL & buik)
    • My OpenSSL patch is here.
  • Prefers ChaCha20 suites with clients that don't have AES-NI(AES hardware acceleration) (e.g., Android devices)
  • More library!
    • headers_more_nginx_module
    • Google PageSpeed for nginx
    • and the other.
  • Support HPACK, SSL Dynamic TLS Records. (Thanks to cloudflare!)
  • SSL Strict-SNI (ex: http { strict_sni on; } ) (Thanks to @JemmyLoveJenny)
    • Strict SNI requires at least two ssl server settings (server { listen 443 ssl }).
    • If you do not have two server settings, SNI will not be enabled and Strict SNI will not be enabled.
    • It does not matter what kind of certificate or duplicate.
    • Use "strict_sni_header on" if you do not want to respond to invalid headers. (only with strict_sni)
  • GeoIP2 Module - Issues #2

Upcoming Features

  • Auto build (rpm, deb, etc.)
  • Memory sharing(shm) for OCSP Stapling.
  • ETC.

Deprecated Features

  • SPDY (Not compatible this version.)
  • GeoIP (Changed to GeoIP2.)