nginx入门与实践

当谈到NGINX的入门与实践时,理解基本概念并能够应用实际场景非常重要。NGINX是一个高性能的HTTP和反向代理服务器,也可用作负载均衡器和HTTP缓存。以下是一些入门级别的NGINX实践和代码示例,帮助你开始学习和使用它。

1. 安装和基本配置

安装NGINX

首先,你需要安装NGINX。具体安装方法取决于你的操作系统,例如在Ubuntu上可以通过以下命令安装:

sudo apt update
sudo apt install nginx
启动NGINX

安装完成后,可以使用以下命令启动NGINX服务:

sudo systemctl start nginx
停止NGINX

如果需要停止NGINX服务,可以使用:

sudo systemctl stop nginx
配置文件位置

NGINX的主配置文件通常位于 /etc/nginx/nginx.conf,而站点配置文件通常位于 /etc/nginx/sites-available/ 目录下。

2. 创建简单的HTTP服务器

创建一个简单的静态网站

假设你有一个简单的静态HTML页面,可以将其放在NGINX的默认网站目录 /var/www/html/ 下,然后通过浏览器访问该页面。以下是一个简单的示例:

/var/www/html/index.html 中创建一个文件:

<!DOCTYPE html>
<html>
<head><title>欢迎使用NGINX</title>
</head>
<body><h1>Hello, NGINX!</h1><p>这是一个简单的NGINX服务器示例。</p>
</body>
</html>
配置NGINX以提供该静态网站

编辑NGINX的默认站点配置文件 /etc/nginx/sites-available/default,添加一个 server 块来指定NGINX如何处理请求:

server {listen 80 default_server;listen [::]:80 default_server;root /var/www/html;index index.html;server_name _;location / {try_files $uri $uri/ =404;}
}

这个配置中:

  • listen 指定NGINX监听的端口(80端口是HTTP的默认端口)。
  • root 指定NGINX寻找文件的根目录。
  • index 指定默认的首页文件。
  • server_name 设置为 _ 表示匹配任何请求的主机名。
  • location / 定义了处理请求的位置。try_files 指令尝试寻找匹配的文件,如果找不到则返回404错误。

3. 使用NGINX作为反向代理

NGINX可以作为反向代理,将请求转发到不同的服务器上。

配置NGINX作为反向代理

假设你有一个Node.js应用运行在本地的3000端口上,可以通过NGINX将请求代理到该应用。

编辑NGINX的配置文件 /etc/nginx/sites-available/default

server {listen 80;server_name example.com;location / {proxy_pass http://localhost:3000;proxy_http_version 1.1;proxy_set_header Upgrade $http_upgrade;proxy_set_header Connection 'upgrade';proxy_set_header Host $host;proxy_cache_bypass $http_upgrade;}
}

在这个配置中:

  • server_name 指定NGINX监听的域名。
  • location / 定义了反向代理的位置。
  • proxy_pass 将请求代理到指定的后端服务器。
  • 其他 proxy_set_header 指令用于设置HTTP头部以确保反向代理正常工作。

4. 配置HTTPS

在生产环境中,通常需要配置HTTPS以提供安全的通信。

配置NGINX支持HTTPS

首先,你需要获取SSL证书(通常是通过Let’s Encrypt免费证书服务获取),然后配置NGINX以支持HTTPS。

编辑NGINX的配置文件 /etc/nginx/sites-available/default

server {listen 80;listen [::]:80;server_name example.com;return 301 https://$server_name$request_uri;
}server {listen 443 ssl http2;listen [::]:443 ssl http2;server_name example.com;ssl_certificate /path/to/fullchain.pem;ssl_certificate_key /path/to/privkey.pem;location / {proxy_pass http://localhost:3000;proxy_http_version 1.1;proxy_set_header Upgrade $http_upgrade;proxy_set_header Connection 'upgrade';proxy_set_header Host $host;proxy_cache_bypass $http_upgrade;}
}

这个配置中:

  • 第一个 server 块将所有HTTP请求重定向到HTTPS。
  • 第二个 server 块监听443端口(HTTPS默认端口)并配置SSL证书和私钥。
  • proxy_pass 和其他代理设置保持不变,但现在在加密的通信通道上进行。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/28728.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

栅格数据实现最优参数地理探测器(OPGD)详细教程!(上)

数据准备 要探寻一堆因素对因变量的影响,首先你要确定要用哪些自变量来影响哪个因变量 想好了之后 你需要到相应的网站去下载你的研究区的自变量和因变量数据的栅格数据(可以是离散的,也可以是连续的) 后续操作是到Arcgis里对你的数据处理一下 由于不是教程的重点,这里就…

uniApp @input事件更改输入框值,值改变了但是页面没更新新的值

<uni-easyinputtype"text"trim"all":inputBorder"false"v-model"customFormData.completePercent"input"(val) > completeOnInput(val)"placeholder"请输入" /> function completeOnInput(val) {let num…

less-loader的less转成CSS的底层原理

在现代Web开发中&#xff0c;CSS预处理器如LESS极大地提高了编写样式的效率和灵活性。而less-loader作为webpack的一个加载器&#xff0c;用于将LESS文件转换为CSS文件。本文将深入探讨less-loader如何工作&#xff0c;从解析LESS文件到生成最终的CSS文件的底层原理。 工作流程…

Go 基础丨切片 slice

1. 底层 runtime/slice.go type slice struct {array unsafe.Pointer // 指向底层数组len int // 切片元素数量cap int // 底层数组容量 }reflect/value.go type SliceHeader struct {Data uintptrLen intCap int }2. 创建 根据数组创建 s : arr[0:3]字面…

低功耗蓝牙ble开发(三)——基于bluez5接口的ble应用示例

5、应用实例 一般 BLE&#xff08;低功耗蓝牙&#xff09;设备的连接流程可以分为以下几个步骤&#xff1a; 启动设备发现&#xff1a;通过 StartDiscovery 方法开始扫描周围的 BLE 设备。监听设备发现信号&#xff1a;监听 InterfacesAdded 信号&#xff0c;以获取发现的设备…

【Linux】进程_7

文章目录 五、进程8. 进程地址空间9. 进程终止10. 进程等待 未完待续 五、进程 8. 进程地址空间 我们上节知道了进程地址空间是根据页表来使虚拟地址转换成内存中的物理地址&#xff0c;那这种 地址空间 页表 的机制有什么好处呢&#xff1f;①这种机制可以将物理内存从无序…

Elixir学习笔记——Erlang 库

Elixir 提供了与 Erlang 库的出色互操作性。事实上&#xff0c;Elixir 不鼓励简单地包装 Erlang 库&#xff0c;而是直接与 Erlang 代码交互。在本节中&#xff0c;我们将介绍一些 Elixir 中没有的最常见和最有用的 Erlang 功能。 Erlang 模块的命名约定与 Elixir 不同&#x…

Springboot整合阿里云ONS RocketMq(4.0 http)

1. 引入依赖 <!--阿里云ons&#xff0c;方便的接入到云服务--> <dependency><groupId>com.aliyun.openservices</groupId><artifactId>ons-client</artifactId><version>1.8.4.Final</version> </dependency>2. 配置 配…

2024年下一个风口是什么?萤领优选 轻资产创业项目全国诚招合伙人

2024年&#xff0c;全球经济与科技发展的步伐不断加快&#xff0c;各行各业都在探寻新的增长点与风口。在这样的时代背景下&#xff0c;萤领优选作为一个轻资产创业项目&#xff0c;正以其独特的商业模式和前瞻的市场洞察力&#xff0c;吸引着众多创业者的目光。(领取&#xff…

SqlSugar有实体CURD应用-C#

本文所述开发环境&#xff1a;.C#、NET8、Visual Studio2022 SqlSugar有实体查询数据表 首先根据《SqlSugar使用DbFirst对象根据数据库表结构创建实体类-C#》中的描述的表结构创建所有表的实体类如下&#xff1a; 表名创建的实体类名tb_studentStudenttb_teacherTeachertb_c…

++++++局部变量、全局变量及变量的存储类别++++====+++指针+++

局部变量、全局变量及变量的存储类别 局部变量与全局变量的基本概念 局部变量&#xff1a;在函数内部定义的变量称为局部变量&#xff0c;也称为内部变量。它们只在定义它们的函数内部有效&#xff0c;即只有在这个函数被调用时&#xff0c;局部变量才会被分配内存空间&#x…

102. 二叉树的层序遍历

题目描述 给你二叉树的根节点 root &#xff0c;返回其节点值的 层序遍历 。 &#xff08;即逐层地&#xff0c;从左到右访问所有节点&#xff09;。 自己想到的笨方法 /*** Definition for a binary tree node.* public class TreeNode {* public var val: Int* pu…

【已解决】better-scroll在PC端如何开启鼠标滚动以及如何始终显示滚动条

总结 需要安装插件 mouse-wheel 和 scrollbar 在PC端如何开启鼠标滚动? 需要安装官方提供的滚动插件&#xff1a;mouse-wheel https://better-scroll.github.io/docs/zh-CN/plugins/mouse-wheel.html 为了开启鼠标滚动功能&#xff0c;你需要首先引入 mouseWheel 插件&…

光伏工程开发的详细步骤

光伏工程作为可再生能源领域的重要组成部分&#xff0c;其开发过程涉及多个环节&#xff0c;包括开发、测绘、设计、施工和运维等。下面将详细介绍这些步骤。 一、开发阶段 1、前期调研&#xff1a;对目标地区进行能源政策、市场需求、资源条件等方面的调研&#xff0c;评估项…

python 逻辑控制语句、循环语句

文章目录 一、逻辑控制语句&#xff08;if、elif、else&#xff09; 一、逻辑控制语句&#xff08;if、elif、else&#xff09; Python 条件语句是通过一条或多条语句的执行结果&#xff08;True或者False&#xff09;来决定执行的代码块。 python 基本的逻辑判断语法&#xff…

SuperMap GIS基础产品FAQ集锦(20240617)

一、SuperMap iDesktopX 问题1&#xff1a;请问udbx数据源的数据集最多支持多少个属性字段&#xff1f; 现在客户合并数据集后属性字段有1119个&#xff0c;导致无法复制数据集 11.1.1 【问题原因】理论上是没有上限&#xff0c;我们底层没有针对这点进行限制&#xff0c;通常…

性能优化篇

1、使用 Class 代替 ProtoBuf 协议 因为 ProtoBuf 采用的是 Arena 内存分配器策略&#xff0c;有些场景会比 C的 Class 内存管理复杂&#xff0c;当有大量内存分配和释放的时候会比 Class 的性能差很多。而且 Protobuf 会不断分配和回收小内存对象&#xff0c;持续地分配和删除…

.gitignore文件忽略的内容不生效问题解决

文章目录 ①&#xff1a;现象②&#xff1a;原因③&#xff1a;解决 ①&#xff1a;现象 在已经提交过的git管理的项目中&#xff0c; 新增加一个.gitignore文件&#xff0c;文件内忽略内容不生效或者修改.gitignore文件之后&#xff0c;文件内新增的忽略内容不生效 ②&#…

了解 Blazor Server App 项目结构

在本文中&#xff0c;你将获得以下问题的答案 先决条件如何创建 Blazor Server App 项目&#xff1f;Blazor Server 应用程序的项目结构是什么样的&#xff1f;每个默认文件夹有什么用如何设置启动razor组件或页面运行&#xff1f; 先决条件 HTML、CSS 和 Javascript 的基本…

如何使用任意浏览器远程访问本地搭建的Jellyfin影音平台

文章目录 前言1. Jellyfin服务网站搭建1.1 Jellyfin下载和安装1.2 Jellyfin网页测试 2.本地网页发布2.1 cpolar的安装和注册2.2 Cpolar云端设置2.3 Cpolar本地设置 3.公网访问测试4. 结语 前言 本文主要分享如何使用Windows电脑本地部署Jellyfin影音服务并结合cpolar内网穿透工…