Nginx使用_Nginx的安装和多域名配置

更新日期: 2018-09-10阅读: 3.5k标签: 运维

Nginx安装

centos6.x yum默认没有nginx的软件包 
安装方式: 
到nginx下载页面http://nginx.org/en/linux_packages.html#stable,复制CENTOS 6的nginx软件源安装包 
运行命令:wget http://nginx.org/packages/centos/6/noarch/RPMS/nginx-release-centos-6-0.el6.ngx.noarch.rpm 
安装rpm包 yum install nginx-release-centos-6-0.el6.ngx.noarch.rpm -y , 此步实际只是加入了nginx的软件包源 
执行 yum install nginx -y 就可以安装好nginx了。

nginx默认安装为Linux的服务 ,所以可以使用service nginx start, stop, restart, try-restart, reload, force-reload, status来操作nginx。


Nginx配置文件

nginx的配置文件默认读取/etc/nginx/nginx.conf文件。

当然也可以修改使用的conf路径,使用命令:
./nginx -c 你的conf文件位置
可以相对路径或者绝对路径。
如果是不熟悉环境的Linux服务器,可以使用命令来快速查找nginx.conf文件 :

sudo  find  / -name "nginx.conf"

也可以使用命令

sudo nginx -t

来输出正在使用的配置文件:

nginx: the configuration file /data/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /data/nginx/conf/nginx.conf test is successful

nginx的配置都是由 directives组成,directives由简单指令或者区块指令组成 
简单指令:listen 80; 
区块指令由{}包含,区块指令又可以包含多个简单指令和区块指令:

http {
    server {
    }
}


多域名配置

我们都知道如果在域名管理的控制面板设置域名对应ip只能设置到ip,不能详细设置到端口。如果一台服务器部署了多个web应用,使用的不同端口启动的,那么就可以Nginx做映射。

比如我有一个域名 www.525.life。

域名还可以分出2级域名: admin.525.life。

我在域名控制面板把这两个域名都指向我的服务器公网ip 123.123.123.123。

这时候发现www.525.life和admin.525.life域名访问都只是对应到了 使用端口80的Web程序(默认的)。

如果我们要访问81端口的应用程序只能使用:

www.525.life:81或者admin.525.life:81。

但是这样很不方便。我们要把端口去掉也能访问就需要使用Nginx做映射。

我们期望www.525.life访问8880端口,admin.525.life访问8881端口。那么可以设置如下:

server
{
    listen 80;
    server_name www.525.life;
    location / {
        #....
        proxy_pass http://localhost:8880;
    }
    ##### other directive
}


server
{
    listen 80;
    server_name admin.525.life;
    location / {
        #....
        proxy_pass http://localhost:8881;
    }
    ##### other directive
}

这样设置就可以了。把8880和8881都映射到80端口的监听。

使用重载命令使nginx生效:

sudo nginx -s reload

使用命令重启nginx生效:

/etc/init.d/nginx restart

这样就能使用www.525.life访问8880端口,admin.525.life访问8881端口。


每个域名一个conf的写法

我们在上面的例子中使用的是一个文件多个域名的写法,也就是只使用一个conf,在里面不断的增加server。这种方式很直观,但是域名多了不好管理。
Nginx支持引入的用法,也就是我们可以在其他地方先新建好conf文件,conf文件中记录server的信息如下:
admin.conf中的内容是:

server
{
    listen 80;
    server_name admin.525.life;
    location / {
        #....
        proxy_pass http://localhost:8881;
    }
    ##### other directive
}
www.conf中的内容是:
server
{
    listen 80;
    server_name www.525.life;
    location / {
        #....
        proxy_pass http://localhost:8880;
    }
    ##### other directive
}

admin.conf和www.conf都放在/data/nginx/conf/vhost目录下。
然后在nginx.conf中使用引入命令:

include             /data/nginx/conf/vhost/*.conf;

即可。需要注意的是这句命令应该放在http{}的花括号内。
因为include的命令引入相当于被引入的所有代码写在nginx.conf中一样。


301跳转

我们留意到生活中很多时候不带www也能访问到某个网站,这也能通过Nginx实现。跟上面的配置一样,再增加一个server如下:

server
{
    listen 80;
    server_name  525.life;
    location / {
        #....
        proxy_pass http://localhost:8880;
    }
    ##### other directive
}

或者进行301跳转

server
{
    listen 80;
    server_name 525.life;
    rewrite ^/(.*) http://www.525.life/$1 permanent;
}


添加404网页

添加404网页,都可又直接在里面添加,如:

server
{
listen 80;
server_name www.web126.com; #绑定域名
error_page 404 /404.html;
}


禁止IP直接访问

最后还有一个方法需要注意,可能有需要禁止IP直接访问80端口或者禁止非本站的域名绑定我们的IP,这样的话应该
如下处理,放到最前一个server上面即可:

server{
listen 80 default;
server_name _;
return 403;
}


链接: https://fly63.com/article/detial/1067

正确的备份级别可节省时间,带宽和存储空间

有效地执行备份和恢复需要仔细考虑使用多个备份级别,因此如果正确规划了增量备份和差异备份,则不需要完全备份。备份和恢复中最基本的一点是备份级别的概念及其含义。如果没有正确理解它们是什么以及它们如何工作,公司就可以采用从浪费的带宽和存储到实际上缺少备份中的重要数据的不良做法。

没执行过 rm -rf /* 的开发不是好运维

打开终端,获取 root 权限,执行以下命令:rm -rf /*,会发生什么呢?估计只要接触过 Linux 的人,肯定没少听过它的故事,清楚之后会发生什么可怕的事情。科普一下,在Linux系统中运行该命令,系统就会忠实的执行命令

内网穿透 frp 配置示例

frp 是一套简单易配的内网穿透服务,可以方便的将内网主机映射至公网。我们只需下载 frp ,在公网主机上配置服务端,在内网主机上配置客户端,运行即可。启动服务端服务:nohup ./frps -c ./frps.ini &

这些自动化运维技巧让网络运维不再背锅

“网络就像wifi,没有故障的时候,就没有人意识到它的存在”,这句话有无数的翻版,但是对于网络工程师来说,这就是现身说法。由于即便是在上千人的公司,网络工程师的人数也仅仅是个位数,所以他们的工作也鲜为人知

如何让运维不再当落后技术的背锅侠?

近年来,企业业务规模的急剧上升,导致运维场景的复杂性也呈指数性上升,原本依靠人工经验的运维工作难度也变得更具有挑战性,而基于机器学习的智能运维(AIOps)开始得到企业IT人员的关注

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!