与其他CDN服务商相比,编程之家CDN的主要优势包括稳定快速、性价比高、简单易用、高效智能。比较多的用户会问到稳定快速这个优点,一般来说,编程之家的CDN特点是分担源站压力,避免网络拥塞,确保在不同区域、不同场景下加速网站内容的分发,提高资源访问速度。以下给大家介绍下mysql数据库推送平台与CDN。
sendfile(数据直接从 kernal的buffer出去)适合小文件
Aio(Nginx)全异步(与事件驱动io的区别是:数据会到达mem才会通知,其实也不需要通知 可以直接返回给客户端) 支持:mmap event drive(处理大文件)
上一回说到,在数据库修改后,redis里面的数据不能做到自动更新,必须手动删除更改过的数据 根据以上问题我们做出如下改进:
所以接下来就要通过 MysqL 触发器将改变的数据同步到 redis 中
Gearman 是一个支持分布式的任务分发框架:
Gearman Job Server: Gearman 核心程序,需要编译安装并以守护进程形式运行在后台。
Gearman Client:可以理解为任务的请求者。
Gearman Worker:任务的真正执行者,一般需要自己编写具体逻辑并通过守护进程方式
运行,Gearman Worker 接收到 GearmanClient 传递的任务内容后,会按顺序处理。
大致流程:下面要编写的 MysqL 触发器,就相当于 Gearman 的客户端。修改表,插入表就相当于直接
下发任务。然后通过 lib_MysqLudf_json UDF 库函数将关系数据映射为 JSON 格式,然后
在通过 gearman-MysqL-udf 插件将任务加入到Gearman 的任务队列中,最后通过
redis_worker.PHP,也就是 Gearman 的worker 端来完成 redis 数据库的更新。
dd1:
cd /root/redis
安装gearman软件包:
yum install gearmand-1.1.8-2.el6.x86_64.rpm libgearman-1.1.8-2.el6.x86_64.rpm
/etc/init.d/PHP-fpm start
netstat -antlpe
dd1:安装PHP的gearman扩展
tar zxf gearman-1.1.2.tgz
cd gearman-1.1.2
PHPize
rpm -ivh libgearman-devel-1.1.8-2.el6.x86_64.rpmlibevent-devel-1.4.13-4.el6.x86_64.rpm libevent-doc-1.4.13-4.el6.noarch.rpmlibevent-headers-1.4.13-4.el6.noarch.rpm
./configure
make && make install
cd /etc/PHP.d/
cp MysqL.ini gearman.ini
vim gearman.ini
/etc/init.d/PHP-fpm restart
查看PHP已经安装过的扩展:
PHP -m | grep gearman
PHP -m | grep MysqL
PHP -m | grep redis
cd redis/
scp gearman-MysqL-udf-0.6.tar.gz 172.25.42.12
scp lib_MysqLudf_json-master.zip 172.25.42.12:
scp libevent-* libgearman-* 172.25.42.12:
dd3:
/etc/init.d/MysqLd start
tar zxf gearman-MysqL-udf-0.6.tar.gz
yum install MysqL-devel -y
rpm -ivh libgearman-devel-1.1.8-2.el6.x86_64.rpmlibevent-devel-1.4.13-4.el6.x86_64.rpm libevent-doc-1.4.13-4.el6.noarch.rpmlibevent-headers-1.4.13-4.el6.noarch.rpm
cd gearman-MysqL-udf-0.6
./configure --libdir=/usr/lib64/MysqL/plugin/
make && make install
cd /usr/lib64/MysqL/plugin/
进入MysqL环境:
注册 UDF 函数
MysqL> CREATE FUNCTION gman_do_background RETURNS STRING SONAME
'libgearman_MysqL_udf.so';
MysqL> CREATE FUNCTION gman_servers_set RETURNS STRINGSONAME
'libgearman_MysqL_udf.so';
查看函数
MysqL> select * from MysqL.func;
安装 lib_MysqLudf_json
lib_MysqLudf_jsonUDF 库函数将关系数据映射为 JSON 格式。通常,数据库中的数据映射为 JSON 格式,是通过程序来转换的
unzip lib_MysqLudf_json-master.zip
cd lib_MysqLudf_json-maste
gcc $(MysqL_config --cflags) -shared -fPIC -olib_MysqLudf_json.so
lib_MysqLudf_json.c
查看 MysqL 的模块目录:
MysqL> show global variables like 'plugin_dir'
拷贝 lib_MysqLudf_json.so 模块:
cp lib_MysqLudf_json.so /usr/lib64/MysqL/plugin/
注册 UDF 函数
MysqL> CREATE FUNCTION json_object RETURNS STRING SONAME
'lib_MysqLudf_json.so'
查看函数
MysqL> select * from MysqL.func;
指定 gearman 的服务信息
MysqL>SELECT gman_servers_set('172.25.42.10:4730');
编写 MysqL 触发器 test.sql
MysqL < test.sql
查看触发器
MysqL> SHOW TRIGGERS FROM test
dd1:编写 gearman 的 worker 端
nohup PHP worker.PHP &>/dev/null & (后台运行)
测试:
更新 MysqL 中的数据
MysqL> update test set name='test1' where id=1
MysqL> update test set name='dangdang' where id=1
Varnish:高速http缓存:
dd1:
varnish-3.0.5-1.el6.x86_64.rpm varnish-libs-3.0.5-1.el6.x86_64.rpm
rpm –ivh
vim /etc/sysconfig/varnish
cd /etc/varnish/
vim default.vcl
/etc/init.d/varnish start
dd3:/etc/init.d/httpd start
### 通过 varnishadm 手动清除缓存
# varnishadm ban.url .*$
#清除所有
# varnishadm ban.url /index.html
#清除 index.html 页面缓存
# varnishadm ban.url /admin/$
#清除 admin 目录缓存
vim default.vcl
###查看缓存命中情况
sub vcl_deliver {
if (obj.hits > 0) {
set resp.http.X-Cache = "HIT from westos cache";
}
else {
set resp.http.X-Cache = "MISS from westos cache";
}
return (deliver);
}
测试缓存命中:
定义多个不同域名站点的后端服务器:
backend default {
.host = "172.25.42.12";
.port = "80";
}
backend web {
.host = "172.25.42.11";
.port = "80";
}
sub vcl_recv {
if (req.http.host ~ "^(www.)?dd.org") {
set req.http.host = "www.dd.org";
set req.backend = default;
} elsif (req.http.host ~ "^bbs.dd.org") {
set req.backend = web;
} else {error 404 "westos cache";
}
测试:www.dd.org 和 dd.org 是同一个缓存
而bbs.dd.org是一个缓存
#当访问 www.dd.org 域名时从 default 上取数据,访问 bbs.dd.org 域名时到web 取数据,访问其他页面报错 //注意:测试主机加解析
负载均衡:(域名负载均衡)
访问www.dd.org 时 两台主机响应它
避免再开一台虚拟机 给dd2 做虚拟主机(一个ip 多个域名)
dd1:
vim default.vcl
director lb round-robin {
{.backend = default;}
{.backend = web;}
}
sub vcl_recv {
if (req.http.host ~ "^(www.)?dd.org") {
set req.http.host = "www.dd.org";
set req.backend = lb;
return (pass); (测试用)
} elsif (req.http.host ~ "^bbs.dd.org") {
set req.backend = web;
} else {error 404 "westos cache";
}
}
varnish cdn 推送平台 (清空缓存)
#需要安装 PHP 支持
# unzip bansys.zip -d /var/www/html
# vi /var/www/html/bansys/config.PHP
#只保留如下设置,其余注释掉
<?PHP
$var_group1 = array(
'host' => array('172.25.42.10'),
'port' => '80',
);
//varnish 群组定义
//对主机列表进行绑定
$VAR_CLUSTER = array(
'www.dd.org' => $var_group1,
);
vim /etc/varnish/default.vcl
/etc/init.d/varnish reload
测试:
如果大家还有什么地方需要了解的可以在编程之家官网找我们的CDN技术工程师的,编程之家CDN技术工程师在行业内拥有十几年的经验了,所以会比小编回答的更加详细专业。编程之家官网链接www.jb51.cc