CDN网络架构
CDN(content delivery network 内容分发网络)
本质上就是提供缓存,使得用户总是能访问离他最近的服务器,akamai是世界上的第一家做CDN的公司
实例:构建CDN分发网络架构
环境:使用7台 Linux主机部署CDN环境架构,使用Nginx作为Web服务器,Squid作为各地区反向代理服务器,Bind作为分离解析DNS服务器
环境如下:
DNS 服务器(192.168.4.253):dns253.hydra.com
反向代理服务器(192.168.4.1):squid1.hydra.com
反向代理服务器(192.168.4.2):squid2.hydra.com
Web1 服务器(192.168.4.3):web1.hydra.com
Web2 服务器(192.168.4..4):web2.hydra.com
测试客户机 01(192.168.4..10):pc01.hydra.com
测试客户机 02(192.168.4..20):pc02.hydra.com
测试时,客户端主机pc01访问http://www.hydra.com 通过DNS解析后,指向,Squid2服务器(192.168.4.2),客户端主机pc02访问http://www.hydra.com通过DNS解析后,指向 Squid1服务器(192.168.4.1)
部署两台Nginx服务器(两台做相同的操作)
使用 yum 安装基础依赖包并使用源码安装 LNMP 环境软件
[root@web1 ~]# yum -y groupinstall "Development tools"
[root@web1 ~]# yum -y install gcc openssl-devel pcre-devel zlib-devel
[root@web1 ~]# useradd –s /sbin/nologin nginx
使用源码安装 Nginx
[root@web1 ~]# tar -zxvf nginx-1.2.0.tar.gz
[root@web1 nginx-1.2.0]# ./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_ssl_module --with-http_flv_module --with-http_stub_status_module --with-http_gzip_static_module
[root@web1 ~]# make && make install
使用源码安装 cmake
[root@web1 ~]# tar -zxvf cmake-2.8.10.2.tar.gz
[root@web1 cmake-2.8.10.2]# ./bootstrap --prefix=/usr/local/cmake
[root@web1 cmake-2.8.10.2]# make && make install
[root@web1 cmake-2.8.10.2]# /usr/local/cmake/bin/cmake --version
[root@web1 ~]# useradd –s /sbin/nologin mysql
使用源码安装 mysql
[root@web1 ~]# tar -zxvf mysql-5.5.13.tar.gz
[root@web1 mysql-5.5.13]# /usr/local/cmake/bin/cmake
\
> -DCMAKE_INSTALL_PREFIX=/usr/local/mysql
\
> -DSYSCONFDIR=/etc
-DMYSQL_DATADIR=/usr/local/mysql/data \
> -DMYSQL_TCP_PORT=3306 \
> -DMYSQL_UNIX_ADDR=/tmp/mysqld.sock \
> -DMYSQL_USER=mysql
-DEXTRA_CHARSETS=all \
> -DWITH_SSL=system
-DENABLED_LOCAL_INFILE=1 \
[root@web1 mysql-5.5.13]# make && make install
[root@web1 mysql-5.5.13]# chown -R mysql.mysql /usr/local/mysql/
[root@web1 mysql-5.5.13]# cd /usr/local/mysql
[root@web1 mysql]#./scripts/mysql_install_db --user=mysql --datadir=/usr/local/mysql/data
使用源码安装 mhash、libiconv、libmcrypt、PHP
[root@web1 ~]# tar -zxvf mhash-0.9.9.9.tar.gz
[root@web1 mhash-0.9.9.9]# ./configure
[root@web1 mhash-0.9.9.9]# make && make install
[root@web1 ~]# tar -zxvf libiconv-1.13.tar.gz
[root@web1 libiconv-1.13]# ./configure
[root@web1 libiconv-1.13]# make && make install
[root@web1 ~]# tar -zxvf libmcrypt-2.5.8.tar.gz
[root@web1 libmcrypt-2.5.8]# ./configure
[root@web1 libmcrypt-2.5.8]# make && make install
[root@web1 libmcrypt-2.5.8]# ldconfig -v
[root@web1 libmcrypt-2.5.8]# cd libltdl
[root@web1 libmcrypt-2.5.8]# cd ./configure --with-gmetad --enable-gexec --enable-ltdl-install
[root@web1 libltdl ]# make && make install
[root@web1 ~]# ln -sv /usr/local/lib/libmcrypt* /usr/lib/
[root@web1 ~]# ln -sv /usr/local/lib/libmhash.* /usr/lib/
[root@web1 ~]# ln -sv /usr/local/lib/libicon.* /usr/lib/
[root@web1 ~]# tar -zxvf php-5.4.9.tar.gz
[root@web1 ~]# cd php-5.4.9
[root@web1 php-5.4.9]# ./configure \
> --prefix=/usr/local/php5 \
> --with-config-file-path=/usr/local/php5nginx/etc \
> --with-mysql=/usr/local/mysql \
> --with-mysqli=/usr/local/mysql/bin/mysql_config \
> --enable-fpm --enable-mbstring
[root@web1 php-5.4.9]# make ZEND_EXTRA_LIBS='-liconv'
[root@web1 php-5.4.9]# make install
[root@web1 php-5.4.9]# cp php.ini-production /usr/local/php5/etc/php.ini
启动相关服务
[root@web1 ~]# /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
[root@web1 ~]# netstat -utnlp | grep :80
启动MySQL,启动前需要拷贝相关配置文件及启动脚本
[root@web1 mysql]# cp /usr/local/mysql/my.cnf /etc/my.cnf
[root@web1 mysql]# cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld
[root@web1 mysql]# chmod +x /etc/init.d/mysqld
[root@web1 mysql]# chkconfig add mysqld
[root@web1 mysql]# chkconfig mysqld on
[root@web1 ~]# service mysqld start
[root@web1 ~]# echo “/usr/local/mysql/lib/” >> /etc/ld.so.conf
[root@web1 ~]# ldconfig
[root@web1 ~]# vim /etc/profile
.. ..
PATH=$PATH:$HOME/bin:/usr/local/mysql/bin/
export PATH
[root@web1 ~]# source /etc/profil
修改配置文件实现 FastCGI 功能,生成 php-fpm 配置文件,默认安装完php后,会自动生成一个php-fpm参考板
[root@web10 ~]# cd /usr/local/php5/etc/
[root@web10 etc]# cp php-fpm.conf.default php-fpm.conf
[root@web10 etc]# vim /usr/local/php5/etc/php-fpm.conf
[global]
pid = run/php-fpm.pid
error_log = log/php-fpm.log
log_level = error
daemonize = yes
[nginx]
user = nginx
group = nginx
listen = 127.0.0.1:9000
pm = dynamic
pm.max_children = 32
pm.start_servers = 15
pm.min_spare_servers = 5
pm.max_spare_servers = 32
[root@web1 ~]# cd php-5.4.9/sapi/fpm/
[root@web1 fpm]# cp init.d.php-fpm /etc/rc.d/init.d/php-fpm
[root@web1 fpm]# chmod +x /etc/rc.d/init.d/php-fpm
[root@web1 fpm]# chkconfig --add php-fpm
[root@web1 fpm]# service php-fpm start
[root@web1 fpm]# ps aux | grep php-fpm
[root@web1 etc]# /usr/local/php5/sbin/php-fpm --fpm-config /usr/local/php5/etc/php-fpm.conf
修改 nginx 配置文件并启动服务
[root@web1 ~]# vim /usr/local/nginx/conf/nginx.conf
location / {
root html;
index index.php index.html index.htm;
}
location ~ \.php$ {
root html;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
include fastcgi_params;
}
[root@web1 ~]# vim /usr/local/nginx/conf/fastcgi_params
.. ..
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param SCRIPT_NAME $fastcgi_script_name;
fastcgi_param DOCUMENT_ROOT $document_
[root@web1 ~]# /usr/local/nginx/sbin/nginx
创建PHP首页文档
[root@web1 ~]# vim /usr/local/nginx/html/index.php
<?php
$links=mysql_connect("localhost","root","密码");(root为mysql账户名称,密码需要修改为实际mysql密码,无密码则留空)
if($links){
echo "link db ok!!!";
}
else{
echo "link db no!!!";
}
?>
部署两台前端 Squid 服务器(两台做相同的操作)
[root@squid1 ~]# yum -y install squid
修改/etc/squid/squid.conf配置文件
[root@squid1 ~]# vim /etc/squid/squid.conf
.. ..
http_port 80 vhost //设置反向代理
visible_hostname squid100.tarena.com //设置主机名
cache_peer 192.168.4.1 parent 80 0 originserver
cache_peer 192.168.4.2 parent 80 0 originserver
cache_mem 128 MB //内存缓存
cache_dir ufs /var/spool/squid 200 16 128 //硬盘缓存
http_access allow localnet //允许本机所在网络中的所以主机使用代理服务器
[root@squid1 ~]# service squid restart; chkconfing squid on(启动 squid 服务,设置为开机启动)
部署 DNS 服务器
[root@dns253 ~]# yum –y install bind bind-chroot
修改 Bind 配置文件实现分离解析,修改主配置文件,添加视图及区域
[root@dns253 ~]# vim /var/named/chroot/etc/named.conf
options
{
directory "/var/named"; //区域数据文件存放路径
listen-on port 53 { any; };
allow-query { any; };
allow-query-cache { any; };
recursion yes;
};
acl client1 { //定义 ACL 指向测试客户端主机 pc01
192.168.4.10;
};
acl client2 { //定义 ACL 指向测试客户端主机 pc02
192.168.4.20;
};
view "zone1" ////定义视图 zone1
{
match-clients { client1; }; //匹配条件为指定 pc01 的 ACL
zone "hydra.com" IN {
tpype master;
file "hydra.com.zone1";
};
};
view "zone2" //定义视图 zone2
{
match-clients { client2; }; //匹配条件为指定 pc02 的 ACL
zone "hydra.com" IN {
type master;
file "hydra.com.zone2";
};
};
修改区域数据文件,添加域名解析记录。因为需要实现分离解析,此区域数据文件需要创建两份,并且要求解析记录要有所不同
[root@dns253 ~]#cp /usr/share/doc/bind-9.8.2/sample/var/named/named.localhost /var/named/chroot/var/named/hydra.com.zone1 //复制模板
[root@dns253 ~]# vim /var/named/chroot/var/named/hydra.com.zone1
$TTL 1D
@ IN SOA @ rname.invalid. (
0 ; serial
1D ; refresh
1H ; retry
1W ; expire
3H ) ; minimum
@ NS dns253.hydra.com.
dns253 A 192.168.4.253
www A 192.168.4.2 //将www解析为Squid2主机的IP地址
squid1 A 192.168.4.1
squid2 A 192.168.4.2
web1 A 192.168.4.3
web2 A 192.168.4.4
pc01 A 192.168.4.10
pc02 A 192.168.4.20
[root@dns254 ~]# cd /var/named/chroot/var/named/
[root@dns254 ~]# vim /var/named/chroot/var/named/hydra.com.zone2
$TTL 1D
@ IN SOA @ rname.invalid. (
0 ; serial
1D ; refresh
1H ; retry
1W ; expire
3H ) ; minimum
@ NS dns253.hydra.com.
dns253 A 192.168.4.253
www A 192.168.4.1 //将www解析为Squid1主机的IP地址
squid1 A 192.168.4.1
squid2 A 192.168.4.2
web1 A 192.168.4.3
web2 A 192.168.4.4
pc01 A 192.168.4.10
pc02 A 192.168.4.20
启动 DNS 服务
[root@dns253 ~]# service named start;chkconfig named on
客户端测试
[root@pc01 ~]# firefox http://www.hydra.com
[root@pc02 ~]# firefox http://www.hydra.com
CDN网络架构的更多相关文章
- 闲谈CDN网络架构
CDN也就是内容分布网络(Context Delivery Network),它是构筑在现有interent上的一种先进的流量分配网络.其目的是通过现有的Internet中增加一层新的网络架构,将网站 ...
- 构建 CDN 分发网络架构简析
构建 CDN 分发网络架构 CDN的基本目的:1.通过本地缓存实现网站的访问速度的提升 CDN的关键点:CNAME在域名解析:split智能分发,引流到最近缓存节点
- 构建 CDN 分发网络架构
cdn基本架构: CDN的基本目的:1.通过本地缓存实现网站的访问速度的提升 CDN的关键点:CNAME在域名解析:split智能分发,引流到最近缓存节点
- 通过Microsoft Azure服务设计网络架构的经验分享(转)
原文:http://www.infoq.com/cn/articles/azure-networking-tips 本文从产品设计和架构角度分享了 Microsoft Azure 网络服务方面的使用经 ...
- 通过Microsoft Azure服务设计网络架构的经验分享
作者 王枫 发布于 2014年4月8日 本文从产品设计和架构角度分享了Microsoft Azure网络服务方面的使用经验,希望你在阅读本文之后能够了解这些服务之间,从而更好地设计你的架构. Mic ...
- 复杂的web---web中B/S网络架构
web中B/S网络架构 1:web中B/S网络架构 2:CDN工作机制和架构 3:负载均衡: B/S分别是浏览器/服务器,架构流程为: 当你访问网站的时候,浏览器发送各种请求给浏览器,服 ...
- B/S网络架构
B/S基于统一的应用层协议HTTP来交互数据,目前的B/S网络架构大多采用如图所示的架构设计,既要满足海量用户访问请求,又要保持用户请求的快速响应. 当一个用户在浏览器输入www.taobao.com ...
- 数据中心网络架构的问题与演进 — 混合云与 VPC 专有网络
目录 文章目录 目录 前文列表 历史背景 混合云 Why hybrid cloud? 混合云市场 混合云的逻辑架构 混合云应用场景 灾难恢复 数据备份 负载扩容 应用部署 开发测试生产部署 混合云产品 ...
- CC视频CTO栗伟:CDN系统架构及CC视频应用实践
2017 年 11 月9日,CC视频获2.08 亿元C轮融资. EGO 北京分会会员.CC视频CTO栗伟获邀作为 EGO 线上分享第三季嘉宾,与大家交流了CDN系统架构及CC 视频的应用实践. \\ ...
随机推荐
- 完美解决打开github速度慢的问题
摘抄自知乎. 修改hosts(HOSTS文件路径:C:\Windows\System32\drivers\etc\hosts) 1.打开Dns检测|Dns查询 - 站长工具 2.在检测输入栏中输入ht ...
- 过16道练习学习Linq和Lambda(转)
1. 查询Student表中的所有记录的Sname.Ssex和Class列. select sname,ssex,class from studentLinq: from s in Students ...
- Tensorflow ActiveFunction激活函数解析
Active Function 激活函数 原创文章,请勿转载哦~!! 觉得有用的话,欢迎一起讨论相互学习~Follow Me Tensorflow提供了多种激活函数,在CNN中,人们主要是用tf.nn ...
- nodejs建立websocket通信
依赖模块 nodejs-websocket 服务端 const ws = require('nodejs-websocket'); console.log('开始建立连接...'); const se ...
- Numpy基础学习
Numpy(Numerical Python的简称)是高性能科学计算和数据分析的基础包. 主要的功能: 1.ndarray,一个具有矢量运算和复杂广播工能的快速且节省空间的多维数组 2.用于对整组数据 ...
- apache 改变文档根目录www的位置
1.找到apache的安装目录,找到config/httpd.conf,找到DocumentRoot "D:/wamp/www/" 改成你想要的目录,例如:改成 DocumentR ...
- MongoDB安装篇-Win7 X64
介绍 MongoDB是一个基于分布式文件存储的数据库.由C++语言编写.旨在为WEB应用提供可扩展的高性能数据存储解决方案. MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库 ...
- PHP的 first day of 和 last day of
话不多说,先上代码(当前是2017年6月2日) echo date("Y-m-d", strtotime("2017-02 first day of")).'& ...
- mac给文件批量添加后缀名
for i in *;do mv "$i" "$i.mp4";done
- 用最简单的例子实现jQuery图片即时上传
[http://www.cnblogs.com/Zjmainstay/archive/2012/08/09/jQuery_upload_image.html] 最近看了一些jQuery即时上传的插件, ...