news 2026/2/16 4:20:20

Linux部署Nginx前后端web教程

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Linux部署Nginx前后端web教程

一、前言

目前Linux部署web类似于IIS,主要有两种方式来实现:Apache、Nginx;

Nginx性能更高一点,这里着重讲;

二、准备

1、安装 Nginx:

sudo apt install -y nginx

2、启动并设置 Nginx 开机自启:

sudo systemctl start nginx sudo systemctl enable nginx

3、验证 Nginx 是否运行正常:

sudo systemctl status nginx

4、查看防火墙开放端口:

sudo ufw status

若无,下载启用防火墙:

sudo apt install -y ufw sudo ufw enable

5、开放所需端口:

sudo ufw allow 80 /tcp

须知:80默认开放,所有与Linux交互的端口都必须开放,否则只本机能连;

三、部署前端

1、提前打包好前端文件;

2、将文件复制至var/www/html

须知:默认存在html文件夹,你也可自己创建文件夹,html内部有.html文件的话需删除或替换;

不会复制的看我上期:快速上手!查看、拷贝、编辑、远程连接Linux命令-CSDN博客

若使用的是自己创建的文件则,创建符号链接以启用该站点配置:

sudo ln -s /etc/nginx/sites-available/my_http_api(创建文件名称) /etc/nginx/sites-enabled/

测试配置文件是否正确:

sudo nginx -t

3、重启Nginx服务:

sudo systemctl restart nginx

4、成功样例:

须知:默认调用80端口,确保防火墙和公网开放80端口,若想自定义端口,可看部署后端配置文件配置;

四、部署后端

前言:这里所做的是Nginx转发后端,就是将Linux所对应端口所传入转发至另个服务器,另个服务器处理之后返回;

1、配置 Nginx :

sudo nano /etc/nginx/sites-available/default

须知:主配置文件通常位于/etc/nginx/nginx.conf,而站点配置文件通常位于/etc/nginx/sites-available/目录下;

nano命令操作文件快捷键:

只需要记住:ctrl+X退出,Y保存,enter关闭;

80默认存在,假设我需要8080,完整放入配置最下面

server { listen 8080; # 可更改8080端口 listen [::]:8080; root /var/www/html; # 部署web的根目录 index index.html index.htm; server_name _; location / { # 启用目录列表功能(一般不启用,看个人) # autoindex on; # autoindex_exact_size off; # 显示文件大小为人类可读格式(如 KB、MB) # autoindex_localtime on; # 显示文件的本地时间 try_files $uri $uri/ =404; } # 针对 .ashx 动态web文件,若服务器转发删除上发loaction,去除下方'#' # location ~ \.ashx$ { # proxy_pass http://ip:port; # 转发服务器部署IIS的http的url # proxy_set_header Host $host; # proxy_set_header X-Real-IP $remote_addr; # proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; # } }

针对https:

server { listen 443 ssl; # 可更改443端口 server_name your_domain; # 域名 # 指定根目录 root /var/www/html; index index.html; # SSL 配置 自定义证书路径 ssl_certificate /home/your_domain/fullchain.pfx; ssl_certificate_key /home/your_domain/privkey.txt; # SSL 安全设置(推荐) ssl_protocols TLSv1.2 TLSv1.3; ssl_prefer_server_ciphers on; ssl_ciphers HIGH:!aNULL:!MD5; # 处理请求的规则 location / { try_files $uri $uri/ =404; } # 针对 .ashx 动态web文件,若服务器转发删除上发loaction,去除下方'#' # location ~ \.ashx$ { # proxy_pass http://ip:port; # 转发服务器部署IIS的http的url # proxy_set_header Host $host; # proxy_set_header X-Real-IP $remote_addr; # proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } }

2、测试配置文件是否正确:

sudo nginx -t

3、重启Nginx服务:

sudo systemctl restart nginx

4、成功样例:

访问前端界面:

调用后端接口:

须知:10058是我自定义的,和上方8080一样,确保防火墙和公网开放端口;

五、结语

1、失败最大可能性是端口是否开放了;

2、转发服务器的url是否有效;

3、配置是否正确,配置后是否重启Nginx;

4、关于Linux命令操作教程:快速上手!查看、拷贝、编辑、远程连接Linux命令-CSDN博客

5、关于Linux与Mysql:Ubuntu Linux远程连接Mysql(Linux or Windows)_linux上服务连接window上的mysql服务-CSDN博客

6、关于部署.net:.net程序部署Linux运行_liunk部署net程序-CSDN博客

至此,关于Linux的运用大致概全了;

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

Altium Designer零基础实战:双层板设计完整示例

从零开始用 Altium Designer 设计一块双层板:STM32最小系统实战全记录 你是不是也曾经打开过 Altium Designer,面对密密麻麻的菜单和面板,不知道从哪里下手? 原理图画到一半,PCB 导入却报错;布线时走着走…

作者头像 李华
网站建设 2026/2/13 11:20:22

screen+与嵌入式Linux结合:构建高效GUI解决方案

用 screen 打造嵌入式 Linux 的“轻量级视觉引擎”:告别臃肿 GUI,实现丝滑交互你有没有遇到过这样的场景?手头是一款基于 Cortex-A7 的工业 HMI 设备,内存只有 128MB,主频不到 500MHz。客户却要求界面要有动画菜单、实…

作者头像 李华
网站建设 2026/2/12 10:53:28

LangFlow托福听力材料摘要生成系统

LangFlow在托福听力摘要生成中的实践与思考 在教育科技的浪潮中,如何让人工智能真正服务于教学一线,而不是停留在实验室或工程师的代码里?这个问题在处理托福听力材料时尤为突出。这类任务要求系统不仅能准确理解长段英文对话,还…

作者头像 李华
网站建设 2026/2/6 23:05:27

LangFlow离职面谈问题生成建议

LangFlow在离职面谈问题生成中的创新应用 在企业人力资源管理中,离职面谈本应是获取员工真实反馈、优化组织氛围的重要环节。然而现实中,许多HR仍依赖经验即兴提问,导致访谈内容零散、关键维度缺失,甚至因情绪化表达引发防御心理。…

作者头像 李华
网站建设 2026/2/8 13:11:48

LangFlow课程大纲自动生成工具开发

LangFlow课程大纲自动生成工具开发 在教育科技快速演进的今天,AI正以前所未有的速度重塑教学内容的生产方式。课程设计不再只是教案堆叠和经验复制,而是逐步走向智能化、个性化与高效化。尤其当高校、培训机构面临“新学科快速上线”“跨领域课程融合”等…

作者头像 李华