深度解析Nginx:高性能Web服务器的奥秘(下)

🐇明明跟你说过:个人主页

🏅个人专栏:《洞察之眼:ELK监控与可视化》🏅

🔖行路有良友,便是天堂🔖

目录

一、前言

1、Nginx概述 

二、Nginx核心功能

1、URL重写与重定向

2、反向代理

3、负载均衡

4、访问控制

5、SSL/TLS配置

三、Nginx模块讲解

1、HTTP模块

2、Stream模块

四、Nginx实际应用

1、Nginx在Web开发中的应用

2、Nginx在CDN中的应用 


一、前言

1、Nginx概述 

Nginx("engine x"的发音类似于"引擎 X")是一款高性能的开源Web服务器和反向代理服务器,由Igor Sysoev创建,并于2004年首次公开发布。它以其卓越的性能、高度的可靠性、简单的配置和低资源消耗而闻名。

以下是Nginx的概述:

  1. 高性能:Nginx以其高效的事件驱动架构而闻名,能够处理大量并发连接和高流量。它使用异步非阻塞I/O模型,有效地处理客户端请求,并且在高负载下表现优异。
  2. 反向代理:Nginx作为反向代理服务器时,可以接收客户端的请求并将其转发给后端服务器。它能够进行负载均衡、缓存静态内容、处理SSL终止等操作,提高了Web应用程序的性能和可靠性。
  3. 负载均衡:Nginx可以将请求分发给多个后端服务器,以实现负载均衡。通过配置不同的负载均衡算法,例如轮询、IP哈希、最少连接等,可以根据不同的需求实现请求的合理分发。
  4. 静态文件服务:Nginx非常擅长提供静态文件服务,能够高效地提供HTML、CSS、JavaScript、图像等静态内容,并且支持文件压缩和HTTP缓存等功能。
  5. 反向代理缓存:Nginx可以缓存后端服务器返回的响应,以减轻后端服务器的负载并提高响应速度。它支持不同类型的缓存,包括文件缓存、内存缓存和代理缓存等。
  6. HTTPS支持:Nginx支持SSL/TLS协议,能够进行HTTPS加密通信,并且支持SSL终止、SSL重定向、证书验证等功能,保障了Web应用程序的安全性。
  7. 简单配置:Nginx的配置文件采用简洁直观的语法,易于理解和维护。它支持模块化配置,可以通过加载不同的模块来扩展其功能,满足不同的需求。
  8. 高度可扩展:Nginx是一个模块化的Web服务器,可以通过加载不同的模块来扩展其功能,例如HTTP反向代理、负载均衡、缓存、安全性等。这使得Nginx可以根据不同的需求进行定制和扩展,适用于各种规模和类型的Web应用程序。

  

二、Nginx核心功能

1、URL重写与重定向

在 Nginx 中,URL 重写和重定向是常见的任务,用于处理客户端请求并将其发送到适当的位置。它们经常用于修改 URL 结构、处理旧 URL、执行 URL 路由等。

下面是 Nginx 中的 URL 重写和重定向的概念和用法:

URL 重写(URL Rewriting)

  • URL 重写是指修改客户端请求的 URL 路径,而不改变客户端看到的 URL。这个过程通常在 Nginx 的配置文件中通过 rewrite 指令来完成。URL 重写可以用于修改 URL 结构、处理错误的 URL 请求等。

例如,假设想要将所有 /old-url 的请求重写到 /new-url,可以使用如下配置:

location /old-url {
    rewrite ^/old-url/(.*)$ /new-url/$1 permanent;
}

  • 这个配置中的 rewrite 指令将匹配以 /old-url 开头的 URL,然后将其重写为以 /new-url 开头的 URL,并使用 permanent 关键字表示这是一个永久重定向。重定向后的 URL 将保留原始的查询参数。

 

URL 重定向(URL Redirection)

  • URL 重定向是指将客户端请求的 URL 重定向到另一个 URL 地址。这个过程会向客户端返回一个 HTTP 状态码(如 301 永久重定向或 302 临时重定向),告诉客户端要跳转到另一个 URL。
  • 在 Nginx 中,可以使用 return 指令或 rewrite 指令来实现 URL 重定向。

例如,要将所有访问根目录的请求重定向到一个新的域名,可以使用如下配置:
 

server {
    listen 80;
    server_name old-domain.com;

    location / {
        return 301 http://new-domain.com$request_uri;
    }
}

  • 这个配置中的 return 指令将所有访问 old-domain.com 根目录的请求重定向到 new-domain.com。

 

URL 重写用于修改 URL 路径,而 URL 重定向则用于将客户端请求重定向到另一个 URL 地址。这两个功能在 Nginx 中都有其独特的用途,可以根据需求选择合适的方法来处理请求。

2、反向代理

Nginx 反向代理是一种常见的用途,它允许 Nginx 接收来自客户端的请求,并将这些请求转发给后端的服务器或应用程序,然后将后端服务器的响应返回给客户端。这种方式可以隐藏后端服务器的实际 IP 地址和配置,并提供负载均衡、缓存、SSL 终端等功能。

下面是一个简单的 Nginx 反向代理配置示例:
 

server {
    listen 80;
    server_name your_domain.com;

    location / {
        proxy_pass http://backend_server;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }
}


在这个配置中:

  • listen 指令指定了 Nginx 监听的端口,这里是 80 端口,用于 HTTP 访问。
  • server_name 指令指定了你的域名。
  • location / 指令定义了处理客户端请求的位置。这里的配置表示当客户端访问网站时,Nginx 将会代理所有的请求。
  • proxy_pass 指令指定了后端服务器的地址,Nginx 会将客户端的请求转发给该地址。
  • proxy_set_header 指令用于设置 HTTP 请求头。在这个例子中,设置了 Host、X-Real-IP 和 X-Forwarded-For 头,用于传递客户端的真实 IP 地址和其他信息给后端服务器。

实际使用中,需要将 backend_server 替换为实际的后端服务器的地址,可以是 IP 地址或域名。此外,可能需要根据实际情况配置其他选项,例如 SSL 配置、缓存配置等。

通过这样的配置,Nginx 将充当反向代理,将客户端的请求转发给后端服务器,并将后端服务器的响应返回给客户端,从而实现了反向代理的功能。

3、负载均衡

Nginx 可以作为负载均衡器,用于将来自客户端的请求分发到多个后端服务器,以提高系统的性能、可用性和可扩展性。Nginx 提供了几种负载均衡算法,如轮询、IP Hash、最少连接等,可以根据需求选择适合的算法。

下面是一个简单的 Nginx 负载均衡配置示例:

http {
    upstream backend_servers {
        server 192.168.1.10;
        server 192.168.1.11;
        server 192.168.1.12;
    }

    server {
        listen 80;
        server_name your_domain.com;

        location / {
            proxy_pass http://backend_servers;
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        }
    }
}


在这个配置中:

  • upstream 指令定义了后端服务器的集群,其中包含了多个服务器的地址和端口。这些服务器可以是真实的后端服务器,也可以是代理服务器或其他类型的服务器。
  • server 指令定义了每个后端服务器的地址和端口。
  • listen 指令和 server_name 指令定义了 Nginx 监听的端口和服务器名。
  • location / 指令定义了处理客户端请求的位置。这里的配置表示当客户端访问网站时,Nginx 将会代理所有的请求给 upstream 中定义的后端服务器集群。
  • proxy_pass 指令将客户端的请求转发给后端服务器集群。
  • proxy_set_header 指令用于设置 HTTP 请求头,以传递客户端的真实 IP 地址和其他信息给后端服务器。

通过这样的配置,Nginx 将会根据负载均衡算法(默认是轮询算法)将客户端的请求分发到多个后端服务器上,从而实现了负载均衡的功能。可以根据实际需求配置更多的后端服务器,并根据需要选择适合的负载均衡算法。

4、访问控制

Nginx 提供了多种方法来实现访问控制,包括基于 IP 地址、基于用户身份、基于 HTTP 请求头等。这些方法可以帮助你限制访问某些资源,保护你的网站免受恶意攻击和未经授权的访问。

下面是几种常见的 Nginx 访问控制方法:

基于 IP 地址的访问控制


使用 allow 和 deny 指令可以实现基于 IP 地址的访问控制。你可以在 Nginx 配置文件中设置允许或拒绝访问的 IP 地址列表。

例如,下面的配置将允许来自指定 IP 地址范围的访问,拒绝其他所有 IP 地址的访问:

location / {
    allow 192.168.1.0/24;
    deny all;
}


基于 HTTP 请求头的访问控制
可以使用 if 指令结合 HTTP 请求头来实现更细粒度的访问控制。

例如,下面的配置将拒绝所有没有 Referer 请求头或者 Referer 不是指定域名的请求:

location / {
    if ($http_referer !~* (your-domain.com)) {
        return 403;
    }
}


基于用户身份的访问控制
如果应用程序需要用户登录,可以结合应用程序的身份验证机制来实现访问控制。

例如,下面的配置要求用户登录后才能访问网站的特定部分:

location /private {
    auth_basic "Restricted";
    auth_basic_user_file /etc/nginx/.htpasswd;
}


在这个例子中,auth_basic 指令用于设置基本身份验证,auth_basic_user_file 指令指定了存储用户名和密码的文件路径。

5、SSL/TLS配置

配置 Nginx 的 SSL/TLS 是保护网站和用户数据安全的重要措施。SSL/TLS 配置包括证书的安装和使用,加密算法的选择,以及其他安全相关的设置。

以下是一个基本的 Nginx SSL/TLS 配置示例:

server {
    listen 443 ssl;
    server_name your_domain.com;

    ssl_certificate /path/to/your/certificate.crt;
    ssl_certificate_key /path/to/your/private.key;

    # 安全参数配置
    ssl_protocols TLSv1.2 TLSv1.3;
    ssl_prefer_server_ciphers on;
    ssl_ciphers 'EECDH+AESGCM:EDH+AESGCM:AES256+EECDH:AES256+EDH';
    ssl_session_cache shared:SSL:10m;
    ssl_session_timeout 10m;
    ssl_session_tickets off;
    ssl_stapling on;
    ssl_stapling_verify on;

    # 可选的安全性增强配置
    add_header Strict-Transport-Security "max-age=31536000; includeSubDomains" always;
    add_header X-Frame-Options "SAMEORIGIN";
    add_header X-Content-Type-Options "nosniff";

    # 配置 SSL 会话的结束方式
    ssl_session_tickets off;

    location / {
        # 其他配置...
    }
}


在这个配置中:

  • listen 443 ssl; 指令表示该服务器块监听 443 端口,并启用 SSL/TLS 加密。
  • server_name 指令指定了你的域名。
  • ssl_certificate ssl_certificate_key 指令指定了 SSL 证书和私钥的路径,这两个文件是 SSL/TLS 加密的必要组件。
  • ssl_protocols 指令用于指定允许使用的 SSL/TLS 协议版本。
  • ssl_prefer_server_ciphers on; 指令表示优先使用服务器端定义的加密套件。
  • ssl_ciphers 指令定义了可用的加密算法套件。
  • ssl_session_cache 指令设置 SSL 会话缓存的大小和存储位置。
  • ssl_session_timeout 指令设置 SSL 会话的超时时间。
  • ssl_session_tickets 指令控制 SSL 会话票据的使用。
  • ssl_stapling ssl_stapling_verify 指令启用 OCSP Stapling 和 OCSP Stapling 验证。
  • add_header 指令用于添加额外的安全头,如 Strict-Transport-Security、X-Frame-Options 和 X-Content-Type-Options。

以上是一个基本的 SSL/TLS 配置示例,可以根据实际需求对其进行调整和扩展,以满足网站安全性和性能需求。

 

三、Nginx模块讲解

1、HTTP模块

Nginx 的 HTTP 模块是 Nginx 的核心模块之一,它处理 HTTP 请求和响应,并提供了丰富的功能和配置选项,包括反向代理、负载均衡、缓存、访问控制等。

以下是一些常用的 Nginx HTTP 模块及其功能:

  1. Core Module(核心模块):提供了基本的 HTTP 服务器功能,包括定义服务器块、监听端口、设置服务器名称等。例如,listen、server_name 等指令都属于核心模块。
  2. Access Module(访问模块):用于控制客户端对服务器的访问权限。包括 allow 和 deny 指令,可以根据客户端的 IP 地址或其他条件来允许或拒绝访问。
  3. Rewrite Module(重写模块):用于重写或修改 URL。提供了 rewrite 指令,可以根据匹配规则修改客户端请求的 URL。
  4. Proxy Module(代理模块):提供了反向代理功能,允许将客户端的请求转发给后端的服务器或应用程序。包括 proxy_pass、proxy_set_header 等指令。
  5. Load Balancing Module(负载均衡模块):用于将客户端的请求分发到多个后端服务器,以提高系统的性能和可用性。包括 upstream 和 server 指令。
  6. SSL Module(SSL 模块):提供了 SSL/TLS 加密功能,用于保护网站和用户数据的安全。包括 ssl_certificate、ssl_certificate_key 等指令。
  7. Headers Module(头部模块):用于添加、修改或删除 HTTP 请求和响应头。包括 add_header、more_set_headers 等指令。
  8. Gzip Module(压缩模块):用于压缩 HTTP 响应体,减小传输数据的大小,提高网站的加载速度。包括 gzip、gzip_types 等指令。
  9. Cache Module(缓存模块):用于缓存静态和动态内容,减轻后端服务器的负载,并提高响应速度。包括 proxy_cache、proxy_cache_key 等指令。

 

以上是一些常见的 Nginx HTTP 模块及其功能,可以根据需求在 Nginx 配置文件中使用这些模块和指令来实现各种功能。 Nginx 的模块化设计使得它可以灵活地适应不同的应用场景和需求。

2、Stream模块

Nginx 的 Stream 模块是 Nginx 的一个核心模块之一,用于处理 TCP 和 UDP 流量。与 HTTP 模块不同,Stream 模块不处理 HTTP 请求和响应,而是处理基于传输层协议的数据流,例如 TCP 连接、UDP 包等。Stream 模块通常用于实现反向代理、负载均衡、TCP/UDP 代理等网络层级别的功能。

以下是一些常见的 Nginx Stream 模块及其功能:

  1. Core Module(核心模块):提供了基本的 Stream 服务器功能,包括定义服务器块、监听端口等。与 HTTP 模块的核心模块类似。
  2. Proxy Module(代理模块):提供了 TCP 和 UDP 的反向代理功能,允许将客户端的 TCP/UDP 流量转发给后端的服务器或应用程序。包括 proxy_pass、proxy_set_header 等指令。
  3. Load Balancing Module(负载均衡模块):用于将客户端的 TCP/UDP 流量分发到多个后端服务器,以提高系统的性能和可用性。包括 upstream 和 server 指令。
  4. SSL Module(SSL 模块):提供了 TCP 的 SSL/TLS 加密功能,用于保护 TCP 连接的安全。包括 ssl_certificate、ssl_certificate_key 等指令。
  5. UDP Module(UDP 模块):用于处理 UDP 流量,可以实现 UDP 的反向代理、负载均衡等功能。Nginx 1.19.0 版本引入了对 UDP 的支持。

 

Stream 模块的使用方式与 HTTP 模块类似,你可以在 Nginx 配置文件中定义 Stream 服务器块,并在其中使用相应的指令来配置 TCP 或 UDP 的代理、负载均衡等功能。通过 Stream 模块,Nginx 可以成为一个功能强大的 TCP/UDP 代理服务器,可以处理各种类型的网络流量,并提供高性能和可靠性。

四、Nginx实际应用

1、Nginx在Web开发中的应用

Nginx 在 Web 开发中有许多应用,它是一个高性能的 Web 服务器和反向代理服务器,提供了许多功能和特性,适用于各种不同的 Web 开发场景。

以下是一些 Nginx 在 Web 开发中常见的应用:

  1. 静态文件服务: Nginx 可以作为一个高性能的静态文件服务器,用于提供网站的静态资源,如 HTML、CSS、JavaScript、图片等。它可以快速地响应静态文件的请求,并有效地缓存静态内容,提高网站的访问速度和性能。
  2. 反向代理: Nginx 可以作为反向代理服务器,将客户端的请求转发给后端的服务器或应用程序,并将后端服务器的响应返回给客户端。这种方式可以隐藏后端服务器的实际 IP 地址和配置,并提供负载均衡、高可用性、安全性等功能。
  3. 负载均衡: Nginx 可以作为负载均衡器,将客户端的请求分发到多个后端服务器上,以提高系统的性能和可用性。它支持多种负载均衡算法,如轮询、IP Hash、最少连接等,并可以根据服务器的健康状态进行动态调整。
  4. 缓存服务: Nginx 可以作为缓存服务器,缓存静态和动态内容,减轻后端服务器的负载,并提高响应速度。它支持内存缓存和磁盘缓存,并可以根据需要配置缓存规则和过期时间。
  5. SSL/TLS 终端: Nginx 支持 SSL/TLS 加密,可以用于安全地传输数据和保护用户隐私。它可以用作 SSL/TLS 终端,对客户端进行 SSL 握手,并在后端服务器之间使用非加密的 HTTP 或 HTTPS 连接。
  6. 反向 WebSocket 代理: Nginx 可以代理 WebSocket 请求,用于实现实时通信和双向数据传输。它支持 WebSocket 协议的代理和负载均衡,可以处理大量的并发连接。
  7. HTTP/2 支持: Nginx 支持 HTTP/2 协议,可以提供更快的网页加载速度和更低的延迟。它可以与现代的 Web 浏览器和服务器一起使用,以实现最新的 Web 性能优化。

2、Nginx在CDN中的应用 

在 CDN(内容分发网络)中,Nginx 是一个非常常见和重要的组件,它提供了多种功能和特性,用于优化内容分发、提高网站性能、加强安全性等。

以下是 Nginx 在 CDN 中的一些常见应用:

  1. 内容缓存: Nginx 可以作为 CDN 的缓存服务器,缓存静态和动态内容,如 HTML、CSS、JavaScript、图片、视频等。通过缓存静态内容,Nginx 可以减轻后端服务器的负载,并提高内容的访问速度和性能。
  2. 反向代理: Nginx 可以作为 CDN 的反向代理服务器,将客户端的请求转发给最近的缓存服务器或源服务器,并将响应返回给客户端。这种方式可以加速内容传输,提高网站的可用性和可靠性。
  3. 负载均衡: CDN 通常包含多个缓存节点,Nginx 可以作为负载均衡器,将客户端的请求分发到多个缓存节点上,以提高系统的性能和可用性。它支持多种负载均衡算法,如轮询、IP Hash、最少连接等,并可以根据节点的健康状态进行动态调整。
  4. SSL/TLS 终端: Nginx 支持 SSL/TLS 加密,可以用于安全地传输内容和保护用户隐私。在 CDN 中,Nginx 可以作为 SSL/TLS 终端,对客户端进行 SSL 握手,并在缓存节点之间使用非加密的 HTTP 或 HTTPS 连接。
  5. 内容压缩: Nginx 支持内容压缩,可以减小传输数据的大小,提高内容的传输速度和节省带宽。在 CDN 中,Nginx 可以压缩静态和动态内容,并提供 Gzip 压缩、Brotli 压缩等功能。
  6. 安全防护: Nginx 提供了丰富的安全特性,如访问控制、反向代理防护、DDoS 防护等。在 CDN 中,Nginx 可以用于防止恶意攻击、保护网站安全,并提供安全日志和监控功能。

 

💕💕💕每一次的分享都是一次成长的旅程,感谢您的陪伴和关注。希望这些关于Nginx的文章能陪伴您走过技术的一段旅程,共同见证成长和进步!😺😺😺

🧨🧨🧨让我们一起在技术的海洋中探索前行,共同书写美好的未来!!! 

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

初识FlaskMySQL实现前后端通信 全栈开发之路——后端篇(1)

全栈开发一条龙——前端篇 第一篇:框架确定、ide设置与项目创建 第二篇:介绍项目文件意义、组件结构与导入以及setup的引入。 第三篇:setup语法,设置响应式数据。 第四篇:数据绑定、计算属性和watch监视 第五篇 : 组件…

拥有一台服务器可以做哪些有趣又实用的事情?

在接触云服务器这个概念你以前,你是不是在想: 可能是,云服务器,这个产品的存在,它可以为你做些什么实用的事情吗? 或者是,云服务器这个看似高大上的科技产品,其实可以为我们的生活…

AI智能体|手把手教你申请一个Kimi(Moonshot)的API KEY

大家好,我是无界生长。 今天分享一下如何申请一个Kimi(Moonshot)的API KEY,为后面Kimi(Moonshot)接入微信机器人做铺垫。学会了的话,欢迎分享转发! 前提 拥有一个Kimi(Moonshot)账号 使用手机号注册即可,新用户可免费…

文章解读与仿真程序复现思路——中国电机工程学报EI\CSCD\北大核心《考虑协变量因素的多能微电网两阶段分布鲁棒优化调度》

本专栏栏目提供文章与程序复现思路,具体已有的论文与论文源程序可翻阅本博主免费的专栏栏目《论文与完整程序》 论文与完整源程序_电网论文源程序的博客-CSDN博客https://blog.csdn.net/liang674027206/category_12531414.html 电网论文源程序-CSDN博客电网论文源…

ARM架构安全特性之标准安全 API

安全之安全(security)博客目录导读 目录 一、机密计算软件 二、Arm机密计算固件架构 三、认证校验 四、Veraison项目 五、独立于语言的安全API 六、平台抽象安全项目(Platform AbstRaction for SECurity project) 七、可移植平台安全API 八、…

黄仁勋炉边对话:创业的超能力与英伟达的加速计算之旅

在TiECon 2024大会上,英伟达的创始人兼CEO黄仁勋与风投公司Mayfield的管理合伙人纳文查德哈进行了一场深入的炉边对话。黄仁勋不仅分享了英伟达的创业故事,还谈到了他对创业和加速计算的深刻见解。下面是我对这次对话的总结,希望能给正在创业…

10.nginx模板(开启监控取值页面)

nginx模板(开启监控取值页面) 1.开启监控页面 vim nginx.conflocation /nginx_status {stub_status;} systemctl restart nginx.server网页展示 导入模板&#xff0c;nginx监控模板zbx_nginx_template.xml <?xml version"1.0" encoding"UTF-8"?…

高级查询(子查询)

可以使用的范围&#xff1a; 子查询是一个嵌套在SELECT、INSERT、UPDATE、DELETE语句或其他子查询中的查询。 任何允许使用表达式的地方都可以使用子查询。 子查询也称为内部查询或内部选择&#xff0c;而包含子查询的语句也称为外部查询或外部选择 子查询的特点和优势 可以…

(undone) 什么是马尔可夫链?Markov Chain

参考视频1&#xff1a;https://www.bilibili.com/video/BV1ko4y1P7Zv/?spm_id_from333.337.search-card.all.click&vd_source7a1a0bc74158c6993c7355c5490fc600 参考视频2&#xff1a;https://www.bilibili.com/video/BV1xg4y1K7z4/?spm_id_from333.788&vd_source7a…

js前端获取农历日期

对于公历来说&#xff0c;直接 new 一个 Date 就能获取到&#xff0c;而对于农历来讲可就很难了&#xff0c;因为农历需要有许多复杂计算&#xff0c;虽然一般用的甚少&#xff0c;但对于某些场景来说还是会需要的&#xff0c;那么怎样获取农历日期呢&#xff1f; 这里推荐一个…

AI视频教程下载:基于OpenAl、LangChain、 Replicate开发AI应用程序

欢迎来到令人兴奋的 AI 应用世界&#xff01;在这门课程中&#xff0c;你将学习到创建一个能够与用户互动、理解自然语言、处理音频输入&#xff0c;甚至分析图像的真正智能应用所需的技能和技术。 AI 工具和技术 你将获得使用几个知名 AI API 和技术的实际经验。这些行业领先…

群晖NAS本地搭建Bitwarden密码管理服务并实现远程同步密码托管

文章目录 1. 拉取Bitwarden镜像2. 运行Bitwarden镜像3. 本地访问4. 群晖安装Cpolar5. 配置公网地址6. 公网访问Bitwarden7. 固定公网地址8. 浏览器密码托管设置 Bitwarden是一个密码管理器应用程序&#xff0c;适用于在多个设备和浏览器之间同步密码。自建密码管理软件bitwarde…

什么是Data Lakehouse Architecture(DLA)?企业为何要创建DLA

公司捕获和存储的数据比以往任何时候都多&#xff0c;因为它们依赖数据来做出关键的业务决策、改进服务或产品&#xff0c;或为最终用户&#xff08;客户&#xff09;提供更好的服务。了解各种大数据存储技术对于为商业智能&#xff08;BI&#xff09;、数据分析和机器学习&…

记录一次 vue2 前端项目整合过程

整合成功效果图 具体说明&#xff1a; 项目A是现在的vue2前端项目&#xff0c;项目B是一个开源的工作流前端&#xff0c;项目后端代码已经整合了&#xff0c;就不多提了。这里主要记录下前端整合的过程和思路。 1、开源工作流里面的功能&#xff0c;拷贝到自己对应的vue2项目里…

密探渗透工具v1.08测试版

目录 前言 免责声明 工具开发者: 工具项目地址: 1.作者做工具的缘起 2.功能介绍 3.工具的更新日志 4.安装与使用 4.1 工具下载 4.2 在jdk8环境下运行: 4.3 运行界面 4.4 资产测绘功能(fofa,鹰图和Quake) 4.5 指纹识别功能 ​编辑 4.6 敏感信息与接口扫描 4.7 文…

移动端自动化测试工具 Appium 之自定义报告

文章目录 一、背景二、具体实现1、保存结果实体2、工具类3、自定义报告监听类代码4、模板代码4.1、report.vm4.2、执行xml 三、总结 一、背景 自动化测试用例跑完后报告展示是体现咱们价值的一个地方咱们先看原始报告。 上面报告虽然麻雀虽小但五脏俱全&#xff0c;但是如果用…

更适合户外使用的开放式耳机,佩戴舒适音质悦耳,虹觅HOLME NEO体验

随着气温的逐渐升高&#xff0c;不管是在室内工作娱乐&#xff0c;还是到户外运动健身&#xff0c;戴上一款合适的耳机都会帮我们隔绝燥热与烦闷&#xff0c;享受音乐与生活。现在市面上的耳机类型特别多&#xff0c;我很喜欢那种分体式的开放耳机&#xff0c;感觉这种耳机设计…

C语言——模拟实现库函数atoi

1. atoi atoi&#xff1a;将字符串转换为整数。 1. 头文件 <string.h> 2. 声明&#xff1a; 1. 如果字符串开始有空格&#xff0c;直接跳过。 2. - 会影响打印的数字的正负。 3. 只打印数字字符&#xff0c;遇到非数字字符就停止。 4. 如果转换之后的数字大于 …

商城小程序系统与C#.net商城小程序系统源码_OctShop

在移动互联网与电商的时代&#xff0c;商城小程序系统已经成为了众多企业和商家开展电商业务的重要工具。OctShop将以商城小程序系统、C#商城小程序系统源码和.net 商城小程序系统为主题&#xff0c;探讨这些系统的特点和优势。 一、商城小程序系统是什么 商城小程序系统是一种…

嵌入式STM32中I2C控制器外设详解

STM32中的I2C外设主要负责IIC协议与外界进行通信,就像USART外设一样,我们在学习的过程中,需要抓住I2C应用的重点。 STM32在使用I2C协议时,可以通过两种方式, 一是软件模拟协议 意思是使用CPU直接控制通讯引脚的电平,产生出符合通讯协议标准的逻辑。例如,像点亮LED那样…