某俄罗斯小哥,竟靠一个服务器软件直接封神?

云惠网小编 2021年12月31日05:18:06
评论
3629字阅读12分5秒
摘要

最近在搭建一个网站,就不可避免地要用到 Nginx,索性就出一期 Nginx 的入门教程,希望也可以帮助到大家~????作为开发者,相信大家都知道 Nginx 的重要性。Nginx 是一个高性能的 HTTP 和反向代理 Web 服务器,由俄罗斯的伊戈尔·赛索耶夫开发,第一个版本发布于 2004 年 10 月 4 日。Nginx 的特点是:内存占用少并发能力强(可支持大约 50000 个并发连接)配置超简洁bug 非常少安装超简单服务特别稳(几个月也不需要重启)基于这些特点,越来越多的

广告也精彩

一、Nginx 的作用

http://nginx.org/en/download.html

这篇已经收录到《Java 程序员进阶之路》专栏的「Nginx」篇,喜欢这个专栏的小伙伴可以去点个 star 关注下了。冲个 1000 star!

与之相反,反向代理是代理服务器的,让大量的请求均衡地访问到某一台服务器上。

从以上信息可以得出:

https://github.com/itwanger/toBeBetterJavaer

作为开发者,相信大家都知道 Nginx 的重要性。Nginx 是一个高性能的 HTTP 和反向代理 Web 服务器,由俄罗斯的伊戈尔·赛索耶夫开发,第一个版本发布于 2004 年 10 月 4 日。

除此之外,Nginx 还有一个很牛逼的功能是动静分离

我们先来看一下 Nginx 的配置结构图:

nginx  启动
nginx -s stop  停止
nginx -s quit  安全退出
nginx -s reload  重新加载配置文件
ps aux|grep nginx  查看nginx进程

基于这些特点,越来越多的网站开始使用 Nginx。于是,掌握 Nginx 就变成了开发者的一项必不可少的技能。

举个例子,10 万个小二同时在访问 itwanger.com, 如果只有一台服务器的话,很容易就瘫痪了,于是高并发的情况下会有很多台服务器(假如 10 台吧)来接这个活,那怎么让 10 万个小二访问到这 10 台服务器呢?

很言简意赅,总之就是二哥,牛逼~

  • 内存占用少
  • 并发能力强(可支持大约 50000 个并发连接)
  • 配置超简洁
  • bug 非常少
  • 安装超简单
  • 服务特别稳(几个月也不需要重启)
worker_processes  1; # Nginx 进程数,一般设置为和 CPU 核数一样
events {
worker_connections  1024; # 每个进程允许最大并发数
}
http {
include       mime.types; # 文件扩展名与类型映射表
default_type  application/octet-stream;
sendfile        on; # 开启高效传输模式
keepalive_timeout  65; # 保持连接的时间,也叫超时时间,单位秒
server {
listen       8080; # 配置监听的端口
server_name  localhost; # 配置的域名
location / {
root   html; # 网站根目录
index  index.html index.htm; # 默认首页文件
}
error_page   500 502 503 504  /50x.html; # 默认50x对应的访问页面
location = /50x.html {
root   html;
}
}
include servers/*; # 加载子配置项
}

2)黑马程序员Nginx教程,总共 159 讲,基本上算是非常全面的 Nginx 的视频教程了。

Nginx 内置了轮询和加权轮询来达到负载均衡的目的。服务器 A 牛逼就把它的权重加大一点,让 5 万个小二访问它;服务器 B 弱一点,权重就再小一点,让 2 万个小二访问它;服务器 C 更弱,权重就最小,让 1 万个小二访问它。

不过,如果在安装宝塔面板必备工具包的时候,如果选择了 phpmyadmin(MySQL 的管理工具),会覆盖掉 80 端口,就导致没办法直接通过默认配置的方式访问 Nginx 启动页面了。

第一步,通过 brew info nginx 命令查看 Nginx 是否安装。

由于我的服务器上 80 端口是默认打开的,所以我将监听端口配置成了 80,如果你配置成其他端口的话,记得宝塔面板和云服务的安全组里把端口打开。

通常来说,Nginx 一旦启动后,我们是很少让它退出的,使用最多的就是 reload 命令。当我们修改了配置文件,是需要执行一次 reload 命令让 Nginx 生效的。

<!DOCTYPE html>
<html>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>沉默王二</title>
<body>
<img src="https://blog.csdn.net/qing_gee/article/details/122165038/niubi.jpeg" />
</body>
</html>

反向代理是 Nginx 作为 Web 服务器最常用的功能之一。什么是反向代理呢?很多初学者在第一次遇到这个名词的时候总免不了出现很多问号。

二、Nginx 的安装

https://www.bilibili.com/video/BV1F5411J7vK

三、Nginx 常用命令

针对不同的操作系统,Nginx 的安装各不相同。Windows 可以直接到官网下载 zip 绿色安装包,解压后就可以了。

root 我指定了 /home/www 目录,首页文件为 index.html。这个文件是我自定义的,来看一下内容。

第二步,通过 brew install nginx 命令安装 Nginx。

好,现在我们登录宝塔面板,尝试把默认的 server 配置复制到 Linux 服务器中的 Nginx 配置里。

1)狂神说的视频入门教程,我个人觉得,狂神的入门教程还是非常舒适的,语速和内容都刚刚好。

我这里以 macOS 环境为例,来演示一下。


第三步,通过 nginx 命令启动 Nginx。

我这里再给大家推荐一些不错的学习资料吧。

好,保存配置文件,并且 reload Nginx,我们在本地的浏览器中输入服务器的 IP 地址就可以看到效果了。

在我们的软件开发中,有些请求是需要后台处理的;有些请求是不需要后台处理的,比如说 css、js 这些文件请求,这些不需要经过后台处理的文件就叫静态文件。

3)极客xx上的 Nginx100 讲,讲的比较深一点,涉及到不少原理层面的东西。钱包比较鼓的话,可以去付费下。不过,听说在某个地方也可以白票。

main        # 全局配置
├── events  # 配置网络连接
├── http    # 配置代理、缓存、日志等
│   ├── upstream # 配置负载均衡
│   ├── server   # 配置虚拟主机,可以有多个 server
│   ├── server
│   │   ├── location  # 用于匹配 URI(URL 是 URI 的一种),可以有多个 location
│   │   ├── location
│   │   └── ...
│   └── ...
└── ...

总结一句就是,正向代理是代理客户端的,让你能正常访问目的服务器。

要知道,Nginx 的 reload 对用户是无感的,这一点我觉得很牛逼~

之前带大家白票过阿里云的服务器,有 Linux 服务器的话,直接通过宝塔面板这个神器就可以安装了。

第四步,在浏览器地址栏通过 localhost:8080 访问,可以看到以下欢迎页面。

那问题来了。每台服务器的能力可能不同,比如说服务器 A 的内存比较大一点,有 100 个 G;服务器 B 的内存小一点,有 10 个 G;服务器 C 的内存更小一点,只有 1 个 G。怎么才能让没台服务器承担起它能力范围内的访问呢?

Nginx 的特点是:

举个例子,小二的浏览器是无法直接访问谷哥的,但香港的代理服务器是可以访问谷哥的,于是小二访问了香港的代理服务器,也就间接地访问了谷哥。那这台代理服务器也就是正向代理

关于 Nginx 的负载均衡,还有动静分离,等到二哥的网站跑起来后,可以专门搞个视频给大家演示下,比较直观一点。Nginx 的入门非常简单,但有一说一,如果想要在工作中用好 Nginx,还是需要花费一番功夫的。

那要想搞明白什么是反向代理,就必须得搞明白什么是正向代理。

再把 Nginx 的默认配置拉出来看一下,我把注释加了进去,这样大家很容易就明白这行配置是用来干嘛的了。

最近在搭建一个网站,就不可避免地要用到 Nginx,索性就出一期 Nginx 的入门教程,希望也可以帮助到大家~😁

五、Nginx 的学习资料

https://github.com/itwanger/toBeBetterJavaer

简单解释一下。

本篇已收录至 GitHub 上开源专栏《Java 程序员进阶之路》,最近更新了不少干货上去,所以没点 star 的小伙伴赶紧去点一波了,毕竟 star 了这个仓库就等于成为了一名更优秀的 Java 程序员。

这就需要一个反向代理服务器了,反向代理服务器让 1 万个小二访问服务器 A,1 万个小二访问服务器 B,1 个小二访问服务器 C,这样的话,每台服务器的压力就相应减小了,是不是很 nice?

这些资料如果能全部过一遍的话,我要喊你 Nginx 小王子了,估计公司遇到 Nginx 问题的话,你肯定是解决问题的那一个。

我们可以根据一些规则,把动态资源和静态资源分开,然后通过 Nginx 把请求分开,静态资源的请求就不需要经过 Web 服务器处理了,从而提高整体上的资源的响应速度。

YYDS

  • 根目录是 /usr/local/var/www
  • 配置文件是 /usr/local/etc/nginx/nginx.conf
  • 默认端口是 8080

https://www.bilibili.com/video/BV1ov41187bq

四、Nginx 的配置

本文转自 https://blog.csdn.net/qing_gee/article/details/122165038

腾讯云618
云惠网小编
SpringCloud -- Config、Bus解析 java

SpringCloud — Config、Bus解析

1、Config1.1、概述简介1. 分布式面临的问题微服务意味着要将单体应用中的业务拆分成一个个子服务,每个服务的粒度相对较小,因此系统中会出现大量的服务。由于每个服务都需要必要...
Java数据结构-了解复杂度 java

Java数据结构-了解复杂度

2.实例分析与计算  四.写在最后  // 计算斐波那契递归fibonacci的时间复杂度 int fibonacci(int N) { return N < 2 ? N : fibonacci...
Java数据结构-认识顺序表 java

Java数据结构-认识顺序表

目录二.顺序表1.概念及结构2.顺序表的实现打印顺序表获取顺序表的有效长度在pos位置新增元素判断是否包含某个元素查找某个元素对应的位置获取/查找pos位置的元素给pos位置的元素...
腾讯云618

发表评论