Nginx网站服务——服务基础,访问控制(实战!)

关于Nginx

一款高性能,轻量级web服务软件

稳定性高
系统资源消耗低
对HTTP并发连接的处理能力高

  • 单台物理服务器可支持30000~50000个并发请求

环境

一台Linux服务器(192.168.13.128)
一台win10测试机

一,在Windows上将LAMP所需压缩软件包共享出来(此处如有问题请看之前的博客相关文章)

二,在Linux上使用远程共享获取文件并挂载到mnt目录下

[[email protected] ~]# smbclient -L //192.168.100.3/   ##远程共享访问
Enter SAMBA\root‘s password: 

                Sharename       Type      Comment
                ---------       ----      -------
                LAMP-C7         Disk
[[email protected] ~]# mount.cifs //192.168.100.3/LAMP-C7 /mnt  ##挂载到/mnt目录下

三,编译安装Nginx

1,解压源码包到/opt下,并查看

[[email protected] ~]# cd /mnt    ##切换到挂载点目录
[[email protected] mnt]# ls
apr-1.6.2.tar.gz                  Discuz_X2.5_SC_UTF8.zip  LAMP-php5.6.txt
apr-util-1.6.0.tar.gz             error.png                mysql-5.6.26.tar.gz
awstats-7.6.tar.gz                httpd-2.4.29.tar.bz2     nginx-1.12.0.tar.gz
cronolog-1.6.2-14.el7.x86_64.rpm  kali.jpg                 php-5.6.11.tar.bz2
[[email protected] mnt]# tar zxvf nginx-1.12.0.tar.gz -C /opt   ##解压Nginx源码包到/opt下
[[email protected] mnt]# cd /opt/    ##切换到解压的目录下
[[email protected] opt]# ls
nginx-1.12.0  rh

2,安装编译需要的环境组件包

[[email protected] opt]# yum -y install gcc \                                       //c语言
gcc-c++ \                        //c++语言
pcre-devel \                     //pcre语言工具
zlib-devel                       //数据压缩用的函式库

3,创建程序用户nginx并编译Nginx

[[email protected] opt]# useradd -M -s /sbin/nologin nginx  ##创建程序用户,安全不可登陆状态
[[email protected] opt]# id nginx
uid=1001(nginx) gid=1001(nginx) 组=1001(nginx)
[[email protected] opt]# cd nginx-1.12.0/                 ##切换到nginx目录下
[[email protected] nginx-1.12.0]# ./configure \         ##配置nginx
> --prefix=/usr/local/nginx \        ##安装路径
> --user=nginx \                         ##用户名
> --group=nginx \                       ##用户组
> --with-http_stub_status_module     ##状态统计模块

4,编译和安装

[[email protected] nginx-1.12.0]# make     ##编译
...
[[email protected] nginx-1.12.0]# make install   ##安装
...

5,优化nginx启动脚本,以便于系统识别

[[email protected] nginx]# ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/  ##创建软连接让系统识别nginx启动脚本
[[email protected] nginx]# nginx -t       ##检查配置文件的语法问题
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
[[email protected] nginx]# nginx      ##开启ngnix
[[email protected] nginx]# netstat -ntap | grep 80     ##查看端口,nginx已经开启
tcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      39620/nginx: master
[[email protected] nginx]# systemctl stop firewalld.service    ##关闭防火墙
[[email protected] nginx]# setenforce 0 

6,安装elinks网页测试工具,并进行测试

[[email protected] nginx]# yum install elinks -y    ##安装elinks软件
[[email protected] nginx]# elinks http://localhost  ##测试nginx网页

7,服务开启重载以及关闭

[[email protected] nginx]# killall -s QUIT nginx   ##停止 或者使用killall -3 nginx
[[email protected] nginx]# killall -s HUP nginx    ##重启 或者使用killall -1 nginx
[[email protected] nginx]# nginx                         ##开启

8,制作管理脚本,便于使用service管理使用

[[email protected] nginx]# cd /etc/init.d/   ##切换到启动配置文件目录
[[email protected] init.d]# ls
functions  netconsole  network  README
[[email protected] init.d]# vim nginx         ##编辑启动脚本文件

#!/bin/bash
# chkconfig: - 99 20                                    ##注释信息
# description: Nginx Service Control Script
PROG="/usr/local/nginx/sbin/nginx"           ##设置变量为nginx命令文件
PIDF="/usr/local/nginx/logs/nginx.pid"       ##设置变量PID文件 进程号为5346
case "$1" in
    start)
        $PROG                                              ##开启服务
        ;;
    stop)
        kill -s QUIT $(cat $PIDF)                    ##关闭服务
        ;;
    restart)                                                  ##重启服务
        $0 stop
        $0 start
        ;;
    reload)                                                  ##重载服务
        kill -s HUP $(cat $PIDF)
        ;;
    *)                                                           ##错误输入提示
                echo "Usage: $0 {start|stop|restart|reload}"
                exit 1
esac
exit 0
[[email protected] init.d]# chmod +x /etc/init.d/nginx    ##给启动脚本执行权限
[[email protected] init.d]# chkconfig --add nginx          ##添加到service管理器中
[[email protected] init.d]# service nginx stop                ##就可以使用service控制nginx
[[email protected] init.d]# service nginx start

Nginx的访问状态统计

  • 启用HTTP_STUB_STATUS状态统计模块
  • nginx -V可以查看已安装的Nginx是否包含统计模块

一,修改nginx配置文件

[[email protected] ~]# cd /usr/local/nginx/conf     ##切换到配置文件目录
[[email protected] conf]# vim nginx.conf              ##修改Nginx配置文件

server {
    listen       80;
    server_name  www.kgc.com;        ##指明一个域名

    charset utf-8;                                 ##中文字符集

    #access_log  logs/host.access.log  main;

    location / {
        root   html;
        index  index.html index.htm;
    }
    location /status {                           ##添加状态统计
    stub_status on;
    access_log off;
    }

二,安装DNS服务器做域名解析

1,安装bind服务

[[email protected] conf]# yum install bind -y   ##安装DNS服务

2,配置主配置文件/etc/named.conf

 [[email protected] conf]# vim /etc/named.conf   ##主配置文件

options {
                listen-on port 53 { any; };      ##将本机监听为所有
                listen-on-v6 port 53 { ::1; };
                directory       "/var/named";
                dump-file       "/var/named/data/cache_dump.db";
                statistics-file "/var/named/data/named_stats.txt";
                memstatistics-file "/var/named/data/named_mem_stats.txt";
                recursing-file  "/var/named/data/named.recursing";
                secroots-file   "/var/named/data/named.secroots";
                allow-query     { any; };      ##允许所有

3,配置区域配置文件(etc/named.rfc1912.zones)

[[email protected] conf]# vim /etc/named.rfc1912.zones  ##配置区域配置文件
zone "localhost" IN {             ##复制模板到下面
                                type master;
                                file "named.localhost";
                                allow-update { none; };
};

zone "kgc.com" IN {              ##修改localhost为kgc.com
                                type master;
                                file "kgc.com.zone";      ##创建区域数据配置文件
                                allow-update { none; };
};

4,编辑区域数据配置文件( kgc.com.zone)

[[email protected] conf]# cd /var/named
[[email protected] named]# cp -p named.localhost kgc.com.zone
##复制模板为kgc.com.zone
[[email protected] named]# vim kgc.com.zone  ##编辑区域数据配置文件

$TTL 1D
@       IN SOA  @ rname.invalid. (
                                                                        0       ; serial
                                                                        1D      ; refresh
                                                                        1H      ; retry
                                                                        1W      ; expire
                                                                        3H )    ; minimum
                                NS      @
                                A       127.0.0.1
www IN  A       192.168.13.128   ##删除ipv6 添加域名解析地址为本机

5,关闭防火墙并开启服务

[[email protected] named]# systemctl start named   ##开启dns服务
[[email protected] named]# systemctl stop firewalld.service    ##关闭防火墙
[[email protected] named]# setenforce 0   ##关闭增强功能

6,利用win10测试机来测试


基于授权的访问控制

配置步骤与Apache基本一致

  • 生成用户密码认证文件
  • 修改主配置文件对相应目录,添加认证配置项
  • 重启服务,访问测试

一,修改主配置文件

[[email protected] ~]# cd /usr/local/nginx/conf     ##切换到配置文件目录
[[email protected] conf]# vim nginx.conf              ##修改Nginx配置文件

    location / {
        auth_basic "secret";                                ##验证类型
        auth_basic_user_file /usr/local/nginx/passwd.db;      ##验证文件路径
        root   html;
        index  index.html index.htm;
    }

二,安装httpd-tools工具包,设置密码认证文件

[[email protected] conf]# yum install httpd-tools -y    ##安装工具包
[[email protected] conf]# htpasswd -c /usr/local/nginx/passwd.db test    ##设置密码认证文件
New password:          ##输入密码
Re-type new password:        ##确认密码
Adding password for user test
[[email protected] conf]# cat /usr/local/nginx/passwd.db      ##查看密码认证文件
test:$apr1$LqqHZeX3$24E7/HeacTVRzKA7nvSgY/
[[email protected] conf]# service nginx stop      ##关闭服务
[[email protected] conf]# service nginx start      ##开启服务

三,使用win10测试机测试


谢谢阅读!!!

原文地址:https://blog.51cto.com/14080162/2446634

时间: 2024-11-05 22:01:37

Nginx网站服务——服务基础,访问控制(实战!)的相关文章

Nginx网站服务——基础服务与访问控制

Nginx简述 Nginx是一款高性能,轻量级web服务软件,其稳定性高.系统资源消耗低, 对HTTP并发连接的处理能力高(单台物理服务器可支持30000~50000个并发请求). Nginx常用命令 nginx -t 检查配置文件语法 nginx 启动nginx服务 killall -3 nginx 停止nginx服务 killall -s QUIT nginx 停止nginx服务 killall -s HUP nginx 重载nginx服务 killall -1 nginx 重载nginx服

部署Nginx网站服务实现访问状态统计以及访问控制功能

Nginx专为性能优化而开发,最知名的优点是它的稳定性和低系统资源消耗,以及对HTTP并发连接的高处理能力,单个物理服务器可支持30000-50000个并发请求. Nginx的安装文件可以从官方网站http://www.nginx.org/下载,下面以Nginx1.12版本为例,基于CentOS7,部署Nginx网站服务. 安装Nginx 第一步源码编译安装 1. 安装支持软件 Nginx的配置及运行需要gcc . gcc-c++ . make . pcre.pcre-devel.zlib-de

在Linux系统中搭建Nginx网站服务

关于Nginx 一款高性能.轻量级Web服务软件 稳定性高 系统资源消耗低 对HTTP并发连接的处理能力高 单台物理服务器可支持30000 ~ 50000个并发请求 Nginx编译安装 Nginx源码包下载 安装支持软件 [[email protected] opt] yum install gcc gcc-c++ make pcre-devel zlib-devel -y 创建运行用户.组 [[email protected] opt] useradd -M -s /sbin/nologin

Centos 7部署Nginx网站服务

一.Nginx服务基础 Nginx专为性能优化而开发,其最知名的优点是它的稳定性和低系统资源消耗,以及对HTTP并发连接的高处理能力(单台物理服务器可支持30000~50000个并发请求).正因为如此,大量提供社交网络.新闻资讯.电子商务及虚拟主机等服务的企业纷纷选择Nginx来提供Web服务. 1.Nginx服务的优势 Nginx是一个很牛的高性能Web和反向代理服务器,它具有有很多非常优越的特性: 高并发连接:官方测试能支撑5万并发连接,在实际生产环境中跑到2,~3W并发连: 内存消耗少:在

Nginx网站服务

一.简介 Nginx ("engine x") 是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP服务器.Nginx是由Igor Sysoev为俄罗斯访问量第二的Rambler.ru站点开发的,第一个公开版本0.1.0发布于2004年10月4日.其将源代码以类BSD许可证的形式发布,因它的稳定性.丰富的功能集.示例配置文件和低系统资源的消耗而闻名.2011年6月1日,nginx 1.0.4发布. Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件

nginx网站服务于虚拟主机

   Nginx网站服务于虚拟主机 1:nginx的优点: 稳定性高 系统资源消耗低 http并发量处理能力好可支持30000-50000个并发请求 主要用于静态页面 以线程为单位,一个进程对应多个用户,(线程很少占用系统资源) 2:与Apache的对比: Apache主要用于动态页面 支持功能多 稳定性能高 Apache以进程为单位,一个用户对应一个进程(一对一) 3:nginx主要用于:电商,网站,社交,门户...... 4:安装及控制nginx 1.安装支持软件 [[email prote

搭建nginx网站服务及应用

实验环境: 服务器系统:Redhat 6.2             ip地址:192.168.10.1 客户机系统:Win7 64位 旗舰版   ip地址:192.168.10.2 系统环境:已搭建LAMP平台 1.搭建nginx服务并实现访问状态统计 [[email protected] ~]#yum -y install pcre-devel zlib-devel  #首先需要安装这两个工具 [[email protected] ~]#useradd -M -s /sbin/nologin

Nginx网站服务+LNMP架构及应用部署

第2章:Nginx网站服务 防伪码:撑起坚强! Nginx专为性能优化而开发,其最知名的优点是它的稳定性和低系统资源消耗,以及对HTTP并发连接的高处理能力(单台物理服务器可支持30000-50000个并发请求).正因如此,大量提供社交网络.新闻资讯.电子商务及虚拟主机等服务的企业纷纷选择Nginx来提供Web服务. 一.安装及运行 1.搭建yum仓库,安装支持软件 2.创建运行用户.组(nginx默认以nobody身份运行,不安全,所以需要创建用户) 3.编译安装nginx和解包 为了方便管理

构建Nginx网站服务

随着计算机与Internet技术的蓬勃发展,各种Web站点成为直接面向用户的中坚力量,在各种网站服务器软件中,除了Apache外,还有一款轻量级的HTTP服务器软件--Nginx,其稳定性.高效的特性逐渐被越来越多的用户认可.本篇博客将搭建Nginx网站服务器,并配置基于域名的虚拟Web主机 Nginx的基本配置 Nginx是由俄罗斯的Igor Sysoev专为性能优化而开发,其最知名的优点是它的稳定性和低系统资源消耗,以及对HTTP并发连接的高处理能力(单台物理服务器可支持30 000-50