news 2026/5/13 9:57:22

NGINX服务(六)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
NGINX服务(六)

nginx 服务

nginx 定位

web 服务器、反向代理服务器、缓存服务器、邮件服务器

架构:master【程序管理】-worker【处理请求的】

安装方式:二进制包、源码包【注意编译环境】

配置结构:全局、event、http [server【location】]

server 重要属性:listen(指定监听端口)、root(设定网站根目录)、index(设定默认首页)、alias(别名,映射)

location 重要属性:root(拼接访问路径与本地目录)、index(指定默认访问文件)、alias(精准匹配替换访问路径)

访问流量逻辑:客户端请求→监听端口匹配 server 虚拟主机→匹配对应 location→按规则转发 / 反向代理 / 返回静态资源→响应数据回传给客户端。

nginx 功能

多网站(配置多虚拟主机,也就是多server块)、

alias 和 root (实现网站目录路径映射)、

日志(访问日志,错误日志记录)、

状态页面(stub_status查看运行状态)、

身份认证(账号密码,登录校验)、

https(SSL证书加密传输 )

[rewrite(URL地址重写跳转)]、

防盗链(通过Referer拦截非法盗链)

nginx实践


nginx动静分离

注:client(客户端) 12主机

proxy Server代理 Ubuntu13

API server动态 ubuntu 16

Static server静态 openuler

1.OpenEuler实现静态分离服务配置环境

echo "Static Web Server" > /usr/share/nginx/html/index.html

cat /etc/nginx/default.d/simple.conf
location / {
add_header X-Host $host;
}

启动nginx服务

systemctl start nginx

关闭防火墙

systemctl stop firewalld

测试效果

curl localhost

2.ubuntu16动态配置,定制python的web服务

from http.server import BaseHTTPRequestHandler, HTTPServer class SimpleHTTPRequestHandler(BaseHTTPRequestHandler): def do_GET(self): # 获取请求的URL路径 url_path = self.path # 获取请求头中的Host信息 host = self.headers.get('Host') # 设置响应状态码 self.send_response(200) # 设置响应头 self.send_header('Content-type', 'text/plain; charset=utf-8') self.end_headers() # 构造响应内容 response_content = f'API Server: {url_path}, Host Header: {host}\n' # 发送响应内容 self.wfile.write(response_content.encode('utf-8')) def run(server_class=HTTPServer, handler_class=SimpleHTTPRequestHandler, port=8080): server_address = ('', port) httpd = server_class(server_address, handler_class) print(f'Starting httpd server on port {port}') httpd.serve_forever() if __name__ == '__main__': run(port=8080)

启动python服务

python3 simple_http_server.py > /dev/null 2&1 &

测试

curl 10.0.0.16:8080/nihao

实现代理配置ubuntu13

server { listen 80 default_server; server_name sswang.magedu.com; root /data/server/nginx/web1; location /api { proxy_pass http://10.0.0.16:8080; proxy_set_header Host "api.magedu.com"; } location /static { rewrite ^/static(.*)$ /index.html break; proxy_pass http://10.0.0.14; proxy_set_header Host "static.magedu.com"; } location /static1/ { proxy_pass http://10.0.0.14/; proxy_set_header Host "static.magedu.com"; } }

重启服务

systemctl restart nginx

测试效果

nginx -t && systemctl restart nginx

curl -H "sswang.magedu.com" 10.0.0.13
curl -H "sswang.magedu.com" 10.0.0.13/api
curl -H "sswang.magedu.com" 10.0.0.13/static
curl -H "sswang.magedu.com" 10.0.0.13/static1
curl -H "sswang.magedu.com" 10.0.0.13/static1 -L
curl -H "sswang.magedu.com" 10.0.0.13/static1 -I

1

客户端测试rocky12

curl -H "sswang.magedu.com" 10.0.0.13/static1 -L
curl -H "sswang.magedu.com" 10.0.0.13/static1 -I

Nginx+Node+NPM 实验

实验名称:Nginx 反向代理对接 Node.js NPM 项目综合演示 实验主机:

  1. 代理端:Rocky 10-15(IP 10.0.0.15,部署 Nginx)
  2. 服务端:Rocky 10-12(IP 10.0.0.12,部署 Node+NPM)

二、后端 10.0.0.12 Node 服务端

安装 Node.js 和 NPM 环境 执行命令:

dnf install nodejs npm -y

node -v

npm -v

创建实验项目目录并初始化 NPM 项目 执行命令:

mkdir -p /opt/nginx-node-demo

cd /opt/nginx-node-demo npm init -y

编写 Node 演示 Web 服务 执行命令创建服务文件:

vim index.js

放行端口、关闭安全拦截 执行命令:

firewall-cmd --add-port=3000/tcp --permanent

firewall-cmd --reload

setenforce 0

启动 Node 后端服务 执行命令:

node index.js


三、前端 10.0.0.15 Nginx 代理端

安装 Nginx 服务 执行命令:

dnf install nginx -y

创建反向代理配置文件 执行命令:

vim /etc/nginx/conf.d/node-proxy.conf

server { listen 80; server_name _; location / { proxy_pass http://10.0.0.12:3000; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } }

校验配置并重启 Nginx 执行命令:

nginx -t

systemctl restart nginx

systemctl enable nginx

放行 Nginx 80 端口 执行命令:

firewall-cmd --add-service=http --permanent

firewall-cmd --reload


四、连通验证步骤

在 10.0.0.15 代理主机执行测试访问 curl localhost

浏览器直接访问 http://10.0.0.15 成功看到 Node 后端返回文字,代表整个实验全部完成


五、NPM 演示

在后端项目目录执行 NPM 包管理操作: npm install express --save 实现 Express 框架的 Node Web 项目部署演示

nginx反向代理实验

部署python环境

apt -y install python3 python3-pip nginx build-essential python3-dev python3-venv

创建python虚拟环境

cd /data/
ls
python3 -m venv myprojectenv
source myprojectenv/bin/activate

安装django环境
pip config set global.index-url https://pypi.doubanio.com/simple
pip config set install.trusted-host pypi.doubanio.com
pip install django
pip install uwsgi

安装django项目

django-admin startproject myproject

配置django项目

cd myproject
ls


vim myproject/settings.py

数据库环境初始化

python manage.py makemigrations
python manage.py migrate

创建登录用户

python manage.py createsuperuser

定制配置

vim myproject/settings.py


收集静态文件

python manage.py collectstatic


在项目根目录下创建一个uwsgi.ini文件

vim uwsgi.ini


赋予权限

chown -R www-data:www-data /data/myproject
chmod -R 755 /data/myproject

创建一个名为uwsgi.service文件

vim /etc/systemd/system/uwsgi.service


启动服务

systemctl daemon-reload
systemctl start uwsgi.service
systemctl is-active uwsgi.service

定制nginx配置

vim /etc/nginx/conf.d/myproject.conf


检测配置文件

nginx -t

启动项目

systemctl start nginx.service


systemctl is-active nginx.service

测试效果



版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/13 9:55:39

learn claude code S12 Worktree 任务隔离详解笔记

S12 Worktree 任务隔离详解笔记基于 s12_worktree_task_isolation.py 源码逐行分析,配合 s12-worktree-task-isolation.md 设计思路。一、问题:多个任务共享一个工作目录,互相踩踏 前面 11 章的 agent 都在同一个工作目录下操作。当只有一个 …

作者头像 李华
网站建设 2026/5/13 9:53:42

opencv-第四章:图像轮廓检测

OpenCV-计算机视觉技术(林伟鹏版) 第四章:图像轮廓检测 文章目录OpenCV-计算机视觉技术(林伟鹏版)前言一、图像轮廓检测概念1.概念二、图像轮廓检测1.图像二值化转换2.图像轮廓匹配3.二值图轮换轮廓检测4.图像轮廓检测…

作者头像 李华
网站建设 2026/5/13 9:50:47

别只会拔电源!Linux 关机的 7 种正确打开方式

文章目录别只会拔电源!Linux 关机的 7 种正确打开方式1. 命令行标准关机(推荐,数据安全)2. 强制/紧急关机(服务不优雅停止,可能丢数据)3. 图形界面方式4. 远程关机5. 物理硬件方式6. 定时关机与…

作者头像 李华
网站建设 2026/5/13 9:46:23

终极指南:用Python快速自动化你的COMSOL多物理场仿真工作流

终极指南:用Python快速自动化你的COMSOL多物理场仿真工作流 【免费下载链接】MPh Pythonic scripting interface for Comsol Multiphysics 项目地址: https://gitcode.com/gh_mirrors/mp/MPh 你是否厌倦了在COMSOL图形界面中重复点击菜单?是否希望…

作者头像 李华
网站建设 2026/5/13 9:44:41

URLSearchParams详解:轻松处理URL查询参数

一、引言 在前端开发中,处理URL查询参数是一个非常常见的需求。无论是解析URL中的参数、构建查询字符串,还是动态修改参数,都需要一套简洁高效的API。 过去,开发者通常需要手动拼接字符串或使用正则表达式来解析URL参数&#xf…

作者头像 李华