nginx的配置和负载均衡

nginx配置systemctl

我们平常启动nginx需要进入/opt/nginx/nginxserve/sbin/去启动nginx,启动的过程太麻烦,所以我们可以直接添加一个nginx的配置,让他可以和mysql一样,使用

systemctl start mysqld

这条命令后直接就可以启动

我们切换到切换到/lib/systemd/system/目录中

可以看到目录里有mysqld.service,这就是为什么mysql可以直接使用systemctl命令直接启动,所以我们直接新建一个文件,nginx.service

touch nginx.service

编译文件

将配置放入到文件中

[Unit]
Description=nginx
After=network.target
[Service]
Type=forking
ExecStart=/opt/nginx/nginxserver/sbin/nginx  -c /opt/nginx/nginxserver/conf/nginx.conf
ExecReload=/opt/nginx/nginxserver/sbin/nginx -s  reload
ExecStop=/opt/nginx/nginxserver/sbin/nginx  -s stop
PrivateTmp=true
[Install]
WantedBy=multi-user.target

保存之后让我们的配置生效

生效成功之后我们就直接启动nginx

查看进程启动成功,配置成功

Nginx配置详解

nginx配置文件nginx.conf组成

Nginx 的主要配置文件是 nginx.conf,它包含了 Nginx 服务器的全局配置、http 配置、server 配置以及 location 配置等信息。

全局块(Global Block)

全局块包含了对整个 Nginx 服务器的全局配置,主要包括配置运行 Nginx 服务器的用户(组)、允许生成的 worker process 数,进程 PID 存放路径、日志存放路径和类型以 及配置文件的引入等。

worker_processes  1;

worker_processes配置,是Nginx服务器并发进行处理服务的关键配置,该值越大,可以支持的并发处理量也越多,但是会受到硬件、软件等设备的约束。

events块

events块涉及的指令,主要影响Nginx服务器与用户的网络连接,常用的设置包括:是否开启对多work process下的网络连接进行序列化,是否允许同时接收多个网络连接,选取哪种时间驱动模型来处理连接请求,每个work process可以同时支持的最大连接数等。

events {
    worker_connections  1024;
}

上述配置表示每个work process支持的最大连接数为1024。这部分的配置对Nginx的性能影响较大,在实际中应该灵活配置。

http块

http全局块配置的指令包括:文件引入、MIME-TYPE定义、日志定义、连接超时时间、单链接请求数上限等。

http块也可以包括http全局块、server块。反向代理、动静分离、负载均衡都是在这部分中配置的。

http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;
​
    server {
        listen       80;
        server_name  localhost;
​
        location / {
            root   html;
            index  index.html index.htm;
        }
​
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
    }
}

全局server块

server块:这块和虚拟主机有密切关系,从用户角度看,虚拟主机和一台独立的硬件主机是完全一样的,该技术的产生是为了节省互联网服务器硬件成本。每个http块可以包含多个server块,而每个server块就相当于一个虚拟主机。而每个server块也分为全局server块,以及可以同时包含多个location块。

location 块

location 块用于匹配请求的 URL,并定义了针对这些 URL 的特定处理方式,比如反向代理、重定向、静态文件服务等。基于Nginx服务器接收到的请求字符串(例如server_name/uri-string),对虚拟主机名称(也可以是IP别名)之外的字符串(例如:前面的/uri-string)进行匹配,对特定的请求进行处理。地址定向、数据缓存和应答控制等功能,还有许多第三方模块的配置也在这里进行。

一个server块可以配置多个location块。

配置端口号

我们在启动jar包时可以自定义一个端口号

Java -jar test.jar --server.port=8899 ...

也可以在启动jar包之前设置它的端口号

负载均衡

负载均衡是指将用户的请求分配到多个后端服务器上进行处理,以达到优化资源利用率、提高响应速度和增加系统的可靠性的目的。负载均衡器通常位于用户和服务器之间,接收用户的请求,并根据某种算法将请求分发给合适的后端服务器。

配置Upstream

我们要在ngin的conf配置文件里去配置upstream,然后把我们的服务器地址要放进去

Aaa 代理的服务器是192.168.227.100:8999和192.168.227.101:8999;

访问192.168.227.99 的时候直接跳转到35 或者36 的项目中

反向代理

启动两个服务器上的两个jar包

启动nginx

在浏览器访问页面

再次刷新页面

发现数据变了,页面在第一个服务器和第二个服务器来回跳,那就说明负载均衡成功了

  • 19
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值