如何在 CentOS 7 用 cPanel 配置 Nginx 反向代理
摘要:Nginx是最快和最强大的Web服务器之一,以其高性能和低资源占用率而闻名。它既可以被安装为一个独立的Web服务器,也可以安装成反向代理Web服务器。在这篇文章,我将讨论在安装了cPanel管理系统的Centos7服务器上安装Nginx作为Apache的反向代理服务器。
Nginx是最快和最强大的Web服务器之一,以其高性能和低资源占用率而闻名。它既可以被安装为一个独立的Web服务器,也可以安装成反向代理Web服务器。在这篇文章,我将讨论在安装了cPanel管理系统的Centos7服务器上安装Nginx作为Apache的反向代理服务器。
Nginx作为前端服务器用反向代理为静态文件提供服务,Apache作为后端为动态文件提供服务。这个设置将整体提高服务器的性能。
让我们过一遍在已经安装好cPanel11.52的CentOS7x86_64服务器上配置Nginx作为反向代理的安装过程。
首先,我们需要安装EPEL库来启动这个进程
第一步:安装EPEL库
root@server1[/usr]#yum-yinstallepel-release
Loadedplugins:fastestmirror,tsflags,universal-hooks
Loadingmirrorspeedsfromcachedhostfile
*EA4:66.23.237.210
*base:mirrors.linode.com
*extras:mirrors.linode.com
*updates:mirrors.linode.com
ResolvingDependencies
-->Runningtransactioncheck
--->Packageepel-release.noarch0:7-5willbeinstalled
-->FinishedDependencyResolution
DependenciesResolved
========================================================================================
PackageArchVersionRepositorySize
========================================================================================
Installing:
epel-releasenoarch7-5extras14k
第二步:可以安装nDeploy的CentOSRPM库来安装我们所需的nDeployWeb类软件和Nginx插件
root@server1[/usr]#yum-yinstallhttp://rpm.piserve.com/nDeploy-release-centos-1.0-1.noarch.rpm
Loadedplugins:fastestmirror,tsflags,universal-hooks
nDeploy-release-centos-1.0-1.noarch.rpm|1.7kB00:00:00
Examining/var/tmp/yum-root-ei5tWJ/nDeploy-release-centos-1.0-1.noarch.rpm:nDeploy-release-centos-1.0-1.noarch
Marking/var/tmp/yum-root-ei5tWJ/nDeploy-release-centos-1.0-1.noarch.rpmtobeinstalled
ResolvingDependencies
-->Runningtransactioncheck
--->PackagenDeploy-release-centos.noarch0:1.0-1willbeinstalled
-->FinishedDependencyResolution
DependenciesResolved
========================================================================================
PackageArchVersionRepositorySize
========================================================================================
Installing:
nDeploy-release-centosnoarch1.0-1/nDeploy-release-centos-1.0-1.noarch110
第三步:安装nDeploy和NginxnDeploy插件
root@server1[/usr]#yum--enablerepo=ndeployinstallnginx-nDeploynDeploy
Loadedplugins:fastestmirror,tsflags,universal-hooks
epel/x86_64/metalink|9.9kB00:00:00
epel|4.3kB00:00:00
ndeploy|2.9kB00:00:00
(1/4):ndeploy/7/x86_64/primary_db|14kB00:00:00
(2/4):epel/x86_64/group_gz|169kB00:00:00
(3/4):epel/x86_64/primary_db|3.7MB00:00:02
DependenciesResolved
========================================================================================
PackageArchVersionRepositorySize
========================================================================================
Installing:
nDeploynoarch2.0-11.el7ndeploy80k
nginx-nDeployx86_641.8.0-34.el7ndeploy36M
Installingfordependencies:
PyYAMLx86_643.10-11.el7base153k
libeventx86_642.0.21-4.el7base214k
memcachedx86_641.4.15-9.el7base84k
python-inotifynoarch0.9.4-4.el7base49k
python-lxmlx86_643.2.1-4.el7base758k
TransactionSummary
========================================================================================
Install2Packages(+5Dependentpackages)
通过以上这些步骤,我们完成了在我们的服务器上Nginx插件的安装。现在我们可以配置Nginx作为反向代理和为已有的cPanel用户账户创建虚拟主机,为此我们可以运行如下脚本。
第四步:启动Nginx作为默认的前端Web服务器,并创建默认的配置文件
root@server1[/usr]#/opt/nDeploy/scripts/cpanel-nDeploy-setup.shenable
Modifyingapachehttpandhttpsportincpanel
httpdrestartedsuccessfully.
Createdsymlinkfrom/etc/systemd/system/multi-user.target.wants/nginx.serviceto/usr/lib/systemd/system/nginx.service.
Createdsymlinkfrom/etc/systemd/system/multi-user.target.wants/ndeploy_watcher.serviceto/usr/lib/systemd/system/ndeploy_watcher.service.
Createdsymlinkfrom/etc/systemd/system/multi-user.target.wants/ndeploy_backends.serviceto/usr/lib/systemd/system/ndeploy_backends.service.
ConfGen::saheetha
ConfGen::satest
你可以看到这个脚本将修改Apache的端口从80到另一个端口来让Nginx作为前端Web服务器,并为现有的cPanel用户创建虚拟主机配置文件。一旦完成,确认Apache和Nginx的状态。
Apache状态:
root@server1[/var/run/httpd]#systemctlstatushttpd
●httpd.service-ApacheWebServer
Loaded:loaded(/usr/lib/systemd/system/httpd.service;enabled;vendorpreset:disabled)
Active:active(running)sinceMon2016-01-1806:34:23UTC;12sago
Process:25606ExecStart=/usr/sbin/apachectlstart(code=exited,status=0/SUCCESS)
MainPID:24760(httpd)
CGroup:/system.slice/httpd.service
‣24760/usr/local/apache/bin/httpd-kstart
Jan1806:34:23server1.centos7-test.comsystemd[1]:StartingApacheWebServer...
Jan1806:34:23server1.centos7-test.comapachectl[25606]:httpd(pid24760)alreadyrunning
Jan1806:34:23server1.centos7-test.comsystemd[1]:StartedApacheWebServer.
Nginx状态:
root@server1[~]#systemctlstatusnginx
●nginx.service-nginx-nDeploy-highperformancewebserver
Loaded:loaded(/usr/lib/systemd/system/nginx.service;enabled;vendorpreset:disabled)
Active:active(running)sinceSun2016-01-1717:18:29UTC;13hago
Docs:http://nginx.org/en/docs/
MainPID:3833(nginx)
CGroup:/system.slice/nginx.service
├─3833nginx:masterprocess/usr/sbin/nginx-c/etc/nginx/nginx.conf
├─25473nginx:workerprocess
├─25474nginx:workerprocess
└─25475nginx:cachemanagerprocess
Jan1717:18:29server1.centos7-test.comsystemd[1]:Startingnginx-nDeploy-highperformancewebserver...
Jan1717:18:29server1.centos7-test.comnginx[3804]:nginx:theconfigurationfile/etc/nginx/nginx.confsyntaxisok
Jan1717:18:29server1.centos7-test.comnginx[3804]:nginx:configurationfile/etc/nginx/nginx.conftestissuccessful
Jan1717:18:29server1.centos7-test.comsystemd[1]:Startednginx-nDeploy-highperformancewebserver.
Nginx作为前端服务器运行在80端口,Apache配置被更改为监听http端口9999和https端口4430。请看他们的情况:
root@server1[/usr/local/src]#netstat-plan|grephttpd
tcp000.0.0.0:44300.0.0.0:*LISTEN17270/httpd
tcp000.0.0.0:99990.0.0.0:*LISTEN17270/httpd
tcp600:::4430:::*LISTEN17270/httpd
tcp600:::9999:::*LISTEN17270/httpd
apacheport
apacheport
root@server1[/usr/local/src]#netstat-plan|grepnginx
tcp00127.0.0.1:800.0.0.0:*LISTEN17802/nginx:master
tcp0045.79.183.73:800.0.0.0:*LISTEN17802/nginx:master
为已有用户创建的虚拟主机的配置文件在“/etc/nginx/sites-enabled”。这个文件路径包含了Nginx主要配置文件。
root@server1[/etc/nginx/sites-enabled]#ll|grep.conf
-rw-r--r--1rootroot311Jan1709:02saheetha.com.conf
-rw-r--r--1rootroot336Jan1709:02saheethastest.com.conf
一个域名的示例虚拟主机:
server{
listen45.79.183.73:80;
#CPIPVSIX:80;
#ServerNames
server_namesaheetha.comwww.saheetha.com;
access_log/usr/local/apache/domlogs/saheetha.commain;
access_log/usr/local/apache/domlogs/saheetha.com-bytes_logbytes_log;
include/etc/nginx/sites-enabled/saheetha.com.include;
}
我们可以启动浏览器查看网站来确定Web服务器的工作状态。安装后,请阅读服务器上的web服务信息。
root@server1[/home]#ipa|grep-ieth0
3:eth0:<BROADCAST,MULTICAST,UP,LOWER_UP>mtu1500qdiscpfifo_faststateUPqlen1000
inet45.79.183.73/24brd45.79.183.255scopeglobaldynamiceth0
root@server1[/home]#nginx-v
nginxversion:nginx/1.8.0
webserver-status
webserver-status
Nginx将会为任何最新在cPanel中创建的账户创建虚拟主机。通过这些简单的的步骤,我们能够在一台CentOS7/cPanel的服务器上配置Nginx作为反向代理。
Nginx作为反向代理的优势
便于安装和配置。
效率高、性能好。
防止Ddos攻击。
支持使用.htaccess作为PHP的重写规则。
原文发布时间为:2016-09-07
本文来自云栖社区合作伙伴“Linux中国”
相关推荐
某些公司会墙特定网站,如果你有一个可访问的域名和服务器,就可以通过nginx反向代理来来解决这些问题。比如现在我们用mirror.example.com镜像www.baidu.com,以下是详细操作。