首先,要先建立一个模型,建立模型的方法寂寞天涯 已经写过专门的教程,不过要注意的是建立模型之后要新建一个字段,名字是:文章正文,英文名是:body,要选择html文本存储模式。固定发布模式。这 样你就可以看到多了两个数据表,一个是dede_archivesxx,一个是dede_addonxx,可以自己取名。我们主要的操作在这两个表上进行。
然后开始我们的主要操作:后台系统管理-系统帐号管理-sql命令运行器
看到下面的运行小窗口了吧,我们在这里运行sql的命令。
主要命令步骤如下:
一、insert into dede_addonx select * from dede_addonarticle where typeid=y
这个dede_addonx就是刚刚我们建立的两个数据库中的一个,是一个附表。
这句话的意思是我们把dede_addonarticle(原来的大表)中的某一个档目(文章栏目数字号y)中的所有数据复制到dede_addonx这个表里。
二、insert into dede_archivesx select * from dede_archives where typeid=y
这个dede_archivesx是我们刚刚建立模型中的主索引表,这句话的意思和上句一样。
三、update `dede_full_search` set `channelid` = 'x' where `dede_full_search`.`typeid` =y
将两个表复制完之后我,我们需要把我们dede数据的主索引表进行较正。
四、update `dede_archivesx` set `channel` =x where `typeid` =y
再将我们的文章模型索引表进行较正
五、delete from dede_addonarticle where typeid=y
将原来已经复制过的数据在原表删除。
第六步、频道管理,相关档目修改-基本设置
内容模型选定刚刚建立的那个模型,然后点高级设置,要设定相对应的模板。然后最下面的继承选项,选定之后整个栏目都会按这个设置顺承。
最后,大功告成,大家可以看看里面的档案了,如果能显示,说明你成功了。
这个操作主要应用于文章模型,其它模型还没有实验,不过大同小异,应该可以实现。
打个比方,这就相当于,把一个大水库分成若干个小水库,然后通知接水的人,去小水库接水。这就是dedecms的分表。
30万条2gb数据网站平台生成html网页每分钟超过1000张
使用dedecms一年多时间,看了论坛上很多站长在抱怨dedecms系统生成html速度慢,其实不然,只要恰当对服务器平台和数据库进行优化,生成速度会有质得提升。
下面我提供一组数据,大家对比一下你网站的数据量和生成速度,能不能有提升的空间。可能有部分站长优化得比我好得多,我只在这里献丑了!
并且提供优化的方法,可能这些方法是官方为商业客户服务的,大家有能力的话可以自己试着做一下。
本人负责建设的网站现有780-1000的并发连接(实时查看网址:)网站数据库有30多万条,内容大概有六个模型,六个内容表数据量比较大,全部合起来有3gb,在给其中一个有5万多条的栏目生成网页时每分钟超过1000张的速度。
大家分析一下上面三张图的数据,dedecms的潜力还是可以挖掘的。
硬件的基本情况,不算特别好,ibm服务器:cpu 四核至强,内存2gb,数据库安装在146gb的sas硬盘上,站点文件存放在500gb的sata硬盘中。
现在我简单描述一下优化措施。
一、安装 centos 5.2,装最基本的组织,mysql,php,apache都不要安装,以后自己下载源码编译安装。
安装完成后运行setup配置系统服务命令,设置以下仅列出需要启动的服务,未列出的服务一律关闭:
crond
irqbalance 仅当服务器cpu为s.m.p架构或支持双核心、ht技术时,才需开启,否则关闭。
microcode_ctl
network
iptables
vsftpd
sshd
syslog
yum-updatesd
二、搭建胜过apache十倍的高并发web服务器 nginx php(fastcgi)
具体配置不再描述,大家参考张宴的文章 http://blog.s135.com/nginx_php_v5/
提供我的配置截图
三、安装编译 mysql数据时编译参数设置注意三点
1. -static 13%
--with-client-ldflags=-all-static
--with-mysqld-ldflags=-all-static
静态链接提高13%性能
2. unix socket 7.5%
--with-unix-socket-path=/tmp/mysql.sock
使用unix套接字链接提高7.5%性能,所以在windows下mysql性能肯定不如unix下面
3. --enable-assembler
允许使用汇编模式(优化性能)
四、优化dedecms数据表索引。官方的默认索引不是最优化的,可能dede官方有所保留。
大家下载一个叫 navicat for mysql 的客户端软件连接到mysql server数据上进行管理操作。
个人认为:凡是要排序的字段(比如文档主表的 sortrank、senddate、pubdate、click、goodpost、badpost)和查询条件的字段(比如:typeid,ismake)以及文档id都要建立索引,如果有一个没有建立,将严重影响mysql运行效率,导致生成html时速度慢。
当系统启用了审核机制以后,标识文档审核属性的字段ismake必须建立索引。
注意:click这个字段,记录文档点击量,此字段值更新频繁,建立索引后对系统维护索引带来一定的负荷,大家自己权衡。有人说频繁更新的字段建立索引会容易导致数据库损坏,这个我还没有遇到过,需要考证。
下面是主表索引建立的截图