IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 系统运维 -> Nginx网站服务(你想要的都在这) -> 正文阅读

[系统运维]Nginx网站服务(你想要的都在这)

一、Nginx服务基础

■Nginx是一款性能、轻量级Web服务软件

■稳定性高

■系统资源消耗低

■对HTTP并发连接的处理能力高:单台物理服务器可支持30000~50000个并发请求

?编译安装Nginx服务

1、关闭防火墙,将安装nginx所需要的包传到/opt目录下

systemctl stop firewalld.service

setenforce 0
systemctl stop httpd.service

?2、安装依赖包

yum -y install prce-devel zlib-devel gcc gcc-c++ make
#nginx的配置及运行需要及运行需要pcre、zlib等软件包的支持,需要其提供相应和库头文件

?3、创建运行用户、组(Nginx 服务程序默认以为nobody身份运行,建议为其创建专门的用户账号,以便更准确控制其访问权限)

?4、编译安装Nginx

①解压nginx压缩包

?

?②启动configure文件

?③编译安装

?④做个软链接

??ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/

?

?⑤启动nginx

?5、添加Nginx系统服务

方法一:创建系统服务脚本

①创建一个脚本文件

#!/bin/bash
#chkconfig 35 99 20
#Ngnix server script
 
COM="/usr/local/nginx/sbin/nginx"
PID="/usr/local/nginx/logs/nginx.pid"
 
case "$1" in
start)
   $COM
;;
stop)
   kill -s QUIT $(cat $PID)
;;
restart)
   $0 stop
   $0 start
;;
reload)
   kill -s HUP $(cat $PID)
;;
*)
   echo "Usage:$0 {start|stop|restart|reload}"
   exit 1
esac
exit 0

②赋予权限 并添加到系统服务内

?chmod +x /etc/init.d/nginx

?chkconfig --add nginx?

?③启动nginx系统服务

?6、了解nginx服务的主配置文件 vim /usr/local/nginx/conf/nginx.conf

全局配置

#user  nobody;                          #运行用户,若编译时未指定则默认为 nobody
worker_processes  1;                    #工作进程数量,可配置成服务器内核数 * 2,如果网站访问量不大,一般设为1就够用了
#error_log  logs/error.log;             #错误日志文件的位置
#pid        logs/nginx.pid;             #PID 文件的位置

I/O事件配置

events {
    use epoll;                          #使用epoll模型,2.6及以上版本的系统内核,建议使用epoll模型以提高性能
    worker_connections  4096;           #每个进程处理4096个连接

如提高每个进程的连接数还需执行"ulimit -n 65535"命令临时修改本地每个进程可以同时打开的最大文件数。
在Linux平台上, 在进行高并发TCP连接处理时, 最高的并发数量都要受到系统对用户 单—一进程同时可打开文件数量的限制(这是因为系统为每个TCP连接都要创建一个socket句柄,每个socket句柄同时也是一个文件句柄)。
可使用ulimit -a命令查看系统允许当前用户进程打开的文件数限制

HTTP配置

                                                                            ##日志格式设定
    #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;                                                ##支持文件发送(下载)
    ##此选项允许或禁止使用socket的TCP cORK的选项(发送数据包前先缓存数据),此选项仅在使用sendfile的时候使用
    #tcp_nopush     on;
    ##连接保持超时时间,单位是秒
    #keepalive_timeout  0;
    keepalive_timeout  65;
     
    #gzip  on;                                                              ##gzip模块设置,设置是否开启gzip压缩输出
     
server {
        listen       80;                                        ##监听地址及端口
        server_name  www.clj.com;                                       ##站点域名,可以有多个,用空格隔开
 
        #charset utf-8;                                         #网页的默认字符集
 
        #access_log  logs/host.access.log  main;       
 
        location / {                                            ##根目录配置
            root   html;                                        ##网站根目录的位置/usr/local/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   html;
        }

日志格式设定∶
$remote_addr与$http x forwarded for用以记录客户端的ip地址;
$remote user∶ 用来记录客户端用户名称;
$time local∶ 用来记录访问时间与时区;$request∶用来记录请求的url与http协议;
$status∶ 用来记录请求状态;成功是200,
$body bytes sent ∶ 记录发送给客户端文件主体内容大小;
$http referer∶ 用来记录从哪个页面链接访问过来的;
$http user agent∶记录客户浏览器的相关信息;

通常web服务器放在反向代理的后面,这样就不能获取到客户的IP地址了,通过Sremote_add拿到的IP地址是反向代理服务器的iP地址。反向代理服务器在转发请求的http头信息中,可以增加x_forwarded_for信息,用以记录原有客户端的IP地址和原来客户端的请求的服务器地址。

location常见配置指令, root、alias、proxy_ pass
root (根路径配置)∶ 请求ww.clj.com/test/1.jpg,会返回文件/usr/local/nginx/html/test/1.jpg
alias (别名配置)∶请求www.clj.com/test/1.jpg,会返回文件/usr/local/nginx/html/1.jpg
proxy_pass (反向代理配置)∶
proxy_pass http://127.0.0.1:8080/; ------------- 会转发请求到http∶//127.0.0.1∶8080/1.jpg
proxy_pass http://127.0.0.1:8080; --------------会转发请求到http∶//127.0.0.1∶8080/test/1.jpg

访问状态统计配置:

1.1.先使用命令/usr/local/nginx/ sbin/nginx -V查看E安装的Nginx 是否包含HTTP_STUB_STATUS模块

1.2.修改 nginx.conf 配置文件,指定访问位置并添加 stub_status 配置(修改之前进行备份)

2.2? 修改nginx.conf 配置文件,指定访问位置并添加stub_status 配置 (记得提前备份下配置文件)

?

?3、重启服务并访问网页

也可以以curl http://192.168.50.10/status进行awk和if语句进行监控

?

二、Nginx访问控制

基于授权访问控制

1、生成用户密码认证文件

①安装tool软件??htpasswd -c /usr/local/nginx/pass.db ly

②创建用于及密码设置??htpasswd -c /usr/local/nginx/pass.db wqx

?

?③修改配置文件

?④重启服务进行网页访问

?2、基于客户端访问控制

访问控制规则如下:

? deny IP/IP段: 拒绝某个IP或IP段的客户端访问

? allow IP/IP 段: 允许某个IP或IP段的客户端访问

???规则从上往下执行,如匹配则停止,不再往下匹配

①修改配置文件

?这里要加;? ?不然会出错,网页无法访问

?②重启服务访问网页

用被限制的客户端访问

?用没有限制的客户端访问

?

  系统运维 最新文章
配置小型公司网络WLAN基本业务(AC通过三层
如何在交付运维过程中建立风险底线意识,提
快速传输大文件,怎么通过网络传大文件给对
从游戏服务端角度分析移动同步(状态同步)
MySQL使用MyCat实现分库分表
如何用DWDM射频光纤技术实现200公里外的站点
国内顺畅下载k8s.gcr.io的镜像
自动化测试appium
ctfshow ssrf
Linux操作系统学习之实用指令(Centos7/8均
上一篇文章      下一篇文章      查看所有文章
加:2021-08-16 12:07:58  更:2021-08-16 12:09:22 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/15 9:48:37-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码