首先卸载掉之前用yum命令下载的nginx

yum remove nginx

安装nginx需要的依赖库

yum install -y gcc patch libffi-devel python-devel zlib-devel bzip2-devel openssl openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gdbm-devel db4-devel libpcap-devel xz-devel

下载安装nginx源码包

cd /opt
wget -c https://nginx.org/download/nginx-1.16.0.tar.gz

解压缩源码(还是在/opt目录下)

tar -zxvf nginx-1.16.0.tar.gz

释放编译文件 开启nginx状态监测功能

cd /opt/nginx-1.16.0
./configure --prefix=/opt/nginx116 --with-http_ssl_module --with-http_stub_status_module

编译安装

make && make install

启动nginx,进入sbin目录,找到nginx启动命令

cd /opt/nginx116/sbin
./nginx #启动
./nginx -s stop #关闭
./nginx -s reload # 平滑重启 ,修改了nginx.conf之后,可以不重启服务,加载新的配置

查看nginx运行状态

查看端口是否运行: netstat -tunlp
查看进程是否运行: ps -ef | grep nginx

nginx目录下的文件

conf 存放nginx所有配置文件的目录,主要nginx.conf
html 存放nginx默认站点的目录,如index.html、error.html等
logs 存放nginx默认日志的目录,如error.log access.log
sbin 存放nginx主命令的目录,sbin/nginx

nginx.conf配置文件解析

注意: 在修改配置文件之前,最好是把配置文件备份一份!!!!!



#定义nginx工作进程数
worker_processes 5; #连接数
events {
worker_connections 1024;
} #错误日志
#error_log logs/error.log; #http定义代码主区域
http {
include mime.types; #暂时不用管
default_type application/octet-stream; #暂时不用管 #定义nginx的访问日志功能
#nginx会有一个accses.log功能,查看用户访问的记录
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 logs/access.log main;
sendfile on; #支持发送文件
keepalive_timeout 65; #保持长连接的超时时间
#开启gzip压缩传输
gzip on; #server就是虚拟主机 比如定义一个斗鱼网站
server {
#定义nginx的访问入口端口,访问地址是 192.168.11.37:80
listen 80;
#定义网站的域名www.woshidouyu.tv
#如果没有域名,就填写服务器的ip地址 192.168.11.37
server_name www.woshidouyu.tv; #域名
#nginx的url域名匹配
#只要请求来自于www.woshidouyu.tv/111111111
#只要请求来自于www.woshidouyu.tv/qweqwewqe
#最低级的匹配,只要来自于www.woshidouyu.tv这个域名,都会走到这个location
location / { #网站的根目录
#这个root参数,也是关键字,定义网页的根目录
#以nginx安装的目录为相对路径 /opt/nginx116/html
#可以自由修改这个root定义的网页根目录
root html; #网站服务器的根目录
#index参数定义网站的首页文件名,默认的文件名
index index.html index.htm;
}
#错误页面的优化(只要是遇到前面4系列的错误,就会直接跳转到相对目录下的40x.html页面)
error_page 400 401 402 403 404 /40x.html;
error_pag 500 502 503 504 /50x.html;
location = /50x.html{ #http://www.woshidouyu.tv/50x.html
root html; #网站服务器的根目录
}
}
}

nginx启动出现错误的情况

如果你在平滑重启nginx时出现以下情况的话,说明你的nginx没有启动



解决方案:

# 只需要将nginx启动起来即可
/opt/nginx116/sbin/nginx

nginx错误页面

配置nginx错误页面

vim /opt/nginx116/conf/nginx.conf
修改server代码块
server {
listen 80;
server_name www.qishihuya.com; location / {
root /opt/www/qishihuya;
index index.html index.htm;
}
#error_page 500 502 503 504 /50x.html;
error_page 400 402 403 404 /40x.html;
location = /40x.html {
root html;
}
} 平滑重启nginx
/opt/nginx112/sbin/nginx -s reload

nginx错误页面优化

打开百度或其他网站,随便输入一个不存在的链接,就可以访问到错误页面
右键点击页面空白处,查看网页源代码
拷贝源代码,粘贴到/opt/nginx112/html/40x.html下面去
再访问我们的网站,随便输入一个不存在的链接, 就可以访问到这个错误页面
http://192.168.1.40/asldfjasd

nginx访问日志功能

nginx限制网站来源IP访问



如果想要在本地访问一个域名, 可以更改本机hosts文件

windows下

c:\\\windows\system32\drivers\etc\hosts

linux下

/etc/hosts

nginx状态检测功能

在虎牙或者其他server代码块添加以下配置

location /status {
# 开启nginx状态检测功能
stub_status on;
}



平滑重启nginx

/opt/nginx166/sbin/nginx -s reload

配置nginx多虚拟主机

效果:

(1) 访问三个不同的域名,显示三个不同的网站

(2) 三个网站互不影响



修改配置文件

 worker_processes  5;

#error_log  logs/error.log;

events {
worker_connections 1024;
} http {
include 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 logs/access.log main;
sendfile on;
keepalive_timeout 65;
#gzip on;
# 配置多个server即可,并且修改server_name,以及不同网站的根目录及index.html页面
server {
listen 80;
server_name www.douyu.top; location / {
root /opt/web_server/douyu; #前提需要创建好目录,并且在目录下创建一个index.html文件,并将代码写入
index index.html index.htm;
}
#error_page 404 /404.html;
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
server {
listen 80;
server_name www.huya.top;
location /{
root /opt/web_server/huya; #前提需要创建好目录,并且在目录下创建一个index.html文件,并将代码写入
index index.html;
}
}
server {
listen 80;
server_name www.zhanqi.top;
location /{
root /opt/web_server/zhanqi; #前提需要创建好目录,并且在目录下创建一个index.html文件,并将代码写入
index index.html;
}
} }

在服务器上创建三个目录

cd /opt
rm -rf web_server
mkdir -p web_server/huya
mkdir -p web_server/douyu
mkdir -p web_server/zhanqi
touch web_server/huya/index.html
touch web_server/huya/index.html
touch web_server/huya/index.html
分别打开这三个index.html文件
vim index.html
分别添加三个直播网站的源代码内容
然后保存退出

修改本机hosts文件

c:\\windows\system32\drivers\etc\hosts

添加以下三行解析记录

10.0.3.156 www.huya.top
10.0.3.156 www.zhanqi.top
10.0.3.156 www.douyu.top

平滑重启nginx

/opt/nginx196/sbin/nginx -s reload

网站访问

浏览器上直接输入 www.huya.top 即可看到页面
浏览器上直接输入 www.zhanqi.top 即可看到页面
浏览器上直接输入 www.douyu.top 即可看到页面

Nginx代理功能

实现一个反向代理

实验效果

在windows中访问代理服务器,然后让代理服务器去拿web服务器的数据

请求数据: windows   ——>   10.0.3.156(假如公网IPwww.qishi8huya.com)   ——>   10.0.3.2(由它返回数据)
返回数据: windows <—— 10.0.3.156 <—— 10.0.3.2 机器准备,两台服务器 反向代理服务器 10.0.3.156 淘宝服务器 10.0.3.2

修改代理服务器10.0.3.156的配置文件

vim /opt/nginx116/conf/nginx.conf
在location代码块下添加一行数据
proxy_pass http://10.0.3.2:8060;



重启代理服务器的nginx

/opt/nginx196/sbin/nginx -s reload

访问代理服务器的IP: 192.168.12.139

访问的结果是192.168.12.200返回的数据即可

Nginx负载均衡

负载均衡原理





配置负载均衡服务器

有三台机器 一台为nginx代理服务器(负载均衡调度器), 另外两台为WEB服务器

10.0.3.156    # 负载均衡调度器
10.0.3.2 # WEB服务器1
10.0.3.212 # WEB服务器2
相当于就是当用户访问10.0.3.156时会返回10.0.3.2服务器上的数据,某天当web服务器1挂掉了,那么用户再次访问10.0.3.156时则会返回10.0.3.212服务器上的数据,因为这两台服务器返回的数据都是相同的,这就是高可用性。

完成效果

用户访问10.0.3.156,由nginx代理服务器通过负载均衡调度器分别分配到两个WEB服务器,实现负载均衡



准备三台机器

10.0.3.156    # 负载均衡调度器
10.0.3.2 # WEB服务器1
10.0.3.212 # WEB服务器2

两个WEB服务器可以正常访问

访问web服务器1返回“代噶好,我系帅帅刘 我真的是1.40这台机器”
访问web服务器2返回“MMP 我TM是文龙”

在nginx代理服务器(负载均衡调度器)上面做如下配置:

# 在http代码块里面,添加配置
upstream qishi8_pool {
server 10.0.3.2:8060;
server 10.0.3.212;
} 在location代码块内,添加
location / {
proxy_pass http://qishi8_pool; #改成跟上面一样的
root html;
index index.html index.htm;
}



分别平滑重启三台机器的nginx服务

/opt/nginx196/sbin/nginx -s reload

访问10.0.3.156就可以看到,WEB1和WEB2交替返回数据

配置权重

在upstream里面配置weight的数值,可以调整服务器的请求权重

可以通过以下几种方式进行权重的配置

调度算法      概述
轮询     按时间顺序逐一分配到不同的后端服务器(默认)
weight    加权轮询,weight值越大,分配到的访问几率越高
ip_hash    每个请求按访问IP的hash结果分配,这样来自同一IP的固定访问一个后端服务器
url_hash   按照访问URL的hash结果来分配请求,是每个URL定向到同一个后端服务器
least_conn 最少链接数,那个机器链接数少就分发

linux下安装nginx(编译安装)及反向代理及负载均衡的更多相关文章

  1. Linux 下面安装 nginx 以及进行TCP反向代理、负载均衡的过程

    1. 下载安装nginx 注意 因为stream 并不是 nginx自带的module  所以需要 在安装是 通过 --with 的方式增加上. 下载必要的程序包 # openssl wget htt ...

  2. 通过Nginx+tomcat+redis实现反向代理 、负载均衡及session同步

    一直对于负载均衡比较陌生,今天尝试着去了解了一下,并做了一个小的实验,对于这个概念有一些认识,在此做一个简单的总结 什么是负载均衡 负载均衡,英文 名称为Load Balance,指由多台服务器以对称 ...

  3. nginx和tomcat实现反向代理、负载均衡和session共享

    这类的文章很多,nginx和tomcat实现反向代理.负载均衡实现很容易,可以参照http://blog.csdn.net/liuzhigang1237/article/details/8880752 ...

  4. Nginx 全模块安装及匹配方式、反向代理和负载均衡配置

    一.安装 OpenResty OpenResty 是一个基于 Nginx 与 Lua 的高性能 Web 平台,其内部集成了大量精良的 Lua 库.第三方模块以及大多数的依赖项.用于方便地搭建能够处理超 ...

  5. Tomcat+Nginx+Redis+MySQL实现反向代理、负载均衡、session共享

    一.环境准备 时间同步 关闭防火墙 联通网络,配置yum源 软件包链接:https://pan.baidu.com/s/1qYbtpnQ 二.安装nginx 1.解决依赖关系 [root@nginx- ...

  6. (Nginx+Apache)实现反向代理与负载均衡

    反向代理负载均衡 使用代理服务器可以将请求转发给内部的Web服务器,使用这种加速模式显然可以提升静态网页的访问速度.因此也可以考虑使用这种技术,让代理服务器将请求均匀转发给多台内部Web服务器之一上, ...

  7. Nginx的使用(反向代理,负载均衡)

    在我目前的工作内容中,接触到Nginx的用处无外乎两点: 1. 反向代理,解决前端跨域的问题 工作内容有门户的概念,就是将各个子系统集成到门户里,在门户里面访问,这样就很容易造成跨域的问题 那么解决的 ...

  8. Nginx的特性功能-反向代理、负载均衡、缓存、动静分离、平滑升级

    反向代理 nginx配置文件 events  {   }  事件驱动 httpd  {   }   关于httpd相关的配置 server {  }  定义虚拟主机 location {   }    ...

  9. Nginx入门简介和反向代理、负载均衡、动静分离理解

    场景 Nginx简介 Nginx ("engine x")是一个高性能的 HTTP 和反向代理服务器 特点是占有内存少,并发能力强,事实上 nginx 的并发能力确实在同类型的网页 ...

  10. nginx详解、反向代理、负载均衡和LNMP架构

    资源池 nginx官方网站:http://nginx.org/ nginx官方文档:http://nginx.org/en/docs/ 本章资源: 点击这里 资源提取码:u2jv 1.nginx简介 ...

随机推荐

  1. [转帖]Ipmitool跟OS下的ipmi模块之间的关系

    https://www.jianshu.com/p/71614d3288e8 OS下默认加载了ipmi的相关模块 注:此时OS下可以正常使用ipmitool命令访问本机的ipmi 设备. [root@ ...

  2. Springboot 使用nacos鉴权的简单步骤

    Springboot 使用nacos鉴权的简单步骤 背景 前端时间nacos爆出了漏洞. 因为他的默认token固定,容易被利用. 具体的问题为: QVD-2023-6271 漏洞描述:开源服务管理平 ...

  3. [转帖]setsockopt(setsockopt的使用方法及注意事项)

    http://xingzuo.aitcweb.com/9156453.html 1. setsockopt简介 setsockopt是一个系统调用函数,用于设置套接字选项.套接字是指通信的两个端点之间 ...

  4. [转帖]iozone磁盘读写测试工具的使用以及命令详解、下载(网站最详细讲解步骤)

    一.iozone简介 iozone是一款开源工具,用来测试文件系统的读写性能,也可以进行测试磁盘读写性能. 二.下载 方式一:网站下载http://www.iozone.org/ 方式二:个人网盘存放 ...

  5. [转帖]TaiShan v110 - Microarchitectures - HiSilicon

      https://en.wikichip.org/wiki/hisilicon/microarchitectures/taishan_v110 Edit Values TaiShan v110 µa ...

  6. [转帖]20个常用的Linux工具命令

    https://www.cnblogs.com/codelogs/p/16060113.html 简介# 网上有很多辅助开发的小工具,如base64,md5之类的,但这些小工具其实基本都可以用Linu ...

  7. Windows 审计日志 安全部分不刷新的解决办法

    现在存在一个问题如图示: 有接近15个小时的日志没有进行记录和展示. 要追查问题比较麻烦. 后来发现必须要手动刷新一下 审计记录才可以实现. 感觉比较奇怪 位置为  计算机配置->windows ...

  8. 让你彻底理解TypeScript中的readonly

    1.readonly的讲解 readonly修饰符,首先是一个关键字 对类中的属性成员进行修饰修饰之后,该属性成员就不能修改了.只能够进行访问 在构造函数中是可以对只读属性(readonly)进行修改 ...

  9. 【发现一个小问题】坑爹的官方日志库`golang.org/x/exp/slog`,凭啥不让我设置debug级别日志

    作者:张富春(ahfuzhang),转载时请注明作者和引用链接,谢谢! cnblogs博客 zhihu Github 公众号:一本正经的瞎扯 一个代码使用了官方的日志库"golang.org ...

  10. 解决Chrome翻译无法使用

    截止2022年11月3日自己ping出的ip不可用了 可以用以下ip 172.217.215.90 172.253.115.90 142.250.126.90 142.250.10.90 142.25 ...