nginx-tutorial/demos
Zhang Peng 01857c4c2d 🔖 java app 2018-07-11 19:44:44 +08:00
..
javaapp 🔖 java app 2018-07-11 19:44:44 +08:00
nginx-1.14.0 🔖 调整示例中的端口号 2018-07-05 10:07:17 +08:00
reactapp 🔖 react app 2018-07-11 16:07:16 +08:00
scripts 🔖 启动类路径改变 2018-07-11 17:23:28 +08:00
README.md 📝 Writing docs. 2018-07-05 10:18:30 +08:00
nginx.conf 🔖 nginx-1.14.0 默认配置文件 2018-07-04 11:44:41 +08:00

README.md

Nginx 示例教程

教程说明

环境要求

  • Maven
  • JDK8
  • Nginx-1.14.0(内置)

javaapp

我写了一个嵌入式 Tomcat 的 Java 服务,代码在 javaapp 目录,基于 maven 管理。这个服务可以通过在启动时指定 -Dtomcat.connector.port-Dtomcat.context.path 来分别指定服务启动时的端口号和 context。这样可以很方便的模拟多个服务器的场景。

例如:

java -Dtomcat.connector.port=9030 -Dtomcat.context.path=/app -cp "JavaWebApp/WEB-INF/classes;JavaWebApp/WEB-INF/lib/*" io.github.dunwu.app.Main
  • io.github.dunwu.app.Main 是这个 Java 服务的启动类。
  • JavaWebApp/WEB-INF/classes;JavaWebApp/WEB-INF/lib/* 是 class 路径和 lib 路径,必须指定,否则无法识别启动类。

如上的配置参数,可以启动一个端口号为 9030上下文为 /app 的服务。访问路径为:http://localhost:9030/app

nginx-1.14.0

nginx-1.14.0 是 Nginx 的 windows 环境的 1.14.0 官方版本。之所以把它完整的放入本项目中也是为了方便演示。

我添加了两个 bat 脚本,可以启动和关闭 nginx 服务。

在 Nginx 默认配置文件 nginx.conf 中我通过配置 include demos/*.conf;Nginx/demos/nginx-1.14.0/conf/demos 目录中所有 Nginx 配置示例都引入。

scripts

scripts 中包含了运行示例的启动脚本。目前只支持 windows 下运行,当然想基于此教程改造为在 Linux 下运行也不难,将 nginx-1.14.0 替换为 Linux 版本bat 脚本修改为 shell 即可。

运行步骤:

  1. 首先必须执行 build-javaapp.bat 构建 javaapp
  2. 想运行哪个 demo就执行对应的 demoxx-start.bat 脚本。

添加 hosts

因为示例中使用的不是公网域名,域名服务器不能识别。所以,要演示示例,还需要修改本地 hosts。

  • windows 的 host 路径一般在:C:\Windows\System32\drivers\etc\hosts
  • linxu 的 host 路径一般在:/etc/hosts

示例说明

Demo01 - 简单的反向代理示例

本示例启动一个 JavaApp访问地址为localhost:9010。 在 Nginx 中配置它的反向代理 host 为 www.demo01.com。Nginx 配置文件:demo01.conf

运行步骤:

  1. 执行 demo01-start.bat 脚本。
  2. 配置 hosts127.0.0.1 www.demo01.com
  3. 在浏览器中访问www.demo01.com

Demo02 - 负载均衡示例

本示例启动三个 JavaApp访问地址分别为

  • localhost:9021
  • localhost:9022
  • localhost:9023

在 Nginx 中统一配置它们的反向代理 host 为 www.demo02.com并设置相应权重以便做负载均衡。Nginx 配置文件:demo02.conf

运行步骤:

  1. 执行 demo02-start.bat 脚本。
  2. 配置 hosts127.0.0.1 www.demo02.com
  3. 在浏览器中访问www.demo02.com

如图所示:三次访问的端口号各不相同,说明三个服务器各自均有不同机率(基于权重)被访问。

Demo03 - 多 webapp 示例

当一个网站功能越来越丰富时,往往需要将一些功能相对独立的模块剥离出来,独立维护。这样的话,通常,会有多个 webapp。

http 的默认端口号是 80如果在一台服务器上同时启动这 3 个 webapp 应用,都用 80 端口,肯定是不成的。所以,这三个应用需要分别绑定不同的端口号。

本示例启动三个 JavaApp访问地址分别为

  • localhost:9030/
  • localhost:9031/product
  • localhost:9032/user

Nginx 中的配置要点就是为每个 server 配置一个 upstream。并在 server 配置下的 location 中指定 context 对应的 upstream。

Nginx 配置文件:demo03.conf

运行步骤:

  1. 执行 demo02-start.bat 脚本。
  2. 配置 hosts127.0.0.1 www.demo03.com
  3. 在浏览器中访问www.demo03.com

如图所示:三次访问的 context 和 端口号各不相同。说明 Nginx 根据不同的 context 将请求分发到指定的服务器上。