Nginx配置组成与性能调优

目录

一、Nginx配置介绍

1. 模块组成

2. 图示 

3. 相关框架 

二. 配置调优

1. 全局配置

1.1 关闭版本和修改版本

1.2 修改启动的进程数

1.3 cpu与work进程绑定

1.4 pid路径

1.5 nginx进程的优先级(work进程的优先级)

1.6 调试work进程打开的文件的个数

1.7 服务是否已后台方式运行

1.8 只有master进程没有worker进程

2. event事件(io模型调优)

3. http设置

3.1 mime

3.2 sever下的root

3.3 server块构建虚拟主机

3.4 alias别名

3.5 location匹配

3.5.1 概述

3.5.2 语法规则

3.5.3 匹配优先级

3.5.4 access模块


一、Nginx配置介绍

1. 模块组成

nginx配置的基本结构由核心模块 、标准HTTP模块 、可选HTTP模块 、邮件服务模块、Stream服务模块和第三方模块 组成,允许用户定义全局性的设置、针对HTTP协议的设置,以及特定服务器和URL路径的定制化设置。yum安装通常情况下,Nginx的主配置文件位于/etc/nginx/nginx.conf;子配置文件: include conf.d/*.conf;日志通常位于/var/log/nginx/目录下,包含access.log(访问日志)和error.log(错误日志)等。

  • 核心模块:是 Nginx 服务器正常运行必不可少的模块,提供错误日志记录 、配置文件解析 、事件驱动机制 、进程管理等核心功能
  • 标准HTTP模块:提供 HTTP 协议解析相关的功能,比如: 端口配置 、 网页编码设置 、 HTTP响应头设置等
  • 可选HTTP模块:主要用于扩展标准的 HTTP 功能,让 Nginx 能处理一些特殊的服务,比如:Flash 多媒体传输 、解析 GeoIP 请求、 网络传输压缩 、 安全协议 SSL 支持等
  • 邮件服务模块:主要用于支持 Nginx 的 邮件服务 ,包括对 POP3 协议、 IMAP 协议和 SMTP协议的支持
  • Stream服务模块: 实现反向代理功能,包括TCP协议代理
  • 第三方模块:是为了扩展 Nginx 服务器应用,完成开发者自定义功能,比如: Json 支持、 Lua 支持等

2. 图示 

3. 相关框架 

全局配置
events{  控制事件驱动      }
http  {  web网页配置有关   server  { location  }   }main block:主配置段,即全局配置段,对http,mail都有效
#事件驱动相关的配置   同步
event {...
}   
#http/https 协议相关配置段
http {...
}          
#默认配置文件不包括下面两个块
#mail 协议相关配置段
mail {...
}    
#stream 服务器相关配置段
stream {负载均衡...
}

二. 配置调优

1. 全局配置

1.1 关闭版本和修改版本

关闭版本:

① 修改nginx配置文件 

[root@localhost ~]# vim /apps/nginx/conf/nginx.conf
#这里是编译安装指定的目录,yum安装配置文件默认在/etc/nginx/nginx.conf
http {server_tokens off;
#修改配置文件放在http语句中
[root@localhost ~]# nginx -t                #检测语法是否有误
nginx: the configuration file /apps/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /apps/nginx/conf/nginx.conf test is successful
[root@localhost ~]# nginx -s reload         #重新加载配置文件

② 客户机访问

修改版本: 修改版本名和版本号需要重新编译安装

① 修改源代码

[root@localhost core]# vim /opt/nginx-1.18.0/src/core/nginx.h
13 #define NGINX_VERSION      "版本号"
14 #define NGINX_VER          "软件名/" NGINX_VERSION
#src源代码目录、core核心代码目录[root@localhost core]# vim /opt/nginx-1.18.0/src/http/ngx_http_header_filter_module.c
49 static u_char ngx_http_server_string[] = "Server: fql" CRLF;
#修改头部信息

② 编译安装 

如果服务开启需要先将服务关闭再编译
[root@localhost nginx-1.18.0]# ./configure --prefix=/apps/nginx --user=nginx --group=nginx --with-http_ssl_module --with-http_v2_module --with-http_realip_module --with-http_stub_status_module --with-http_gzip_static_module --with-pcre --with-stream --with-stream_ssl_module --with-stream_realip_module
[root@localhost nginx-1.18.0]#make && make install
[root@localhost nginx-1.18.0]# systemctl stop firewalld.service 
[root@localhost nginx-1.18.0]# setenforce 0
[root@localhost nginx-1.18.0]# /apps/nginx/sbin/nginx
#启动nginx

 ③ 客户机访问

 server_tokens on(默认)软件名/版本号
 server_tokens offfql

1.2 修改启动的进程数

① 修改配置文件

[root@localhost ~]# pstree -p | grep nginx|-nginx(1717)---nginx(1718)
[root@localhost ~]# ps aux | grep -v grep | grep nginx
root       1717  0.0  0.0  46204  1164 ?        Ss   16:06   0:00 nginx: master process /apps/nginx/sbin/nginx -c /apps/nginx/conf/nginx.conf
nginx      1718  0.0  0.1  48736  1996 ?        S    16:06   0:00 nginx: worker process
#查看现有进程数
[root@localhost ~]# vim /apps/nginx/conf/nginx.conf
worker_processes  1;   
#允许的启动工作进程数数量,和真实的cpu数量有关,将数值改为auto
worker_processes  auto;

② 重新加载配置文件,再次查看进程数

[root@localhost ~]# lscpu | grep "CPU(s):"      #查看cpu核心数
CPU(s):                2                       
[root@localhost ~]# nginx -s reload             #重新加载配置文件
[root@localhost ~]# pstree -p | grep nginx|-nginx(1717)-+-nginx(1745)|             `-nginx(1746)
[root@localhost ~]# ps aux | grep -v grep | grep nginx
root       1717  0.0  0.1  46344  2020 ?        Ss   16:06   0:00 nginx: master process /apps/nginx/sbin/nginx -c /apps/nginx/conf/nginx.conf
nginx      1745  0.0  0.1  48856  2120 ?        S    16:07   0:00 nginx: worker process
nginx      1746  0.0  0.1  48856  2120 ?        S    16:07   0:00 nginx: worker process
#此时查看worker进程数已变成两个

1.3 cpu与work进程绑定

将Nginx工作进程绑定到指定的CPU核心,默认Nginx是不进行进程绑定的,绑定并不是意味着当前nginx进程独占以一核心CPU,但是可以保证此进程不会运行在其他核心上,这就极大减少了nginx的工作进程在不同的cpu核心上的来回跳转,减少了CPU对进程的资源分配与回收以及内存管理等,因此可以有效的提升nginx服务器的性能。由于早期开发原因,理论上最大性能为8核心。

CPU序号:
CPU MASK: 00000001:0号CPU         #这里的8个0代表8颗cpu
                     00000010:1号CPU
                     ................
                     10000000:7号CPU 

① 查看指定状态,修改配置文件

[root@localhost ~]# ps axo pid,cmd,psr,ni|grep nginx1717 nginx: master process /apps   0   01745 nginx: worker process         1   01746 nginx: worker process         0   01761 grep --color=auto nginx       0   0
[root@localhost ~]# vim /apps/nginx/conf/nginx.conf
4 worker_cpu_affinity 00000001 00000010;
#序号绑定cpu亲缘性,即把第一个进程放在0号cpu,把第一个进程放在1号cpu

 ② 重新加载配置,再次查看进程状态

[root@localhost ~]# nginx -s reload
[root@localhost ~]# ps axo pid,cmd,psr | grep nginx1717 nginx: master process /apps   01774 nginx: worker process         01775 nginx: worker process         11791 grep --color=auto nginx       1
#此时可以看到两个worker进程分别对应一颗核心

③ 验证进程对应cpu核心是否会改变(不会改变)

1.4 pid路径

 进程号文件位置可以自定义,一般情况下不做修改。

1.5 nginx进程的优先级(work进程的优先级)

 默认优先级为0,将nginx的work进程的优先级调高可以使用nice设置,从而提高效率。nice的优先级是 -20到19。

① 查看进程现有优先级

[root@localhost ~]# ps axo pid,cmd,psr,ni|grep nginx|sort -n  #以数字排序1717 nginx: master process /apps   0   01774 nginx: worker process         0   01775 nginx: worker process         1   01946 grep --color=auto nginx       1   0
#查看默认优先级,默认优先级为0

② 修改配置文件

[root@localhost ~]# vim /apps/nginx/conf/nginx.conf
5 worker_priority -20;
[root@localhost ~]# nginx -s reload

③ 再次查看进程优先级

[root@localhost ~]# ps axo pid,cmd,psr,ni|grep nginx|sort -n1717 nginx: master process /apps   0   01966 nginx: worker process         0 -201967 nginx: worker process         1 -201969 grep --color=auto nginx       1   0

1.6 调试work进程打开的文件的个数

所有worker进程能打开的文件数量上限,包括:Nginx的所有连接(例如与代理服务器的连接等),而不仅仅是与客户端的连接,另一个考虑因素是实际的并发连接数不能超过系统级别的最大打开文件数的限制,最好与ulimit -n 或者limits.conf的值保持一致。

① 文件个数相关介绍

[root@localhost ~]# pstree -p | grep nginx|-nginx(1717)-+-nginx(1966)|             `-nginx(1967)
[root@localhost ~]# cd /proc/1966/fd
[root@localhost fd]# ls
0  1  10  11  2  3  4  5  6  7
#这里的fd文件夹代表进程同一时间打开文件(链接)数,需要将改值尽量调大

 ② 修改配置文件

[root@localhost ~]# vim /apps/nginx/conf/nginx.conf
6 worker_rlimit_nofile 65536;
#所有的进程最多可以打开的文件数量为65536,即master进程下所有的worker进程最大可以打开文件数为65536
#数值根据机器性能而定
[root@localhost ~]# nginx -s reload

③ 系统默认单个进程最多可以打开1024文件,修改内核pam认证文件

[root@localhost ~]# ulimit -a | grep open
open files                      (-n) 1024[root@localhost ~]# vim /etc/security/limits.conf
60 *                -       nofile          65536所有用户       软硬均可
#需要重启才可以生效

1.7 服务是否已后台方式运行

一般服务都是后台运行,前台容器中会用到。

daemon off;
#加入此选项

1.8 只有master进程没有worker进程

实际生产中使用较少,测试机器一般性能较差,worker进程过多影响性能。

master_process off|on;
#是否开启Nginx的master-worker工作模式,仅用于开发调试场景,默认为on

2. event事件(io模型调优)

events {
   worker_connections  65536;  #设置单个工作进程的最大并发连接数
   use epoll;
   #使用epoll事件驱动,Nginx支持众多的事件驱动,比如:select、poll、epoll,只能设置在events模块中设置。
   accept_mutex on; 
   #on为同一时刻一个请求轮流由work进程处理,而防止被同时唤醒所有worker,避免多个睡眠进程被唤醒的设置,默认为off,新请求会唤醒所有worker进程,此过程也称为"惊群",因此nginx刚安装完以后要进行适当的优化。建议设置为on
   multi_accept on; 
   #ON时Nginx服务器的每个工作进程可以同时接受多个新的网络连接,此指令默认为off,即默认为一个工作进程只能一次接受一个新的网络连接,打开后几个同时接受多个。建议设置为on
}

3. http设置

 http协议配置说明:

http {include  mime.types; 
#导入支持的文件类型,是相对于/apps/nginx/conf的目录default_type application/octet-stream; 
#除mime.types中文件类型外,设置其它文件默认类型,访问其它类型时会提示下载不匹配的类型文件
#日志配置部分#log_format main '$remote_addr - $remote_user [$time_local] "$request" '#                 '$status $body_bytes_sent "$http_referer" '#                 '"$http_user_agent" "$http_x_forwarded_for"';#access_log logs/access.log main;
#自定义优化参数sendfile       on; #tcp_nopush     on; #在开启了sendfile的情况下,合并请求后统一发送给客户端。#tcp_nodelay   off; #在开启了keepalived模式下的连接是否启用TCP_NODELAY选项,当为off时,延迟0.2s发送,默认On时,不延迟发送,立即发送用户响应报文。#keepalive_timeout 0;keepalive_timeout  65 65; #设置会话保持时间,第二个值为响应首部:keepAlived:timeout=65,可以和第一个值不同#gzip on; #开启文件压缩server {listen       80; #设置监听地址和端口server_name localhost; #设置server name,可以以空格隔开写多个并支持正则表达式,

3.1 mime

此项为支持的文件格式,如果不支持的格式会自动帮你下载,如果支持就会显示在网页上。

① 查看支持的文件格式

[root@localhost ~]# cat /apps/nginx/conf/mime.types

② 切换到nginx的web目录,新建测试文件

[root@localhost ~]# cd /apps/nginx/html
[root@localhost html]# touch fql.fql 123.html
[root@localhost html]# echo 123 > 123.html

③ 网页访问

3.2 sever下的root

 root指定了主页文件的位置,指定文件的路径,操作详见虚拟主机案例。

3.3 server块构建虚拟主机

Nginx的虚拟主机功能允许一台服务器托管多个域名,并根据不同的域名请求来提供不同的网站内容,从而提高了服务器资源的利用率。这种功能通常被称为"server block"或"server section"。

① 修改主配置文件

[root@localhost ~]# vim /apps/nginx/conf/nginx.conf
22     include       /apps/nginx/conf.d/*.conf;    #如果在该路径下以conf结尾将被读取
[root@localhost ~]# nginx -t                       #检查语法是否有误
[root@localhost ~]# nginx -s reload                #重新加载配置文件

② 新建编辑子配置文件

[root@localhost ~]# mkdir -p /apps/nginx/conf.d/
[root@localhost ~]# cd /apps/nginx/conf.d/
[root@localhost conf.d]# vim pc.conf 
server {                                         #模块listen 80;                               #监听端口sercer_name www.pc.com;                  #域名root /data/nginx/html/pc/;               #访问目录
}[root@localhost conf.d]# vim mobile.conf
server {listen 80;server_name www.mobile.com;root /data/nginx/html/mobile/;
}[root@localhost conf.d]# mkdir /data/nginx/html/{pc,mobile} -p
[root@localhost html]# echo pc > /data/nginx/html/pc/index.html
[root@localhost html]# echo mobile > /data/nginx/html/mobile/index.html

③ 配置客户端/etc/hosts 文件,并访问域名

[root@localhost ~]#vim /etc/hosts
192.168.190.102 www.pc.com www.mobile.com
[root@localhost ~]# curl www.pc.com
pc
[root@localhost ~]# curl www.mobile.com
mobile

3.4 alias别名

root为追加,alias为替换。

server {listen 80;server_name www.fql.com;location /nwes {root /data/nginx/html/pc/;#相当于追加,将文件夹news追加到/data/nginx/html/pc/news}location /study{alias /mnt/nginx/sports/;#相当于替换,访问study就是访问/mnt/nginx/sports}
}

3.5 location匹配

3.5.1 概述

Nginx的location指令是用来匹配请求URL的一种方式,可以根据不同的URL路径来指定不同的处理方式。location指令可以用来匹配请求的URI(Uniform Resource Identifier),并根据匹配的结果来决定如何处理该请求。

3.5.2 语法规则

location [ = | ~ | ~* | ^~ ] uri { ... }

  • = :用于标准url前,需要请求字串与uri精确匹配,大小敏感,如果匹配成功就停止向下匹配并立即处理请求
  • ^~:用于标准url前,表示包含正则表达式,并且匹配以指定的正则表达式开头,对URI的最左边部分做匹配检查,不区分字符大小写
  • ~:用于标准url前,表示包含正则表达式,并且区分大小写
  • ~*:用于标准url前,表示包含正则表达式,并且不区分大写
  • 不带符号:匹配起始于此uri的所有的uri
  • \:用于标准url前,表示包含正则表达式并且转义字符。可以将 . * ?等转义为普通符号
3.5.3 匹配优先级

从高到低:=, ^~, ~/~*,不带符号(起始于根)

注意:alias影响优先级;/和=/,谁在前面谁优先。

服务端:
[root@localhost ~]# cd /apps/nginx/conf.d/
[root@localhost conf.d]# vim fql.conf
server {listen 80;server_name www.fql.com;root /data/html/;            #全局配置,兜底location / {                 #追踪url,根据用户的root /opt/;                  #局部配置}
}
[root@localhost ~]# echo opt > /opt/index.html
[root@localhost ~]# nginx -s reload客户端:
[root@localhost opt]# curl www.fql.com
opt

注意:局部与全局:局部优先级高于全局优先级;当局部没有指明路径,全局兜底。

不区分大小写:

① 新建子配置文件

#正则表达式匹配:
[root@localhost conf.d]# vim fql.conf
server {listen 80;server_name www.fql.com;root /data/html/;location ~* /A.?\.jpg/ {       #不区分大小写root /opt/;}
}

② 在/opt/images文件夹存放A.jpg图片

[root@localhost opt]# ls
A.jpg

③ 网页访问

④ 这里需要注意的,虽然程序不区分大小写,但是Linux(当前xfs)系统内核区分。 

⑤ 解决方法:准备两份

[root@localhost opt]# cp A.jpg a.jpg

只要是图片就去images中找:

server{
location ~* \.(gif|jpg|jpeg|bmp|png|tiff|tif|ico|wmf|js|css)$ {root /data/nginx/images/;}
}
3.5.4 access模块

Nginx的access模块用于控制对服务器资源的访问权限,允许或拒绝特定的请求。这个模块通常用于实现访问控制、安全策略和防盗链等功能。

① 新建子配置

[root@localhost conf.d]# vim test.conf
server {listen 80;server_name www.nginx.com;root /data/html/;location /test {root /data/;deny 192.168.190.1;}
}
[root@localhost conf.d]# nginx -s reload

② 建立文件夹,添加web信息

[root@localhost ~]# mkdir /data/test -p
[root@localhost ~]# echo test/ > /data/test/index.html

③ 192.168.190.1网页访问

④ 其他机器访问

[root@localhost opt]# curl 192.168.190.102/test/
test/

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

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

大模型相关论文笔记

Retrieval-Augmented Generation for Knowledge-Intensive NLP Tasks 用于知识密集型NLP任务的检索增强生成 Facebook 2020 PDF CODE (论文代码链接已失效,以上是最新链接) 引言 大模型有幻觉问题(hallucinations)&…

web前端安全性——CSRF跨站请求伪造

承接上篇讲述的XSS跨站脚本攻击 跨站请求伪造(CSRF) 1、概念 CSRF(Cross-site request forgery) 跨站请求伪造:攻击者诱导受害者进入第三方网站,在第三方网站中,向被攻击网站发送跨站请求。利用受害者在被攻击网站已经获取的注…

Python Web开发记录 Day1:HTML

名人说:莫道桑榆晚,为霞尚满天。——刘禹锡(刘梦得,诗豪) 创作者:Code_流苏(CSDN)(一个喜欢古诗词和编程的Coder😊) 目录 一、HTML1、前端引入和HTML标签①前端引入②浏览…

Stylized Trees and Foliage

程式化的树木和树叶为你的场景提供了各种各样的树木和灌木。 需要安装 Shader Graph,以便对大多数部分使用自定义着色器! 有多种材料和模块化选择。材料上有多种颜色的叶子,甚至有模块化的树创建,可以用提供的模块化预制件构建自己的树。 在演示场景中可以看到以下包:风格…

linux设备树:phandle和port

linux设备树:phandle和port 参考文档: https://elixir.bootlin.com/linux/v5.10.209/source/Documentation/devicetree/bindings/graph.txt https://elixir.bootlin.com/linux/v6.8-rc5/source/Documentation/devicetree/bindings/display/rockchip/roc…

⭐北邮复试刷题LCR 018. 验证回文串__双指针 (力扣119经典题变种挑战)

LCR 018. 验证回文串 给定一个字符串 s ,验证 s 是否是 回文串 ,只考虑字母和数字字符,可以忽略字母的大小写。 本题中,将空字符串定义为有效的 回文串 。 示例 1: 输入: s “A man, a plan, a canal: Panama” 输出: true 解释…

C#通过继承泛型类来分块显示学生的个人信息以及成绩信息

目录 一、涉及到的知识点 1.泛型类的继承 2.泛型类的可视化 (1)用UML图说明泛型类的可视化 (2)用实例说明泛型类的可视化 二、实例1 1.源码 2.生成效果 三、实例2 再发一个继承泛型类的应用案例。 一、涉及到的知识点 …

openEuler安装MySQL客户端、openEuler安装MySQL-client、openEuler部署MySQL-client

MySQL客户端下载链接:https://downloads.mysql.com/archives/community/ mysql-community-client-5.7.30-1.el7.x86_64.rpm mysql-community-common-5.7.30-1.el7.x86_64.rpm mysql-community-libs-5.7.30-1.el7.x86_64.rpm 3个必选 8.0.22以上的版本是4个&…

Facebook的未来蓝图:数字社交的下一个篇章

在数字化时代,社交媒体已经成为人们日常生活中不可或缺的一部分。而在众多的社交媒体平台中,Facebook一直处于领先地位,不断探索着数字社交的新领域和新形式。随着科技的不断发展和社会的不断变革,Facebook正在谱写着数字社交的未…

好书推荐| After Effects 2022案例实战全视频教程

After Effects 2022案例实战全视频教程 作者 :王红卫 书号:9787302631958 定价:99元 出版时间:2023年7月 作者介绍 王红卫 拥有多年设计师的经学经验,北京理工大学百事特教师,水木风云工作室创始人&a…

libgdx摄像头的移动

概述:要知道,做一个游戏,摄像头是必不可少的。接下来,我将讲解libgdx里面摄像头的移动 2d摄像头OrthographicCamera也叫做正交相机 结果展示: 按上下左右是可以移动的 OrthographicCamera camera的使用&#xff1a…

合纵连横 – 以 Flink 和 Amazon MSK 构建 Amazon DocumentDB 之间的实时数据同步

在大数据时代,实时数据同步已经有很多地方应用,包括从在线数据库构建实时数据仓库,跨区域数据复制。行业落地场景众多,例如,电商 GMV 数据实时统计,用户行为分析,广告投放效果实时追踪&#xff…

63-JQuery语法,选择器,事件,方法,遍历循环each,attr(),.prop()

1.一个JS库,用js封装很多的方法放到一个文件里面,直接拿了用就可以 文件名带min是压缩过的不带min是没压缩过的 2.JQuery语法 通过选取HTML元素,并对选取的元素执行某些操作 基础语法:$(selector).action() <!-- 需要把JQuery文件先引入才能用 --><script src…

ICRA 2024:UC伯克利、斯坦福大学等共同开发机器人强化学习套件(SERL),20分钟学会装配电路板!

近年来&#xff0c;机器人强化学习技术领域取得显著的进展&#xff0c;例如四足行走&#xff0c;抓取&#xff0c;灵巧操控等&#xff0c;但大多数局限于实验室展示阶段。将机器人强化学习技术广泛应用到实际生产环境仍面临众多挑战&#xff0c;这在一定程度上限制了其在真实场…

智慧社区的魔力:数据可视化的引领之力

在迅猛发展的科技时代&#xff0c;数据可视化作为一种强大的工具&#xff0c;为智慧社区的建设提供了无限可能。它不仅改变了我们对信息的获取方式&#xff0c;更为社区管理、居民生活等方面注入了新的活力。下面我就以可视化从业者的角度&#xff0c;简单聊聊这个话题。 数据可…

【招聘】资深后端开发工程师-飞书IM(杭州、北京)

职位描述 团队介绍&#xff1a;飞书是字节跳动旗下先进企业协作与管理平台&#xff0c;围绕目标、信息与人三个维度全方位助力组织升级。一站式整合即时沟通、日历、音视频会议、文档、云盘、邮箱等办公协作套件&#xff0c;让组织和个人工作更高效更愉悦。飞书目前已服务包括互…

python52-Python流程控制if分支之不要忘记冒号

从Python语法解释器的角度来看&#xff0c;Python冒号精确表示代码块的开始点&#xff0c;这个功能不仅在条件执行体中如此&#xff0c;后面的循环体、方法体、类体全都遵守该规则。 如果程序遗忘了冒号&#xff0c;那么Python解释器就无法识别代码块的开始点。例如如下程序。…

java内存详解

内存&#xff1a;可理解为“内存条”&#xff0c;所有软件在程序运行时都会进入到内存中 内存划分&#xff08;5块&#xff09; ① 栈&#xff08;Stack&#xff09; 主要运行方法&#xff0c;方法执行完毕会弹栈&#xff0c;释放空间 ② 堆&#xff08;Heap&#xff09; a.主…

Mysql第三关之事务、锁、高可用

简介 本章较深入探索Mysql核心机制&#xff0c;Innodb引擎架构&#xff0c;MVCC多版本并发控制、事务支撑、各种级别的锁、Mysql高可用设计等概括梳理。 Mysql组成架构 图片来自网络 在Mysql架构设计中&#xff0c;大概可以分为Mysql server层和存储引擎层。 Server层 s…

Google插件Sider: ChatGPT Sidebar + GPTs GPT-4 Turbo Sider

Sider: ChatGPT Sidebar 可以使得满屏都是机器人&#xff0c;左侧栏可以打开访问GPT-4. 配置跳板机地址 google 搜索的右侧也有打开