仓酷云

标题: 来看看:利用Nginx反向代办署理与proxy_cache缓存搭建CDN服务器的设置办法 [打印本页]

作者: 海妖    时间: 2015-1-16 13:47
标题: 来看看:利用Nginx反向代办署理与proxy_cache缓存搭建CDN服务器的设置办法
在这里你会学到更多的知识,学习linux,更要学习一种geek的精神,python之禅中也说过:以总结分享为荣,以跪求其解为耻;
碰着成绩:
挪动用户会见web服务器www.ckuyun.com很慢

办理举措:
1、在挪动机房安排一台nginx反向代办署理服务器
2、经由过程域名DNS智能剖析,一切挪动用户会见www.ckuyun.com时剖析到nginx反向代办署理服务器
3、nginx反向代办署理服务器与web服务器之间接纳专线毗连
申明:
1、web服务器
线路:电信
IP:192.168.21.129
域名:www.ckuyun.com
2、nginx反向代办署理服务器
线路:挪动
体系:CentOS6.2
IP:192.168.21.164
vi/etc/hosts#编纂,在文件最初增加上面一行
192.168.21.129www.ckuyun.com
3、客户端
线路:挪动
体系:Windows7
IP:192.168.21.130
C:WindowsSystem32driversetchosts#用记事本翻开,在文件最初增加上面一行
192.168.21.164www.ckuyun.com

###################以下操纵在nginx反向代办署理服务器上设置###################


1、封闭SELinux

vi/etc/selinux/config
#SELINUX=enforcing#正文失落
#SELINUXTYPE=targeted#正文失落
SELINUX=disabled#增添
:wq保留,封闭。
shutdown-rnow重启体系
2、开启防火墙80端口
vi/etc/sysconfig/iptables
增加上面的内容
-AINPUT-mstate--stateNEW-mtcp-ptcp--dport80-jACCEPT
/etc/init.d/iptablesrestart#重启防火墙使设置失效
3、安装编译工具
yuminstallwgetmakegccgcc-c++zlib-developensslopenssl-develpcre-develgdkernelkeyutilspatchperl
4、体系商定
软件源代码包寄存地位:/usr/local/src
源码包编译安装地位:/usr/local/软件名字
5、下载软件
cd/usr/local/src#进进目次
(一)、下载nginx(今朝不乱版)
wgethttp://nginx.org/download/nginx-1.0.12.tar.gz
(二)、下载pcre(撑持nginx伪静态)
wgetftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.21.tar.gz
(二)、下载ngx_cache_purge(扫除指定URL缓存)
wgethttp://labs.frickle.com/files/ngx_cache_purge-1.5.tar.gz
6、安装pcre
cd/usr/local/src
mkdir/usr/local/pcre#创立安装目次
tarzxvfpcre-8.21.tar.gz
cdpcre-8.21
./configure--prefix=/usr/local/pcre#设置
make
makeinstall
7、安装nginx
groupaddwww#增加www组
useradd-gwwwwww-s/bin/false#创立nginx运转账户www并到场到www组,不同意www用户间接登录体系
cd/usr/local/src
tarzxvfngx_cache_purge-1.5.tar.gz
tarzxvfnginx-1.0.12.tar.gz
cdnginx-1.0.12
./configure--prefix=/usr/local/nginx--user=www--group=www--with-http_stub_status_module--with-openssl=/usr/--with-pcre=/usr/local/src/pcre-8.21--add-module=../ngx_cache_purge-1.5
注重:--with-pcre=/usr/local/src/pcre-8.21指向的是源码包解压的路径,而不是安装的路径,不然会报错
make#编译
makeinstall#安装
/usr/local/nginx/sbin/nginx#启动nginx
chownwww.www-R/usr/local/nginx/html#设置目次一切者
chmod700-R/usr/local/nginx/html#设置目次权限
vi/etc/rc.d/init.d/nginx#设置nginx开启启动,编纂启动文件增加上面内容
=======================================================
#!/bin/bash
#nginxStartupscriptfortheNginxHTTPServer
#itisv.0.0.2version.
#chkconfig:-8515
#description:Nginxisahigh-performancewebandproxyserver.
#Ithasalotoffeatures,butitsnotforeveryone.
#processname:nginx
#pidfile:/var/run/nginx.pid
#config:/usr/local/nginx/conf/nginx.conf
nginxd=/usr/local/nginx/sbin/nginx
nginx_config=/usr/local/nginx/conf/nginx.conf
nginx_pid=/usr/local/nginx/logs/nginx.pid
RETVAL=0
prog="nginx"
#Sourcefunctionlibrary.
./etc/rc.d/init.d/functions
#Sourcenetworkingconfiguration.
./etc/sysconfig/network
#Checkthatnetworkingisup.
[${NETWORKING}="no"]&&exit0
[-x$nginxd]||exit0
#Startnginxdaemonsfunctions.
start(){
if[-e$nginx_pid];then
echo"nginxalreadyrunning...."
exit1
fi
echo-n$"Starting$prog:"
daemon$nginxd-c${nginx_config}
RETVAL=$?
echo
[$RETVAL=0]&&touch/var/lock/subsys/nginx
return$RETVAL
}
#Stopnginxdaemonsfunctions.
stop(){
echo-n$"Stopping$prog:"
killproc$nginxd
RETVAL=$?
echo
[$RETVAL=0]&&rm-f/var/lock/subsys/nginx/usr/local/nginx/logs/nginx.pid
}
reload(){
echo-n$"Reloading$prog:"
#kill-HUP`cat${nginx_pid}`
killproc$nginxd-HUP
RETVAL=$?
echo
}
#Seehowwewerecalled.
case"$1"in
start)
start

stop)
stop

reload)
reload

restart)
stop
start
;;
status)
status$prog
RETVAL=$?

*)
echo$"Usage:$prog{start|stop|restart|reload|status|help}"
exit1
esac
exit$RETVAL
=======================================================
:wq!保留加入
chmod775/etc/rc.d/init.d/nginx#付与文件实行权限
chkconfignginxon#设置开机启动
/etc/rc.d/init.d/nginxrestart
servicenginxrestart
8、设置nginx
cp/usr/local/nginx/conf/nginx.conf/usr/local/nginx/conf/nginx.confbak#备份nginx设置文件
(一)、设置nginx运转账号
vi/usr/local/nginx/conf/nginx.conf#编纂
找到usernobody;修正为
userwwwwww;#在第一行
(二)、克制nginx空主机头
vi/usr/local/nginx/conf/nginx.conf#编纂
找到server,在下面一行增加以下内容:
##############################
server{
listen80default;
server_name_;
location/{
roothtml;
return404;
}
location~/.ht{
denyall;
}
}
##############################
/etc/rc.d/init.d/nginxrestart#重启nginx
如许设置以后,空主机头会见会间接跳转到nginx404毛病页面。
(三)、增加nginx假造主机包括文件
cd/usr/local/nginx/conf/#进进nginx安装目次
mkdirvhost#创建假造目次
vi/usr/local/nginx/conf/nginx.conf#编纂
找到上一步增加的代码,在最初增加以下内容:
includevhost/*.conf;
比方:
##############################
server{
listen80default;
server_name_;
location/{
roothtml;
return404;
}
location~/.ht{
denyall;
}
}
includevhost/*.conf;
##############################
(四)、增加proxy_cache参数设置包括文件
cd/usr/local/nginx/conf/#进进目次
touchproxy.conf#创建文件
vi/usr/local/nginx/conf/nginx.conf#编纂
找到http{鄙人面增加一行
includeproxy.conf;
(五)、增加被代办署理服务器列表包括文件

cd/usr/local/nginx/conf/#进进目次
touchmysvrhost.conf#创建文件
vi/usr/local/nginx/conf/nginx.conf#编纂
找到上一步增加的代码,鄙人面增加一行
includemysvrhost.conf;
(六)、设置nginx全局参数
vi/usr/local/nginx/conf/nginx.conf#编纂
worker_processes2;#事情历程数,为CPU的中心数大概两倍
events
{
useepoll;#增添
worker_connections65535;#修正为65535,最年夜毗连数。
}
#############以下代码在http{部分增添与修正##############
server_names_hash_bucket_size128;#增添
client_header_buffer_size32k;#增添
large_client_header_buffers432k;#增添
client_max_body_size300m;#增添
tcp_nopushon;#修正为on
keepalive_timeout60;#修正为60
tcp_nodelayon;#增添
server_tokensoff;#增添,不显现nginx版本信息
gzipon;#修正为on
gzip_min_length1k;#增添
gzip_buffers416k;#增添
gzip_http_version1.1;#增添
gzip_comp_level2;#增添
gzip_typestext/plainapplication/x-javascripttext/cssapplication/xml;#增添
gzip_varyon;#增添
(七)、设置proxy_cache参数设置
cd/home#进进目次
mkdir-p/home/proxy_temp_dir#proxy_temp_dir与proxy_cache_dir这两个文件夹必需在统一个分区
mkdir-p/home/proxy_cache_dir#proxy_cache_dir与proxy_temp_dir这两个文件夹必需在统一个分区
chownwww.www-Rproxy_cache_dirproxy_temp_dir#设置目次一切者
chmod-R777proxy_cache_dirproxy_temp_dir#设置目次权限
体系运维www.ckuyun.com温馨提示:qihang01原创内容

作者: 莫相离    时间: 2015-1-18 11:00
当然你不需搭建所有服务,可以慢慢来。自己多动手,不要非等着别人帮你解决问题。
作者: 仓酷云    时间: 2015-1-25 15:55
另外Linux上也有很多的应用软件,安装运行了这些软件后,你就可以在Linux上编辑文档、图?片,玩游戏、上网、播放多媒体文件等。
作者: 不帅    时间: 2015-2-3 06:56
期间我阅读了不少关于Linux的相关资料,其中也不乏一些有趣的小故事,这既丰富了我的课余生活,也让我加深了对一些术语的理解,比玩游戏强多了。?
作者: 透明    时间: 2015-2-8 20:18
我是学习嵌入式方向的,这学期就选修了这门专业任选课。
作者: 乐观    时间: 2015-2-26 04:37
掌握硬件配置,如显卡,声卡,网卡等,硬件只要不是太老或太新一般都能被支持,作为一名Linux系统管理员建议多阅读有关硬件配置文章,对各种不支持或支持不太好的硬件有深刻的了解。
作者: 山那边是海    时间: 2015-3-8 12:05
学习Linux半年了~个人认为不会的多在网上找资料网上有很多资料可以搜索到,LS那位说放手去搞。
作者: 分手快乐    时间: 2015-3-15 23:12
应对Linux的发展历史和特点有所了解,Linux是抢占式多任务多用户操作系统,Linux最大的优点在于其作为服务器的强大功能,同时支持多种应用程序及开发工具。
作者: 灵魂腐蚀    时间: 2015-3-22 18:10
一定要学好命令,shell是命令语言,命令解释程序及程序设计语言的统称,shell也负责用户和操作系统之间的沟通。




欢迎光临 仓酷云 (http://ckuyun.com/) Powered by Discuz! X3.2