首页 > 系统相关 >Nginx 实战-02-nginx proxy_pass 服务代理访问 使用笔记 ubuntu nodejs

Nginx 实战-02-nginx proxy_pass 服务代理访问 使用笔记 ubuntu nodejs

时间:2024-05-31 21:01:18浏览次数:16  
标签:02 http nodejs etc js nginx gzip server

前言

大家好,我是老马。很高兴遇到你。

我们为 java 开发者实现了 java 版本的 nginx

https://github.com/houbb/nginx4j

如果你想知道 servlet 如何处理的,可以参考我的另一个项目:

手写从零实现简易版 tomcat minicat

手写 nginx 系列

如果你对 nginx 原理感兴趣,可以阅读:

从零手写实现 nginx-01-为什么不能有 java 版本的 nginx?

从零手写实现 nginx-02-nginx 的核心能力

从零手写实现 nginx-03-nginx 基于 Netty 实现

从零手写实现 nginx-04-基于 netty http 出入参优化处理

从零手写实现 nginx-05-MIME类型(Multipurpose Internet Mail Extensions,多用途互联网邮件扩展类型)

从零手写实现 nginx-06-文件夹自动索引

从零手写实现 nginx-07-大文件下载

从零手写实现 nginx-08-范围查询

从零手写实现 nginx-09-文件压缩

从零手写实现 nginx-10-sendfile 零拷贝

从零手写实现 nginx-11-file+range 合并

从零手写实现 nginx-12-keep-alive 连接复用

准备工作-HTTP 服务

我们简单起见,使用 node.js 启动一个简单的前端服务。

ubuntu 如何安装 node.js

  1. 更新包索引
    更新你的包索引列表以确保你安装的是最新版本的软件包。

    sudo apt update
    
  2. 安装 Node.js
    使用 apt 安装 Node.js 和 npm(Node.js 的包管理器)。

    sudo apt install -y nodejs npm
    

    这将安装最新的 Node.js 和 npm 版本。

  3. 验证安装
    安装完成后,你可以通过检查 Node.js 和 npm 的版本来验证安装是否成功。

    node -v
    npm -v
    

安装版本如下:

$ node -v
v12.22.9

$ npm -v
8.5.1

nodejs 创建一个 http 服务

Node.js 最简单的入门例子是一个基础的 Web 服务器,它使用 Node.js 内置的 http 模块来响应 HTTP 请求。

以下是创建这样一个服务器的步骤:

  1. 安装 Node.js:确保你已经在系统上安装了 Node.js。你可以通过在终端运行以下命令来检查 Node.js 是否已安装以及其版本号:

    node -v
    
  2. 创建一个新的 JavaScript 文件:在你的文本编辑器中,创建一个名为 app.js 的新文件。

  3. 编写代码:在 app.js 文件中,输入以下代码:

    const http = require('http'); // 引入 http 模块
    
    // 创建一个 HTTP 服务器
    const server = http.createServer((req, res) => {
      res.writeHead(200, {'Content-Type': 'text/plain'});
      res.end('Hello, World!\n'); // 响应请求并发送一个字符串
    });
    
    // 服务器监听 3000 端口
    server.listen(3000, '127.0.0.1', () => {
      console.log('Server running at http://127.0.0.1:3000/');
    });
    
  4. 运行你的服务器:在终端中,导航到 app.js 文件所在的目录,然后运行以下命令:

    node app.js
    
  5. 访问服务器

$ curl http://127.0.0.1:3000/
Hello, World!

想通过 nginx 来代理访问这个 http 服务,应该如何配置实现?

要通过 Nginx 代理访问你的 Node.js HTTP 服务,你需要在 Nginx 的配置文件中设置一个代理服务器。

以下是配置 Nginx 以代理 Node.js 服务的步骤:

先看一下 nginx 的配置

默认的配置如下:

cat /etc/nginx/nginx.conf

如下:

$ cat /etc/nginx/nginx.conf
user www-data;
worker_processes auto;
pid /run/nginx.pid;
include /etc/nginx/modules-enabled/*.conf;

events {
        worker_connections 768;
        # multi_accept on;
}

http {

        ##
        # Basic Settings
        ##

        sendfile on;
        tcp_nopush on;
        types_hash_max_size 2048;
        # server_tokens off;

        # server_names_hash_bucket_size 64;
        # server_name_in_redirect off;

        include /etc/nginx/mime.types;
        default_type application/octet-stream;

        ##
        # SSL Settings
        ##

        ssl_protocols TLSv1 TLSv1.1 TLSv1.2 TLSv1.3; # Dropping SSLv3, ref: POODLE
        ssl_prefer_server_ciphers on;

        ##
        # Logging Settings
        ##

        access_log /var/log/nginx/access.log;
        error_log /var/log/nginx/error.log;

        ##
        # Gzip Settings
        ##

        gzip on;

        # gzip_vary on;
        # gzip_proxied any;
        # gzip_comp_level 6;
        # gzip_buffers 16 8k;
        # gzip_http_version 1.1;
        # gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;

        ##
        # Virtual Host Configs
        ##

        include /etc/nginx/conf.d/*.conf;
        include /etc/nginx/sites-enabled/*;
}


#mail {
#       # See sample authentication script at:
#       # http://wiki.nginx.org/ImapAuthenticateWithApachePhpScript
#
#       # auth_http localhost/auth.php;
#       # pop3_capabilities "TOP" "USER";
#       # imap_capabilities "IMAP4rev1" "UIDPLUS";
#
#       server {
#               listen     localhost:110;
#               protocol   pop3;
#               proxy      on;
#       }
#
#       server {
#               listen     localhost:143;
#               protocol   imap;
#               proxy      on;
#       }
#}

简单解释

这是一个 Nginx 的主配置文件,它包含了用于定义 Nginx 服务器行为的多种设置。

以下是配置文件中每一行的解释,其中注释行以 # 开头:

# 指定运行 Nginx 的用户和用户组
user www-data;

# 设置工作进程的数量,'auto' 会让 Nginx 根据 CPU 核心数自动设置
worker_processes auto;

# 指定 Nginx 进程的 PID 文件存放位置
pid /run/nginx.pid;

# 包含所有在 /etc/nginx/modules-enabled/ 目录下启用的模块配置文件
include /etc/nginx/modules-enabled/*.conf;

events {
    # 设置每个工作进程的最大连接数
    worker_connections 768;
    # 以下注释掉的选项可以启用或禁用多请求接受
    # multi_accept on;
}

http {
    ### 基础设置 ###

    # 开启高效文件传输模式
    sendfile on;
    # 开启 TCP 无推送选项,可以提高性能
    tcp_nopush on;
    # 设置类型hash桶的最大大小
    types_hash_max_size 2048;
    # 以下注释掉的选项可以关闭服务器版本号在错误页面和HTTP头部的显示
    # server_tokens off;

    # 设置服务器名称的hash桶大小
    # server_names_hash_bucket_size 64;
    # 禁止在重定向响应中出现服务器名称
    # server_name_in_redirect off;

    # 包含 MIME 类型配置文件
    include /etc/nginx/mime.types;
    # 默认的 MIME 类型
    default_type application/octet-stream;

    ### SSL 设置 ###

    # 设置 SSL/TLS 协议版本
    ssl_protocols TLSv1 TLSv1.1 TLSv1.2 TLSv1.3; # 不支持 SSLv3,参考 POODLE 漏洞
    # 优先使用服务器端的加密套件
    ssl_prefer_server_ciphers on;

    ### 日志设置 ###

    # 定义访问日志的存放路径
    access_log /var/log/nginx/access.log;
    # 定义错误日志的存放路径
    error_log /var/log/nginx/error.log;

    ### Gzip 设置 ###

    # 开启 Gzip 压缩
    gzip on;
    # 以下注释掉的选项可以进一步配置 Gzip 压缩行为
    # gzip_vary on;
    # gzip_proxied any;
    # gzip_comp_level 6;
    # gzip_buffers 16 8k;
    # gzip_http_version 1.1;
    # gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;

    ### 虚拟主机配置 ###

    # 包含 /etc/nginx/conf.d/ 目录下的所有配置文件
    include /etc/nginx/conf.d/*.conf;
    # 包含 /etc/nginx/sites-enabled/ 目录下的所有配置文件
    include /etc/nginx/sites-enabled/*;
}

#mail {
    # 下面的注释掉的链接提供了一个 Nginx 与 Apache/PHP 脚本进行 IMAP 认证的示例
    # 详见:http://wiki.nginx.org/ImapAuthenticateWithApachePhpScript
    #
    # auth_http localhost/auth.php;
    # pop3_capabilities "TOP" "USER";
    # imap_capabilities "IMAP4rev1" "UIDPLUS";
    #
    # server {
    #     listen     localhost:110;
    #     protocol   pop3;
    #     proxy      on;
    # }
    #
    # server {
    #     listen     localhost:143;
    #     protocol   imap;
    #     proxy      on;
    # }
#}

这个配置文件定义了 Nginx 服务器的基本运行参数,如用户、工作进程、PID 文件位置,以及事件处理、HTTP、SSL、日志、Gzip 压缩和虚拟主机包含的设置。被注释的部分可以通过去掉前面的 # 符号来启用。

标签:02,http,nodejs,etc,js,nginx,gzip,server
From: https://www.cnblogs.com/houbbBlogs/p/18225274

相关文章

  • 管理 Windows Server 2022 中 DNS 服务器相关的 CMD 批处理命令的示例
    一些与管理WindowsServer2022中DNS服务器相关的CMD批处理命令的示例:创建新的DNS区域:CopyCodednscmd/ZoneAddexample.com/Primary删除DNS区域:CopyCodednscmd/ZoneDeleteexample.com/f添加区域转发:CopyCodednscmd/ZoneResetForwardersexample......
  • 在 Windows Server 2022 中,您可以使用 PowerShell 来管理 DNS 服务器,以下是一些常用的
    在WindowsServer2022中,您可以使用PowerShell来管理DNS服务器,以下是一些常用的PowerShell命令及其示例:安装DNS服务器角色:安装DNS服务器角色:powershellCopyCodeInstall-WindowsFeature-NameDNS-IncludeManagementTools配置DNS区域和记录:创建新的......
  • 【2024-05-30】销售能力
    20:00人类最宝贵的财富是希望,希望减轻了我们的苦恼,为我们在享受当前的乐趣中描绘出来乐趣的远景。                                ——伏尔泰今天下午公司来了一个客人,她不是来找我的,是找我们公司财务总......
  • 【运维项目经历|026】Redis智能集群构建与性能优化工程
    ......
  • Nginx:a client request body is buffered to a temporary file
    https://www.cnblogs.com/iAmSoScArEd/p/18225191Nginxwarn:2024/05/3119:28:37[warn]8467#0:*9505669aclientrequestbodyisbufferedtoatemporaryfile/usr/local/openresty/nginx/client_body_temp/0002098837,client:10.xx.xx.xx,server:xxx.xx.com,r......
  • Leetcode-2028. 找出缺失的观测数据
    2028.找出缺失的观测数据现有一份n+m次投掷单个六面骰子的观测数据,骰子的每个面从1到6编号。观测数据中缺失了n份,你手上只拿到剩余m次投掷的数据。幸好你有之前计算过的这n+m次投掷数据的平均值。给你一个长度为m的整数数组rolls,其中rolls[i]是第i......
  • Visual Studio 2022安装SVN插件教程
    原文链接:https://blog.csdn.net/weixin_44504146/article/details/1328311011.第一步:避免踩坑,超级重要!!!关闭VisualStudio2022应用程序;(不然插件装不上,一直转圈!)2.第二步:下载VisualStudio2022版本对应的SVN插件https://www.visualsvn.com/visualsvn/download/(注意对应版本20......
  • vs2022安装 社区版/Visual Studio 2022 Professional、Enterprise安装教程
    原文链接:https://zhuanlan.zhihu.com/p/472099786https://blog.csdn.net/qq_38390060/article/details/129580789一、Windows安装VisualStudio20221.1下载地址首先登陆VisualStudio官网:https://visualstudio.microsoft.com/zh-hans/ 2、我们双击开始安装之后会弹出安......
  • 工程管理软件哪个好?2024年10个最佳工程管理软件
    本文将分享10款工程管理软件:PingCode、Worktile、Wrike、Asana、Monday.com、AdobeWorkfront、Smartsheet、Jira、ClickUp、MicrosoftProject。在高速发展的建筑和工程行业,管理复杂的项目要求极高的精确性和效率。工程管理软件在这一领域发挥着至关重要的作用,它通过提供详细......
  • Windows server 2022从基础到进阶的 DNS 管理内容,适合初学者快速入门并建立起对 DNS
    关于WindowsServer2022DNS管理器初级应用的大纲:1. 介绍DNS服务1.1什么是DNS?1.2DNS的作用和重要性1.3DNS解析过程概述2. 部署DNS服务器2.1安装DNS服务器角色2.2配置DNS服务器基本设置2.3DNS服务器的启动和停止3. 管理DNS区域3.1什么......