百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Nginx安装与编译

off999 2025-01-06 14:48 20 浏览 0 评论

一、Nginx的概念

在传统的web项目部署中是将一个项目部署到一个web的服务器中,此时就会存在一个问题,当一台服务器无法承载高的访问量的时候,就会显得很慢,如果一台服务器宕机了,那么用户就无法访问了,如果是一个很大的项目就会造成无法估量的损失。 针对以上的问题,我们可以考虑使用一定的算法将访问分发到多个web的服务器中,就是说可以将web项目部署到多台服务器上,此时如果用户的访问量继续增加则可以再继续增加服务器的数量来均衡用户的访问,在这种情况下就算其中一台服务器宕机了则不会影响用户的访问来降低服务器宕机带来的损失。 这种使用多台服务器分担压力的行为就叫做负载均衡,使用负载均衡实现服务器解决高并发访问带来的压力,同时其中某台服务器宕机之后用户还可以继续访问,这实现了高可用。目前常用的web服务器代理是nginx,就是一个反向服务代理。


二、Nginx的安装和编译

1、下载Nginx服务器安装文件

官方下载网站:https://nginx.org/en/download.html


2、将所有的开发包解压到/usr/local/src下

tar -xzvf ngx_cache_purge-2.3.tar.gz -C /usr/local/src/

tar -xzvf nginx-upstream-fair-a18b409.tar.gz -C /usr/local/src/

tar -xzvf nginx-1.11.3.tar.gz -C /usr/local/src/

tar -xzvf keepalived-1.2.24.tar.gz -C /usr/local/src/

tar -xzvf echo-nginx-module-0.59.tar.gz -C /usr/local/src/

以上的开发包是源码,需要进行编译和安装后才能使用,Nginx默认情况下编译后的文件都会保存到源码的文件中,这样非常不方便,所以需要单独创建一个文件目录保存有关Nginx的所有配置,mkdir –p 就是递归创建目录

mkdir -p /usr/local/nginx/{logs,conf,fastcgi_temp,sbin,client_body_temp,proxy_temp,uwsgi_temp,scgi_temp}

3、进入Nginx的源码目录

cd /usr/local/src/nginx-1.11.3/

4、配置编译项

在配置编译项之前,为了防止编译不成功,需要安装相关的开发包

apt-get install gcc libpcre3 libpcrecpp* libpcre3-dev libssl-dev

在编译时会生成一些配置文件,可执行文件,一些有关的库,下面的操作就是指定生成的这些文件指定的保存路径,不让其默认保存,方便我们后期修改配置文件

./configure --prefix=/usr/local/nginx/ \

--sbin-path=/usr/local/nginx/sbin/ \

--with-http_ssl_module \

--conf-path=/usr/local/nginx/conf/nginx.conf \

--pid-path=/usr/local/nginx/logs/nginx.pid \

--error-log-path=/usr/local/nginx/logs/error.log \

--http-log-path=/usr/local/nginx/logs/access.log \

--http-fastcgi-temp-path=/usr/local/nginx/fastcgi_temp \

--http-client-body-temp-path=/usr/local/nginx/client_body_temp\

--http-proxy-temp-path=/usr/local/nginx/proxy_temp \

--http-uwsgi-temp-path=/usr/local/nginx/uwsgi_temp \

--http-scgi-temp-path=/usr/local/nginx/scgi_temp \

--add-module=/usr/local/src/echo-nginx-module-0.59 \

--add-module=/usr/local/src/gnosek-nginx-upstream-fair-a18b409\

--add-module=/usr/local/src/ngx_cache_purge-2.3

相关参数的解析

--prefix= 指向安装目录。

--sbin-path= 指定执行程序文件存放位置。

--modules-path= 指定第三方模块的存放路径。

--conf-path= 指定配置文件存放位置。

--error-log-path= 指定错误日志存放位置。

--pid-path= 指定pid文件存放位置。

--lock-path= 指定lock文件存放位置。

--user= 指定程序运行时的非特权用户。

--group= 指定程序运行时的非特权用户组。

--builddir= 指向编译目录。

--with-rtsig_module 启用rtsig模块支持。

--with-select_module 启用select模块支持,一种轮询处理方式,不推荐在高并发环境中使用,禁用:--without-select_module。

--with-poll_module 启用poll模块支持,功能与select相同,不推荐在高并发环境中使用。

--with-threads启用thread pool支持。

--with-file-aio 启用file aio支持。

--with-http_ssl_module 启用https支持。

--with-http_v2_module 启用ngx_http_v2_module支持。

--with-ipv6 启用ipv6支持。

--with-http_realip_module 允许从请求报文头中更改客户端的ip地址,默认为关。

--with-http_addition_module 启用ngix_http_additon_mdoule支持(作为一个输出过滤器,分部分响应请求)。

--with -http_xslt_module 启用ngx_http_xslt_module支持,过滤转换XML请求 。

--with-http_image_filter_mdoule 启用ngx_http_image_filter_module支持,传输JPEG\GIF\PNG图片的一个过滤器,默认不启用,需要安装gd库。

--with-http_geoip_module 启用ngx_http_geoip_module支持,用于创建基于MaxMind GeoIP二进制文件相配的客户端IP地址的ngx_http_geoip_module变量。

--with-http_sub_module 启用ngx_http_sub_module支持,允许用一些其他文本替换nginx响应中的一些文本。

--with-http_dav_module 启用ngx_http_dav_module支持,增加PUT、DELETE、MKCOL创建集合,COPY和MOVE方法,默认为关闭,需要编译开启。

--with-http_flv_module 启用ngx_http_flv_module支持,提供寻求内存使用基于时间的偏移量文件。

--with-http_mp4_module 启用ngx_http_mp4_module支持,启用对mp4类视频文件的支持。

--with-http_gzip_static_module 启用ngx_http_gzip_static_module支持,支持在线实时压缩输出数据流。

--with-http_random_index_module 启用ngx_http_random_index_module支持,从目录中随机挑选一个目录索引。

--with-http_secure_link_module 启用ngx_http_secure_link_module支持,计算和检查要求所需的安全链接网址。

--with-http_degradation_module 启用ngx_http_degradation_module 支持允许在内存不足的情况下返回204或444代码。

--with-http_stub_status_module 启用ngx_http_stub_status_module 支持查看nginx的状态页。

--without-http_charset_module 禁用ngx_http_charset_module这一模块,可以进行字符集间的转换,从其它字符转换成UTF-8或者从UTF8转换成其它字符。它只能从服务器到客户端方向,只有一个字节的字符可以转换。

--without-http_gzip_module 禁用ngx_http_gzip_module支持,同--with-http_gzip_static_module功能一样。

--without-http_ssi_module 禁用ngx_http_ssi_module支持,提供了一个在输入端处理服务器包含文件(SSI)的过滤器。

--without-http_userid_module 禁用ngx_http_userid_module支持,该模块用来确定客户端后续请求的cookies。

--without-http_access_module 禁用ngx_http_access_module支持,提供了基于主机ip地址的访问控制功能。

--without-http_auth_basic_module 禁用ngx_http_auth_basic_module支持,可以使用用户名和密码认证的方式来对站点或部分内容进行认证。

--without-http_autoindex_module 禁用ngx_http_authindex_module,该模块用于在ngx_http_index_module模块没有找到索引文件时发出请求,用于自动生成目录列表。

--without-http_geo_module 禁用ngx_http_geo_module支持,这个模块用于创建依赖于客户端ip的变量。

--without-http_map_module 禁用ngx_http_map_module支持,使用任意的键、值 对设置配置变量。

--without-http_split_clients_module 禁用ngx_http_split_clients_module支持,该模块用于基于用户ip地址、报头、cookies划分用户。

--without-http_referer_module 禁用ngx_http_referer_modlue支持,该模块用来过滤请求,报头中Referer值不正确的请求。

--without-http_rewrite_module 禁用ngx_http_rewrite_module支持。该模块允许使用正则表达式改变URI,并且根据变量来转向以及选择配置。如果在server级别设置该选项,那么将在location之前生效,但如果location中还有更进一步的重写规则,location部分的规则依然会被执行。如果这个URI重写是因为location部分的规则造成的,那么location部分会再次被执行作为新的URI,这个循环会被执行10次,最后返回一个500错误。

--without-http_proxy_module 禁用ngx_http_proxy_module支持,http代理功能。

--without-http_fastcgi_module 禁用ngx_http_fastcgi_module支持,该模块允许nginx与fastcgi进程交互,并通过传递参数来控制fastcgi进程工作。

--without-http_uwsgi_module 禁用ngx_http_uwsgi_module支持,该模块用来使用uwsgi协议,uwsgi服务器相关。

--without-http_scgi_module 禁用ngx_http_scgi_module支持,类似于fastcgi,也是应用程序与http服务的接口标准。

--without-http_memcached_module 禁用ngx_http_memcached支持,用来提供简单的缓存,提高系统效率。

--without-http_limit_conn_module 禁用ngx_http_limit_conn_module支持,该模块可以根据条件进行会话的并发连接数进行限制。

--without-http_limit_req_module 禁用ngx_limit_req_module支持,该模块可以实现对于一个地址进行请求数量的限制。

--without-http_empty_gif_module 禁用ngx_http_empty_gif_module支持,该模块在内存中常驻了一个1*1的透明gif图像,可以被非常快速的调用。

--without-http_browser_module 禁用ngx_http_browser_mdoule支持,创建依赖于请求报头的值 。如果浏览器为modern,则$modern_browser等于modern_browser_value的值;如果浏览器为old,则$ancient_browser等于$ancient_browser_value指令分配的值;如果浏览器为MSIE,则$msie等于1。

--without-http_upstream_ip_hash_module 禁用ngx_http_upstream_ip_hash_module支持,该模块用于简单的负载均衡。

--with-http_perl_module 启用ngx_http_perl_module支持,它使nginx可以直接使用perl或通过ssi调用perl。

--with-perl_modules_path= 设定perl模块路径

--with-perl= 设定perl库文件路径

--http-log-path= 设定access log路径

--http-client-body-temp-path= 设定http客户端请求临时文件路径

--http-proxy-temp-path= 设定http代理临时文件路径

--http-fastcgi-temp-path= 设定http fastcgi临时文件路径

--http-uwsgi-temp-path= 设定http scgi临时文件路径

--http-scgi-temp-path= 设定http scgi临时文件路径

--without-http 禁用http server功能

--without-http-cache 禁用http cache功能

--with-mail 启用POP3、IMAP4、SMTP代理模块

--with-mail_ssl_module 启用ngx_mail_ssl_module支持

--without-mail_pop3_module 禁用pop3协议。

--without-mail_iamp_module 禁用iamp协议。

--without-mail_smtp_module 禁用smtp协议。

--with-google_perftools_module 启用ngx_google_perftools_mdoule支持,调试用,可以用来分析程序性能瓶颈。

--with-cpp_test_module 启用ngx_cpp_test_module支持。

--add-module= 指定外部模块路径,启用对外部模块的支持。

--with-cc= 指向C编译器路径。

--with-cpp= 指向C预处理路径。

--with-cc-opt= 设置C编译器参数,指定--with-cc-opt="-I /usr/lcal/include",如果使用select()函数,还需要同时指定文件描述符数量--with-cc-opt="-D FD_SETSIZE=2048"。 (PCRE库)

--with-ld-opt= 设置连接文件参数,需要指定--with-ld-opt="-L /usr/local/lib"。(PCRE库)

--with-cpu-opt= 指定编译的CPU类型,如pentium,pentiumpro,...amd64,ppc64...

--without-pcre 禁用pcre库。

--with-pcre 启用pcre库。

--with-pcre= 指向pcre库文件目录。

--with-pcre-opt= 在编译时为pcre库设置附加参数 。

--with-md5= 指向md5库文件目录。

--with-md5-opt= 编译时为md5库设置附加参数。

--with-md5-asm 使用md5汇编源。

--with-sha1= 指向sha1库文件目录。

--with-sha1-opt= 编译时为sha1库设置附加参数。

--with-sha1-asm 使用sha1汇编源。

--with-zlib= 指向zlib库文件目录。

--with-zlib-opt= 在编译时为zlib设置附加参数。

--with-zlib-asm= 为指定的CPU使用汇编源进行优化。

--with-libatomic 为原子内存的更新操作的实现提供一个架构。

--with-libatomic= 指向libatomic_ops的安装目录。

--with-openssl= 指向openssl安装目录。

--with-openssl-opt= 在编译时为openssl设置附加参数。

--with-debug 启用debug日志。

成功之后会出现如下信息


5、执行编译命令 make,编译成功后显示如下信息

在执行make命令的时候,有可能还没有下载相关的开发包,需要执行apt-get install make 下载相关的开发包

6、进行Nginx安装

make install

7、启动命令

/usr/local/nginx/sbin ./nginx

8、启动之后nginx默认占用的端口号是80.我们从浏览器直接访问地址

出现以上显示页面说明Nginx安装成功

相关推荐

在NAS实现直链访问_如何访问nas存储数据

平常在使用IPTV或者TVBOX时,经常自己会自定义一些源。如何直链的方式引用这些自定义的源呢?本人基于armbian和CasaOS来创作。使用标准的Web服务器(如Nginx或Apache...

PHP开发者必备的Linux权限核心指南

本文旨在帮助PHP开发者彻底理解并解决在Linux服务器上部署应用时遇到的权限问题(如Permissiondenied)。核心在于理解“哪个用户(进程)在访问哪个文件(目录)”。一、核心...

【Linux高手必修课】吃透sed命令!文本手术刀让你秒变运维大神!

为什么说sed是Linux运维的"核武器"?想象你有10万个配置文件需要批量修改?传统方式要写10万行脚本?sed一个命令就能搞定!这正是运维工程师的"暴力美学"时...

「实战」docker-compose 编排 多个docker 组成一个集群并做负载

本文目标docker-compose,对springboot应用进行一个集群(2个docker,多个类似,只要在docker-compose.yml再加boot应用的服务即可)发布的过程架构...

企业安全访问网关:ZeroNews反向代理

“我们需要让外包团队访问测试环境,但不想让他们看到我们的财务系统。”“审计要求我们必须记录所有第三方对内部系统的访问,现在的VPN日志一团糟。”“每次有新员工入职或合作伙伴接入,IT部门都要花半天时间...

反向代理以及其使用场景_反向代理实现过程

一、反向代理概念反向代理(ReverseProxy)是一种服务器配置,它将客户端的请求转发给内部的另一台或多台服务器处理,然后将响应返回给客户端。与正向代理(ForwardProxy)不同,正向代...

Nginx反向代理有多牛?一篇文章带你彻底搞懂!

你以为Nginx只是个简单的Web服务器?那可就大错特错了!这个看似普通的开源软件,实际上隐藏着惊人的能力。今天我们就来揭开它最强大的功能之一——反向代理的神秘面纱。反向代理到底是什么鬼?想象一下你...

Nginx反向代理最全详解(原理+应用+案例)

Nginx反向代理在大型网站有非常广泛的使用,下面我就重点来详解Nginx反向代理@mikechen文章来源:mikechen.cc正向代理要理解清楚反向代理,首先:你需要搞懂什么是正向代理。正向代理...

centos 生产环境安装 nginx,包含各种模块http3

企业级生产环境Nginx全模块构建的大部分功能,包括HTTP/2、HTTP/3、流媒体、SSL、缓存清理、负载均衡、DAV扩展、替换过滤、静态压缩等。下面我给出一个完整的生产环境安装流程(C...

Nginx的负载均衡方式有哪些?_nginx负载均衡机制

1.轮询(默认)2.加权轮询3.ip_hash4.least_conn5.fair(最小响应时间)--第三方6.url_hash--第三方...

Nginx百万并发优化:如何提升100倍性能!

关注△mikechen△,十余年BAT架构经验倾囊相授!大家好,我是mikechen。Nginx是大型架构的核心,下面我重点详解Nginx百万并发优化@mikechen文章来源:mikechen....

在 Red Hat Linux 上搭建高可用 Nginx + Keepalived 负载均衡集群

一、前言在现代生产环境中,负载均衡是确保系统高可用性和可扩展性的核心技术。Nginx作为轻量级高性能Web服务器,与Keepalived结合,可轻松实现高可用负载均衡集群(HA+LB...

云原生(十五) | Kubernetes 篇之深入了解 Pod

深入了解Pod一、什么是PodPod是一组(一个或多个)容器(docker容器)的集合(就像在豌豆荚中);这些容器共享存储、网络、以及怎样运行这些容器的声明。我们一般不直接创建Pod,而是...

云原生(十七) | Kubernetes 篇之深入了解 Deployment

深入了解Deployment一、什么是Deployment一个Deployment为Pods和ReplicaSets提供声明式的更新能力。你负责描述Deployment中的目标状...

深入理解令牌桶算法:实现分布式系统高效限流的秘籍

在高并发系统中,“限流”是保障服务稳定的核心手段——当请求量超过系统承载能力时,合理的限流策略能避免服务过载崩溃。令牌桶算法(TokenBucket)作为最经典的限流算法之一,既能控制请求的平...

取消回复欢迎 发表评论: