Nginx入门
一、安装(基于docker-compose)
使用docker安装Nginx非常简单,只需要准备如下YML文件即可:
version: "3"
services:
nginx12:
restart: always
image: daocloud.io/library/nginx:1.12.0
container_name: nginx12
ports:
- 80:80
在 /opt 下创建nginx目录,在nginx目录中创建上述docker-compose.yml文件,执行docker-compose up -d
命令:
查看docker容器:
在浏览器中测试访问,出现如下页面,即安装成功。
二、配置文件
使用命令docker exec -it nginx容器id bash
进入nginx容器内部:
进入容器的 /etc/nginx目录下:
可以看到一个配置文件nginx.conf
和 一个配置文件目录conf.d
2.1、核心配置文件 nginx.conf
# 全局块
user nginx;
worker_processes 1; # 数值越大,nginx并发能力越强
error_log /var/log/nginx/error.log warn; # nginx错误日志存放路径
pid /var/run/nginx.pid;
# event块
events {
worker_connections 1024; # 数值越大,nginx的并发能力越强
}
# HTTP块
http {
include /etc/nginx/mime.types; # 引入一个外部文件:mime.types 存放有大量的媒体类型(请求/响应头类型)
default_type application/octet-stream; # 默认使用的媒体类型
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 /var/log/nginx/access.log main;
sendfile on;
#tcp_nopush on;
keepalive_timeout 65;
#gzip on;
include /etc/nginx/conf.d/*.conf; # 引入/etc/nginx/conf.d目录下以.conf结尾的配置文件
}
2.2、默认配置文件 default.conf
默认情况下,nignx容器的/etc/nginx/conf.d
路径下有一个default.conf
配置文件
内容如下:
server {
listen 80; # 监听端口号
server_name localhost; # nginx接收请求的IP或域名
#charset koi8-r;
#access_log /var/log/nginx/log/host.access.log main;
location / {
root /usr/share/nginx/html; # 静态资源路径
index index.html index.htm; # 首页
}
#error_page 404 /404.html;
# redirect server error pages to the static page /50x.html
#
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root /usr/share/nginx/html;
}
# proxy the PHP scripts to Apache listening on 127.0.0.1:80
#
#location ~ \.php$ {
# proxy_pass http://127.0.0.1;
#}
# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
#
#location ~ \.php$ {
# root html;
# fastcgi_pass 127.0.0.1:9000;
# fastcgi_index index.php;
# fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
# include fastcgi_params;
#}
# deny access to .htaccess files, if Apache's document root
# concurs with nginx's one
#
#location ~ /\.ht {
# deny all;
#}
}
三、反向代理
3.1、修改docker-compose.yml文件
由于nginx主要需要配置的是/etc/nginx/conf.d
下的配置文件,所以在docker-compose.yml中配置一个数据卷。文件内容如下:
version: "3"
services:
nginx12:
restart: always
image: daocloud.io/library/nginx:1.12.0
container_name: nginx12
ports:
- 80:80
volumes:
- /opt/volumes/nginx12/conf.d:/etc/nginx/conf.d
然后重新创建nginx容器
3.2、自定义配置文件
进入数据卷目录,创建一个my.conf配置文件,添加如下内容:
server {
listen 80;
server_name localhost;
location / {
root /usr/share/nginx/html;
index index.html index.htm;
}
}
重启nginx之后,在浏览器测试:
3.3、实现反向代理
nginx实现反向代理非常简单,只需要修改配置文件即可。
修改my.conf如下:
server {
listen 80;
server_name localhost;
location / {
# 动态资源转发
proxy_pass http://www.baidu.com/; # 转发请求至百度
}
}
在浏览器中输入http://192.168.1.7/可以跳转至百度首页
四、负载均衡
Nginx自身提供了三种负载均衡策略:
- 轮询——将客户端请求轮流分派给服务器(默认方式)
- 权重——根据服务器配置的权重比例而有偏向的分派
- IP_Hash——根据IP的哈希值指定分派,同一个IP的请求只会发送给个同一个服务器
4.1轮询配置
Nginx默认使用此方式,配置如下:
# upstream块
# my-server:自定义名称,注意不要使用该下划线"_"
upstream my-server{
# server配置 IP:PORT
server 192.168.1.7:8080;
server 192.168.1.7:8081;
}
server {
listen 80;
server_name localhost;
location / {
# 将映射路径指定为upstream配置即可
proxy_pass http://my-server;
}
}
4.2、权重
想要使用权重,只需要在upstream中的server路径后添加weight
配置:
upstream my-server{
# server配置 IP:PORT
server 192.168.1.7:8080 weight=10; # weight:权重,数值越大权重越高,注意weight=10中不要有空格
server 192.168.1.7:8081 weight=2;
}
server {
listen 80;
server_name localhost;
location / {
# 将映射路径指定为upstream配置即可
proxy_pass http://my-server;
}
}
4.3、IP_Hash
使用IP_Hash只需要在upstream块中添加ip_hash;
配置即可:
upstream my-server{
ip_hash;
# server配置 IP:PORT
server 192.168.1.7:8080;
server 192.168.1.7:8081;
}
server {
listen 80;
server_name localhost;
location / {
proxy_pass http://my-server;
}
}
五、动静分离
Nginx的并发能力公式如下:
静态资源 = worker_processes * worker_connections / 2
动态资源 = worker_processes * worker_connections / 4
通过动静分离,Nginx可以提升并发性能(更多并发)、提高处理效率(更快响应)。
5.1、动态代理配置
location / {
proxy_pass http://IP:PORT;
}
5.2、静态代理配置
注意:静态资源是指Nginx服务器中的资源,若使用docker创建容器的方式开启Nginx,则指的是Nginx容器内部的资源,当然,可以通过数据卷方式映射到本机。
location / {
root 静态资源路径;
# 可选配置
index 资源名称;# 首页
autoindex on;# 以列表的方式展示静态资源下的全部内容
}
示例:
-
为Nginx内部的一个目录添加数据卷映射
version: "3" services: nginx12: restart: always image: daocloud.io/library/nginx:1.12.0 container_name: nginx12 ports: - 80:80 volumes: - /opt/volumes/nginx12/conf.d:/etc/nginx/conf.d # 静态资源映射路径 - /opt/volumes/nginx12/static:/opt/static
-
配置静态资源路径
upstream my-server{ ip_hash; # server配置 IP:PORT server 192.168.1.7:8080; server 192.168.1.7:8081; } server { listen 80; server_name localhost; location / { proxy_pass http://my-server; } location /static { root /opt; index index.jpg; autoindex off; } }
访问http://192.168.1.7/static/: