Nginx访问控制与虚拟主机(基于端口,基于域名),内附源码

 Nginx访问控制与虚拟主机(基于端口,基于域名),内附源码  

 

nginx安装文件可以从官方网站http://www.nginx.org/下载。下面以稳定版nginx-1.6.0为例,介绍nginx的安装和运行控制,实验主机为redhat6.5系统。

免费提供源码包:百度云盘

 https://pan.baidu.com/s/1nQ9Qok49au7Cn3elS7IbBQ

 

1,编译安装nginx

(1)安装支持软件

nginx的配置及运行需要pcre,zlib等软件包的支持,因此应预先安装这些软件的开发包pcre-devel ,zlib-devel ,以便提供相应的库和头文件,确保nginx的安装顺利

        yum -y install pcre-devel zlib-devel gcc gcc-c++

Nginx访问控制与虚拟主机(基于端口,基于域名),内附源码

 

(2)解压nginx软件包,并创建用户,组。

   nginx服务程序默认以nobody身份运行,建议为其创建专门的用户帐号,以便更准确地控制其访问权限,增加灵活性,降低安全风险。例如:创建一个名为nginx的用户,不建立宿主目录,也禁止登录到shell环境。

        tar xzvf nginx-1.6.0.tar.gz -C /opt

        cd /opt/nginx-1.6.0/

        useradd -M -s /sbin/nologin nginx

Nginx访问控制与虚拟主机(基于端口,基于域名),内附源码

(3)编译安装nginx

./configure /
–prefix=/usr/local/nginx /
–user=nginx /
–group=nginx /
–with-http_stub_status_module             //开启stub_status状态统计模块//
make
make install
ln -s /usr/local/nginx/sbin/* /usr/local/sbin/   //建立软连接,让系统识别nginx命令

Nginx访问控制与虚拟主机(基于端口,基于域名),内附源码  

 Nginx访问控制与虚拟主机(基于端口,基于域名),内附源码  

Nginx访问控制与虚拟主机(基于端口,基于域名),内附源码  

(4)nginx的运行控制

—–检查、启动、重启、停止——–
nginx -t        //检查
nginx            //启动
killall -1 nginx    //重启
killall -3 nginx    //停止

Nginx访问控制与虚拟主机(基于端口,基于域名),内附源码

——-制作管理脚本——–
vi /etc/init.d/nginx
#!/bin/bash
# chkconfig: – 99 20
# description: Nginx Service Control Script
PROG="/usr/local/nginx/sbin/nginx"
PIDF="/usr/local/nginx/logs/nginx.pid"
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

Nginx访问控制与虚拟主机(基于端口,基于域名),内附源码
chmod +x /etc/init.d/nginx
chkconfig –add nginx

Nginx访问控制与虚拟主机(基于端口,基于域名),内附源码

Nginx访问控制与虚拟主机(基于端口,基于域名),内附源码

2.nginx访问状态统计

nginx内置了http_stub_status状态统计模块,用来反馈当前的web访问情况,要使用nginx的统计功能,除了启用内建模块以外,还需要修改nginx.conf配置文件,指定访问位置并添加stub_status配置代码。

[root@ling conf]# vim nginx.conf

server {
        listen       80;
        server_name  localhost;
    charset utf-8;

        location / {
            root   html;
            index  index.html index.htm;
        }

        location ~ /status {
        stub_status   on;
        access_log off;
        }                                                           //在"server"这里插入这4行的

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }

       }
    }

——-解释如下———
location ~ /status {        //访问位置为/status
        stub_status   on;    //打开状态统计功能
        access_log off;        //关闭此位置的日志记录
}

Nginx访问控制与虚拟主机(基于端口,基于域名),内附源码

然后重启nginx服务,新的配置生效后,在浏览器中访问nginx服务器的/status网站位置,可以看到当前的状态统计信息,

Nginx访问控制与虚拟主机(基于端口,基于域名),内附源码

     Active connettions          //表示当前的活动连接数

     server accepts handle requests    //表示已经处理的连接信息    三个数字依次表示:已处理的连接数;成功的TCP握手次数;已处理的请求数

 

Nginx访问控制与虚拟主机(基于端口,基于域名),内附源码  

3,基于域名的虚拟主机

利用虚拟主机,不用为每个要运行的网站提供一台单独的nginx服务器或单独运行一组nginx进程,虚拟主机提供了在同一台服务器,同一组nginx进程上运行多个网站的功能。

使用nginx搭建虚拟主机服务器时,每个虚拟web站点拥有独立的“server{}”配置段,各自监听的ip地址,端口号,网站名。

(1)修改配置文件nginx.conf,把配置文件中的server{}代码段全部去掉,加入两个新的server{}段,对应两个域名accp.com  ,benet.com。

 

Nginx访问控制与虚拟主机(基于端口,基于域名),内附源码

Nginx访问控制与虚拟主机(基于端口,基于域名),内附源码

(2)分别准备各个网站的站点目录和测试首页

Nginx访问控制与虚拟主机(基于端口,基于域名),内附源码

(3)在浏览器中,分别访问两个域名,可以看到不同的页面。

Nginx访问控制与虚拟主机(基于端口,基于域名),内附源码

Nginx访问控制与虚拟主机(基于端口,基于域名),内附源码

4,基于端口的虚拟主机

(1)在配置文件nginx.conf中再添加一个server{}段,端口改为8080,和benet.com对应同一个ip地址。

 

Nginx访问控制与虚拟主机(基于端口,基于域名),内附源码

(2)创建站点目录和测试页面

Nginx访问控制与虚拟主机(基于端口,基于域名),内附源码

(3)访问www.benet.com:8080端口

Nginx访问控制与虚拟主机(基于端口,基于域名),内附源码

5,授权用户的访问控制

nginx和apache一样,可以实现基于用户授权的访问控制,当客户端想要访问相应的网站或者目录时,要求用户输入用户名和密码才能正常访问。

(1)使用htpasswd生成用户认证文件,

Nginx访问控制与虚拟主机(基于端口,基于域名),内附源码

(2)修改密码文件的权限为400,将所有者改为nginx,设置nginx的运行用户能够读取。

Nginx访问控制与虚拟主机(基于端口,基于域名),内附源码

(3)修改主配置文件,添加相应配置项

location / {
            auth_basic "secret";
            auth_basic_user_file /usr/local/nginx/passwd.db;
            root   html;
            index  index.html index.htm;
        }

Nginx访问控制与虚拟主机(基于端口,基于域名),内附源码

(4)用浏览器访问网址,检验控制效果。

Nginx访问控制与虚拟主机(基于端口,基于域名),内附源码

原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/183132.html

(0)
上一篇 2021年11月2日
下一篇 2021年11月2日

相关推荐

发表回复

登录后才能评论