首先卸载掉之前用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. [转帖]shell删除文件前几行或后几行

    https://www.cnblogs.com/1394htw/p/14852207.html shell删除文件前几行或后几行 #!/bin/bash #删除前两行 sed -i '1,2d' fi ...

  2. Oracle DBCA 静默删除以及建库的脚本

    No.1 背景 公司最近有一个测试环境需要重新备份恢复 但是里面有6个数据库实例 400多G的数据文件. 一般情况下 需要drop user xxx cascade ; 然后执行 drop table ...

  3. 一键升级Openssh的方法

    快速升级OpenSSH8.6的办法 首先: 最终的方法 创建一个文件夹,并且设置好一个启动脚本. 内容主要如下: ├── rpm │   ├── openssh-8.6p1-1.el8.x86_64. ...

  4. 【行云流水线】满足你对工作流编排的一切幻想~skr

    流水线模型 众所周知,DevOps流水线(DevOps pipeline)的本质是实现自动化工作流程,用于支持软件开发.测试和部署的连续集成.交付和部署(CI/CD)实践.它是DevOps方法论的核心 ...

  5. echarts轮训展示某个

    //学校资产占比的配置 function schollAssets() { var myChart = window.$echarts.init( document.getElementById('s ...

  6. 【调研】VictoriaMetrics的上报api能否替换prometheus的api?

    prometheus的上报api在:https://github.com/prometheus/client_golang VictoriasMetrics的上报API在:https://github ...

  7. layui之静态表格的分页及搜索功能以及前端使用XLSX导出Excel功能

    LayUI官方文档:https://layui.dev/docs/2/#introduce XLSX NPM地址:https://www.npmjs.com/package/xlsx XLSX 使用参 ...

  8. c和c++编译器之gcc和mingw

    三大编译器:gcc,llvm,clang 什么是gcc? gcc 官方网站:https://gcc.gnu.org GCC(GNU Compiler Collection,GNU编译器套件),是由 G ...

  9. 【三】tensorboard安装、使用教学以及遇到的问题

    相关文章: [一]tensorflow安装.常用python镜像源.tensorflow 深度学习强化学习教学 [二]tensorflow调试报错.tensorflow 深度学习强化学习教学 [三]t ...

  10. PostFix+Dovecot 部署邮件系统

    Postfix 是一种电子邮件服务器是一个开放源代码的软件. Postfix 是MTA邮件传输代理软件.是sendmail提供替代品的一个尝试,在Internet世界中,大部分的电子邮件都是通过sen ...