Nginx-学习笔记

Nginx的介绍

在这里插入图片描述

为什么要学习Nginx

q1:客户端到底要将请求发给那台服务器?
q2:如果所有客户端请求都发生给了服务器1
q3:客户端发送的请求可能是申请动态资源的,也有申请静态资源的

在这里插入图片描述
在搭建集群后,使用Nginx做方向代理服务器。

Nginx的介绍

Nginx的特点:
1.稳定性极强。7*24小时不间断运行。
2.Nginx提供了非常丰富的配置实例。
3.占用内存小,并发量高。

Nginx的安装

安装Nginx

version: '3.1'
services:
  nginx:
    restart: always
    image: daocloud.io/library/nginx:latest
    container_name: nginx
    ports:
      - 80:80

Nginx的配置文件


worker_processes  1;
error_log  /var/log/nginx/error.log warn;
# 以上统称为全局块,worker_processes他的数值越大,Nginx的并发能力越强
# error_log  错误日志存放位置

events {
    worker_connections  1024;
}
# event块
# worker_connections他的数值越大,并发能力越强

http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;
    server {
	    listen       80;
	    listen  [::]:80;
   	 	server_name  localhost;
   	 	
   		location / {
		        root   /usr/share/nginx/html;
		        index  index.html index.htm;
    }
    # location块
	# root:将接收到的请求根据 /usr/share/nginx/html 去查找静态资源
	# index: 默认去上述的路径中找到index.html或者index.htm
}
	# server块
	# listen:代表Nginx监听的端口号
	# localhost:代表Nginx接受请求的ip
}

# http块
# include 代表引入一个外部的文件 -> /mime.types中放着大量的媒体类型
# include /etc/nginx/conf.d/*.conf; -> 引入了conf.d目录下以.conf结尾的配置文件

修改docker-compose文件

version: '3.1'
services:
  nginx:
    restart: always
    image: daocloud.io/library/nginx:latest
    container_name: nginx
    ports:
      - 80:80
    volumes: 
      - /opt/docker_nginx/conf.d/:/etc/nginx/conf.d

Nginx的反向代理

正向代理

在这里插入图片描述
1.正向代理服务时由客户端设立的。
2.客户端了解代理服务器和目标服务器都是谁。
3.帮助咱们实现突破访问权限,提供访问速度,对目标服务器隐藏客户端的ip地址。

反向代理

在这里插入图片描述

1.反向代理服务器是配置在服务端的。
2.客户端是不知道访问的到底是哪一台服务器。
3.达到负载均衡,并且可以隐藏服务器真正的ip地址。

基于Nginx实现反向代理

准备目标服务器

启动tomcat服务器,保证可以直接访问到。

编写Nginx的配置文件

server{
  listen:80;
  server_name localhost;
  # 基于反向代理访问到Tomcat服务器
  location /{
    proxy_pass http://ip:port/;
  }
}

关于Nginx的location路径映射

  1. = 匹配
    location = / {
    #精准匹配,主机名后面不能带任何的字符串
    }
  2. 通用匹配
    location /xxx {
    #匹配所有以/xxx开头的路径
    }
  3. 正则匹配
    location ~/xxx {
    #匹配所有以/xxx开头的路径
    }
  4. 匹配开头路径
    location ^~ /images/ {
    #匹配所有以/image开头的路径
    }
  5. ~* .(gif | jpg|png)$ {
    #匹配以gif,jpg,png结尾的路径
    }
优先级关系

location = > location /xxx/yyy/zzz > location ^~ > location ~, ~* > location /起始路径 > location /

Nginx 负载均衡

Nginx为我们默认提供了三种负载均衡的策略:

  1. 轮询:
    将客户端发起的请求,平均的分配给每一台服务器。
  2. 权重
    会将客户端的请求,根据服务器的权重值不同,分配不同的数量
  3. ip_hash:
    基于发起请求的客户端的ip地址不同,他始终会将请求发送到指定的服务器上。

轮询

想实现Nginx轮询负载机制,只需要在配置文件中添加以下内容

upstream 名字 {
  server ip:port;
  server ip:port;
  .....
}
server {
 listen 80;
 server_name localhost;
 
 location / {
  	 proxy_pass http://upstream的名字/;
	}
}

权重

upstream 名字 {
  server ip:port  weight=权重比例;
  server ip:port  weight=权重比例;
  .....
}
server {
 listen 80;
 server_name localhost;
 
 location / {
  	 proxy_pass http://upstream的名字/;
	}
}

ip_hash

upstream 名字 {
  ip_hash; #有无权重无所谓
  server ip:port  weight=权重比例;
  server ip:port  weight=权重比例;
  .....
}
server {
 listen 80;
 server_name localhost;
 
 location / {
  	 proxy_pass http://upstream的名字/;
	}
}

Nginx动静分离

Nginx的并发能力公式:
workr_processes * worker_connections /4|2 =Nginx最终的并发能力
动态资源需要/4 ,静态资源需要/2
在这里插入图片描述
Nginx通过动静分离,来提升Nginx的并发能力,更快的给用户相应。

动态资源代理

#配置如下
location / {
 proxy_pass 路径;
}

静态资源代理

#配置如下
location / {
 root 静态资源路径;
 index 默认访问路径下的什么资源;
 autoindex on; #代表展示静态资源全部内容,以列表形式展开。
}

先修改docker,添加一个数据券,映射到Nginx服务器的一个目录。


version: '3.1'
services:
  nginx:
    restart: always
    image: daocloud.io/library/nginx:latest
    container_name: nginx
    ports:
      - 80:80
    volumes:
      - /opt/docker_nginx/conf.d/:/etc/nginx/conf.d
      - /opt/docker_nginx/img/:/data/img
      - /opt/docker_nginx/html/:/data/html

添加了index.html和1.jpg静态资源到映射数据券的目录

修改配置文件

upstream my-server{
 ip_hash;
 server  192.168.0.103:8080 weight=10;
 server  192.168.0.103:8081 weight=2;
}

server{
  listen 80;
  server_name localhost;

  # 代理html静态资源
  location /html{
    root /data;
    index index.html;
 }
# 代理到img静态资源
 location /img{
  root /data;
  autoindex on;
 }


 # location / {
  #  proxy_pass http://my-server/;
#}

 # location = /index {
   # proxy_pass http://192.168.0.107:8081/; # tomcat 首页
  #}

 # location ^~ /hlhz_oa_new/ {
  #  proxy_pass http://192.168.0.107:8081/hlhz_oa_new/hlhz_new/login/login.html; #项目首页
 # }

  # 基于反向代理访问tomcat服务器
 # location /{
  #  proxy_pass http://192.168.0.107:8080/; # Hello Nginx!

 # }
 # location /{
 #   root /usr/share/nginx/html;
 #   index index.html index.htm;
 #}
}

Nginx集群

在这里插入图片描述

单点故障,避免Nginx的宕机,导致整个程序的奔溃
准备多台Nginx
准备keepalive,监听Nginx的健康情况
准备haproxy,提供一个虚拟的路径,统一的去接受用户的请求

集群搭建

在这里插入图片描述
Dockerfile
在这里插入图片描述

docker-compose.yml
在这里插入图片描述
enterpoint.sh
在这里插入图片描述
haproxy.cfg
在这里插入图片描述
keepalived-master.conf
在这里插入图片描述
keepalived-slave.conf
在这里插入图片描述
通过xterm拖拽到/opt/docker_nginx_cluster/目录下
docker-compose up -d 启动
先访问单独的两个nginx服务器进行测试。
若两个单独的Nginx服务器可以访问,访问80端口,然后关掉master服务器,看是否能访问到slave服务器。

笔记资料总结于视频,这位老是讲解的很通俗易懂。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
4S店客户管理小程序-毕业设计,基于微信小程序+SSM+MySql开发,源码+数据库+论文答辩+毕业论文+视频演示 社会的发展和科学技术的进步,互联网技术越来越受欢迎。手机也逐渐受到广大人民群众的喜爱,也逐渐进入了每个用户的使用。手机具有便利性,速度快,效率高,成本低等优点。 因此,构建符合自己要求的操作系统是非常有意义的。 本文从管理员、用户的功能要求出发,4S店客户管理系统中的功能模块主要是实现管理员服务端;首页、个人中心、用户管理、门店管理、车展管理、汽车品牌管理、新闻头条管理、预约试驾管理、我的收藏管理、系统管理,用户客户端:首页、车展、新闻头条、我的。门店客户端:首页、车展、新闻头条、我的经过认真细致的研究,精心准备和规划,最后测试成功,系统可以正常使用。分析功能调整与4S店客户管理系统实现的实际需求相结合,讨论了微信开发者技术与后台结合java语言和MySQL数据库开发4S店客户管理系统的使用。 关键字:4S店客户管理系统小程序 微信开发者 Java技术 MySQL数据库 软件的功能: 1、开发实现4S店客户管理系统的整个系统程序; 2、管理员服务端;首页、个人中心、用户管理、门店管理、车展管理、汽车品牌管理、新闻头条管理、预约试驾管理、我的收藏管理、系统管理等。 3、用户客户端:首页、车展、新闻头条、我的 4、门店客户端:首页、车展、新闻头条、我的等相应操作; 5、基础数据管理:实现系统基本信息的添加、修改及删除等操作,并且根据需求进行交流信息的查看及回复相应操作。
现代经济快节奏发展以及不断完善升级的信息化技术,让传统数据信息的管理升级为软件存储,归纳,集中处理数据信息的管理方式。本微信小程序医院挂号预约系统就是在这样的大环境下诞生,其可以帮助管理者在短时间内处理完毕庞大的数据信息,使用这种软件工具可以帮助管理人员提高事务处理效率,达到事半功倍的效果。此微信小程序医院挂号预约系统利用当下成熟完善的SSM框架,使用跨平台的可开发大型商业网站的Java语言,以及最受欢迎的RDBMS应用软件之一的MySQL数据库进行程序开发。微信小程序医院挂号预约系统有管理员,用户两个角色。管理员功能有个人中心,用户管理,医生信息管理,医院信息管理,科室信息管理,预约信息管理,预约取消管理,留言板,系统管理。微信小程序用户可以注册登录,查看医院信息,查看医生信息,查看公告资讯,在科室信息里面进行预约,也可以取消预约。微信小程序医院挂号预约系统的开发根据操作人员需要设计的界面简洁美观,在功能模块布局上跟同类型网站保持一致,程序在实现基本要求功能时,也为数据信息面临的安全问题提供了一些实用的解决方案。可以说该程序在帮助管理者高效率地处理工作事务的同时,也实现了数据信息的整体化,规范化与自动化。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值