linux中下载nginx

Nginx是一款高性能的开源Web服务器软件。它可以作为一个HTTP服务器进行网站的发布,也可以作为反向代理服务器进行负载均衡。Nginx以其出色的性能、稳定性和低资源消耗而受到广泛的使用。它的特点包括支持并发连接数高、内存消耗低、事件驱动等,适用于大部分的网站环境。

nginx文件结构

1、全局块:

配置影响nginx全局的指令。一般有运行nginx服务器的用户组,nginx进程pid存放路径,日志存放路径,配置文件引入,允许生成worker process数等。

2、events块:

配置影响nginx服务器或与用户的网络连接。有每个进程的最大连接数,选取哪种事件驱动模型处理连接请求,是否允许同时接受多个网路连接,开启多个网络连接序列化等。

3、http块:

可以嵌套多个server,配置代理,缓存,日志定义等绝大多数功能和第三方模块的配置。如文件引入,mime-type定义,日志自定义,是否使用sendfile传输文件,连接超时时间,单连接请求数等。

4、server块:

配置虚拟主机的相关参数,一个http中可以有多个server。

5、location块:

配置请求的路由,以及各种页面的处理情况。

nginx下载地址:

nginx: download

本次使用 1.20.2 版本

1.下载软件包(本次下载到的是/usr/local/src目录下)

wget https://nginx.org/download/nginx-1.20.2.tar.gz

2.安装依赖项

yum -y install gcc pcre-devel zlib-devel openssl openssl-devel

3.安装nginx

解压

tar -zxvf nginx-1.20.2.tar.gz

进入NG目录

cd ./nginx-1.20.2

配置

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

编译

make

make install

4.配置systemd方式管理

vim /usr/lib/systemd/system/nginx.service

复制代码
[Unit]
Description=The Nginx HTTP Server
After=network.target remote-fs.target nss-lookup.target

[Service]
Type=forking
PIDFile=/usr/local/nginx/logs/nginx.pid
ExecStart=/usr/local/nginx/sbin/nginx
ExecReload=/usr/local/nginx/sbin/nginx -s reload
ExecStop=/usr/local/nginx/sbin/nginx -s stop
PrivateTmp=true

[Install]
WantedBy=multi-user.target
5.操作

systemctl start nginx.service #(启动nginx服务)

systemctl stop nginx.service #(停止nginx服务)

systemctl enable nginx.service #(设置开机自启动)

systemctl disable nginx.service #(停止开机自启动)

systemctl status nginx.service #(查看服务当前状态)

systemctl restart nginx.service #(重新启动服务)

systemctl list-units --type=service #(查看所有已启动的服务)

6.配置反向代理

nginx反向代理有以下几个主要的优势和用途:

  1. 负载均衡:Nginx可以将客户端的请求分发到多个后端服务器上,以减轻单个服务器的压力,并提高整体的性能和可靠性。

  2. 高可用性和容错:通过使用多个后端服务器,如果某个服务器发生故障或者不可用,Nginx可以自动将请求转发到其他可用的服务器上,确保服务的连续性。

  3. 缓存:Nginx可以缓存后端服务器的响应,减少对后端服务器的请求,提高响应速度,并减轻后端服务器的负载。

  4. 安全性:Nginx可以过滤和拦截恶意请求,以保护后端服务器免受攻击。

通过配置反向代理,可以将Nginx作为一个中间层,提供负载均衡、高可用性和安全性等功能,以满足不同场景下的需求。

配置 /usr/local/nginx/conf/nginx.conf
拓展
nginx负载均衡
复制代码
upstream webset{
​		server 192.168.0.1:8080 weight=1; # 应用服务器1
​		server 192.168.0.1:8088 weight=2; # 应用服务器2
​		server 192.168.0.1:8090 backup; # 热备
​		ip_hash; # 相同ip请求相同服务器
​	}
​	server {
​		listen 80;
​		location / {
​			proxy_pass http://webset;
​		}
​	}
nginx虚拟主机
复制代码
server {
​		listen 80 default_server;
​		server_name _;
​		return 444; # 过滤其他域名的请求,返回444状态码
​	}
​	server {
​		listen 80;
​		server_name www.aaa.com; # www.aaa.com域名
​		location / {
​			proxy_pass http://localhost:8080; # 对应端口号8080
​		}
​	}
​	server {
​		listen 80;
​		server_name www.bbb.com; # www.bbb.com域名
​		location / {
​			proxy_pass http://localhost:8081; # 对应端口号8081
​		}
​	}

如有错误给孩子提醒一下,感谢观看!

相关推荐
戴为沐1 天前
Linux内存扩容指南
linux
zylyehuo2 天前
Linux 彻底且安全地删除文件
linux
用户805533698032 天前
主线 U-Boot 上 RK3506:和闭源 rkbin 拔河的三个隐性契约
linux·嵌入式
用户034095297912 天前
linux fcitx 5 雾凇拼音 设置在中文输入法下仍然输入英文标点
linux
乘云数字DATABUFF2 天前
5分钟部署开源APM Databuff:OpenTelemetry全链路追踪入门实战
运维·后端
Web3探索者4 天前
可视化服务器管理和传统命令行区别是什么?新手教程:Linux 运维到底该用图形界面还是 SSH 命令行?
linux·ssh
zylyehuo4 天前
Linux系统中网线与USB网络共享冲突
linux
荣--4 天前
一键部署不是为了省时间 —— 它是把"买来的 PaaS"变成"自己的平台"的拐点
运维·zabbix·工程化·一键部署·平台化·边界设计
江华森4 天前
动手实战学 Docker — 从零到集群编排完全指南
运维
Avan_菜菜5 天前
FRP 内网穿透完整实战:从 HTTP 映射到 HTTPS 自签代理
运维·nginx·https