nginx

关注公众号 jb51net

关闭
首页 > 网站技巧 > 服务器 > nginx > Nginx基础安装+配置文件

Nginx基础安装+配置文件过程

作者:嘻嘻嘻哈哈哈嘻嘻嘻

这篇文章主要介绍了Nginx基础安装+配置文件过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

一.Nginx基础

1.基础知识点

Nginx 是一个 轻量级、高性能的Web服务应用,可以作为 HTTP 服务器、虚拟主机、反向代理服务器、负载均衡器,以及支持 TCP/UDP 的通用代理服务器。

特点:稳定性高、不容易宕机;开源免费;内存/cpu资源消耗较少;并发能力高,至少能同时处理2-3万并发,最多能支持5万并发

2.异步非阻塞机制

Nginx 的异步非阻塞机制通过 事件驱动模型 和 I/O 多路复用技术 实现,使得单个 Worker 进程能够高效处理成千上万的并发连接。

1. Worker进程初始化,监听指定的端口(如80或443)。

2. 当有新的连接请求到达时,Worker进程接受该连接,并将其注册到事件循环中。

3. 事件循环使用I/O多路复用机制(epoll)来监视所有注册的文件描述符(即连接)。

4. 当某个连接上有可读或可写事件发生时,事件循环会触发相应的回调函数来处理该事件。

5. 在处理事件时,如果需要进行I/O操作(如读取请求数据或发送响应数据),这些操作会被异步执行,不会阻塞进程。

6. 处理完一个事件后,事件循环继续检查其他事件,循环往复。

二.Nginx安装

2.1安装nginx3种方式

1.包管理工具安装(yum/apt)

2.本地包安装(rpm/dpkg)

3.源码编译安装

原理:从Nginx官网下载源代码,手动编译并安装。

特点:

3.1 源码编译安装nginx流程(ubuntu)

1. 更新apt源、下载lrzsz工具

apt update
apt install -y lrzsz 用于本地主机和服务器相互传输文件

2.安装依赖包

ubuntu: apt -y install libpcre3-dev zlib1g-dev libssl-dev build-essential
centos: yum -y install gcc pcre-devel openssl-devel zlib-devel openssl openssl-devel

3.创建运行用户

Nginx 服务程序默认以 nobody 身份运行:useradd -M -s /sbin/nologin nginx

4.编译安装nginx

./configure --prefix=/usr/local/nginx \  #指定了Nginx的安装目录。在这种情况下,它将安装在 
                                          /usr/local/nginx 目录下。
--user=nginx --group=nginx \          #指定了运行Nginx进程的用户和组。在这种情况下,它将是用户 
                                      和组 nginx。
--with-http_gzip_static_module \       #启用了支持使用 .gz 扩展名提供预压缩文件的功能。
--with-http_flv_module \
--with-http_ssl_module \                #启用了对HTTP连接的SSL/TLS加密支持。
--with-http_realip_module \
--with-http_v2_module \                 #启用了对HTTP2.0协议的支持
--with-http_sub_module \               
--with-http_mp4_module \              
--with-http_stub_status_module \        #启用了 stub_status 模块,提供了访问Nginx状态信息的方 
                                       法。
--with-pcre \                          #启用了对Perl Compatible Regular Expressions(PCRE) 
                                       库的支持。
--with-stream \                        #启用了对TCP/UDP代理模块的支持。
--with-stream_ssl_module \             #启用了对TCP/UDP连接的SSL/TLS加密支持。
--with-stream_realip_module            #允许Nginx从PROXY协议头部获取客户端的真实IP地址。

make -j 2(cpu数量决定)

make -install (安装)

注意:

1.让系统识别nginx操作命令,将nginx的可执行文件做上软链接

2.更改nginx文件夹下的属主属组

chown -R nginx.nginx /usr/local/nginx

5.检查、启动、重启、停止 nginx服务

1.检查nginx配置文件:/usr/local/nginx/conf/nginx_conf

nginx -t 检查配置文件是否有语法错误

2.启动nginx服务

3.停止nginx服务

4.重载nginx服务

5.日志分割,重新打开日志文件

nginx 存放日志文件的位置: /usr/local/nginx/logs

生成存放成功日志、错误日志的空文件:kill -USR1 $(cat /usr/local/nginx/logs/nginx.pid)

6.nginx如何前台启动

3.2nginx版本平滑升级

kill -USR2 <PID号>

注意:升级完成后要使用绝对路径启动服务,否则升级可能会报错

3.3添加 Nginx 系统服务管理

因为编译安装没有service文件,如果想要系统服务统一管理systemed,需要编写service文件。

service 文件

[Unit]
Description=nginx
After=network.target

[Service]
Type=forking
PIDFile=/usr/local/nginx/logs/nginx.pid
ExecStart=/usr/local/nginx/sbin/nginx
ExecReload=/bin/kill -s HUP $MAINPID
ExecStop=/bin/kill -s QUIT $MAINPID
PrivateTmp=true

[Install]
WantedBy=multi-user.target

三.nginx进程

以处理 HTTP 请求为例:

1. 核心优势

nginx配置文件的路径: /usr/local/nginx/conf/nginx_conf

全局块:全局配置,对全局生效;

注意:http模块中还可以第三方模块的配置

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文