使用系统二进制源方式安装
在ubuntu/debian系
sudo apt-get install nginx
或者redhat/centos系
sudo yum install nginx
这种方式最简单的,最快捷的方式,但是不是最好的方式,下面我们来说这种主要问题。
优点
所有安装二进制依赖已经处理好了,不用担心兼容性问题,开箱即用
nginx的连接配置,用户权限这个都不用处理,已经帮你写好这块了
不用担心nginx bug维护升级问题,直接获取最新系统就可以了
卸载简单,直接一个命令即可
日志维护简单,自动截断当天日志,压缩保存
缺点
不能自主选择安装版本
不能自主选择编译的模块
扩展功能变得很麻烦,需要重新编译
目类结构复杂,配置文件在/etc/下,部署文件在/var/www
重启服务,修改配置都需要root权限
性能差一点编译安装
如果你是一个linux新手,绝对推荐使用这中方式安装,不用考虑编译依赖问题,直接安装完就可以使用。但是如果你这个服务器是用于生产环境正在开发逐步完善的过程,不推荐使用这种方式。将来可能会添加第三方模块,到时肯定要编译安装(下面会说到)。在重启服务器的时候,不要使用root用户,而是使用sudo短暂获取root。如果你这条服务器都是用来部署一些静态文件,主要做一些web空间,平常主要用ftp工具部署文件,用这种方式肯定没什么问题的。
编译安装
优缺点,我就不写了,基本就是上面的颠倒过来就可以了。使用这种方法安装,都必须懂一点linux编译知识,linux中度用户才可以驾驭。我看见网上大多数教程,都是将编译依赖直接装在/usr/local/这种方式并不好。如果将来我们要卸载这些依赖,发现非常麻烦。并不是直接在目类下直接删除就可以完事的,有些linux发行版本,会将安装文件,写入配置文件中,这些配置文件有不知道哪里找。如果依赖版本影响到其他软件,怎么处理版本问题。我们只想安装nginx,结果延申出一大堆问题。
编译环境准备
在开始之前,保证你的linux准备了gcc、make、wget,g++ 这些软件。
创建一个目类用来存放下载文件,进入目录中下载依赖库源文件
下载openssl主要用于ssl模块加密,支持htps
wget https://www.openssl.org/source/openssl-1.0.2s.tar.gz
下载pcre来实现对地址重定向,地址重写功能和localtion指令以及正则表达式的支持
wget https://ftp.pcre.org/pub/pcre/pcre-8.43.tar.gz
下载zlib gzip压缩模块
wget https://zlib.net/zlib-1.2.11.tar.gz
下载nginx
wget http://nginx.org/download/nginx-1.17.1.tar.gz
使用tar 解压所有的文件
ls *.tar.gz | xargs -n1 tar xzvf
编译选项
使用./configure设置各种nginx参数的脚本,包括源和配置文件的路径,编译器选项,连接处理方法和模块列表。该脚本通过创建编译代码和安装nginx开源所需的makefile来完成。
参数 | 描述 |
---|---|
–prefix=98953a78f52873edae60a617ec082494 | nginx安装目录,以及有其他配置脚本选项的路径设置的所有相对路径的基本位置。默认值/usr/local/nginx |
–sbin-path=7988e5ef09cb060996e437e0d2342881/sbin/nginx | |
–conf-path=98953a78f52873edae60a617ec082494 | nginx配置文件的名称。但是,您可以通过在nginx命令行上使用选项指定其他文件来始终在启动时覆盖此值。默认值:aac119f8a3a563a827b4e4c50481b4e7 conf / nginx.conf-c 2334ac29606bf8a170583e4f7533b1f4 |
–pid-path=98953a78f52873edae60a617ec082494 | nginx.pid文件的名称,用于存储nginx主进程的进程id 。安装后,可以使用nginx配置文件中的pid指令更改文件名的路径。默认值:aac119f8a3a563a827b4e4c50481b4e7 /logs/nginx.pid |
–error-log-path=98953a78f52873edae60a617ec082494 | error,warn和诊断数据的日志文件的名称。安装后,可以使用nginx配置文件中的error_log指令更改文件名。默认值:aac119f8a3a563a827b4e4c50481b4e7 /logs/error.log |
–http-log-path=98953a78f52873edae60a617ec082494 | http服务器请求的主日志文件的名称。安装后,始终可以使用nginx配置文件中的access_log指令更改文件名。默认值:aac119f8a3a563a827b4e4c50481b4e7 /logs/access.log |
–user=8a11bc632ea32a57b3e3693c7987c420 | nginx运行进程的拥有者。安装后,可以使用nginx配置文件中的user指令更改名称。默认:nobody |
–group=name | nginx运行进程的拥有者用户组。安装后,可以使用nginx配置文件中的user指令更改名称。默认值:–user选项设置的值 |
–with-pcre=98953a78f52873edae60a617ec082494 | pcre库源代码的路径,这是位置指令和rewrite模块中正则表达式支持所必需的 |
–with-pcre-jit | 使用“即时编译”支持(pcre_jit指令)构建pcre库 |
–with-zlib=98953a78f52873edae60a617ec082494 | zlib库的源代码路径,gzip模块需要该路径 |
–with-http_ssl_modul | 启用https支持 |
–with-http_v2_module | 开启 http/2请求支持 |
还要太多编译参数我就不一一列举,有兴趣的同学可以自己去
参看
编译安装
./configure \ --with-openssl=../openssl-1.0.2s \ --with-pcre=../pcre-8.43 \ --with-zlib=../zlib-1.2.11 \ --with-pcre-jit --user=admin \ --prefix=/home/admin/nginx \ --with-http_ssl_module \ --with-http_v2_module
输出以下信息,说明依赖没问题
configuration summary + using pcre library: ../pcre-8.43 + using openssl library: ../openssl-1.0.2s + using zlib library: ../zlib-1.2.11 nginx path prefix: "/home/admin/nginx" nginx binary file: "/home/admin/nginx/sbin/nginx" nginx modules path: "/home/admin/nginx/modules" nginx configuration prefix: "/home/admin/nginx/conf" nginx configuration file: "/home/admin/nginx/conf/nginx.conf" nginx pid file: "/home/admin/nginx/logs/nginx.pid" nginx error log file: "/home/admin/nginx/logs/error.log" nginx http access log file: "/home/admin/nginx/logs/access.log" nginx http client request body temporary files: "client_body_temp" nginx http proxy temporary files: "proxy_temp" nginx http fastcgi temporary files: "fastcgi_temp" nginx http uwsgi temporary files: "uwsgi_temp" nginx http scgi temporary files: "scgi_temp"
编译
make
安装
make install
设置权限
因为linux设置普通用户,不能占用1024一下的端口,直接启动nginx会出现权限不足的错误。将nginx分配给root用户,在分配特殊权限。
sudo chown root nginx sudo chmod u+s nginx
以上是Linux中安装Nginx实例分析的详细内容。更多信息请关注PHP中文网其他相关文章!