因为手里的一个程序员论坛(http://bbs.it-home.org/) 经常出现IO问题,所以有了迁移discuz图片的想法
discuz附件图片迁移阿里云OSS,该方法也适用于七牛、又拍云
该方法是用discuz官方提供的扩展接口来实现的
DiscuzX使用云存储原理:
通过改造ftp类,当附件上传到本地时再通过ftp类将附件上传到云存储上。
下面使用阿里云存储做discuz远程附件的操作步骤:
1、确认您使用的discuz版本;
2. 开通云存储,新建bucket(公共读),这个步骤就不多说了,完全傻瓜式操作;
3、备份 source/class/class_core.php 和 config/config_global.php 两个文件;
4、根据您的discuz论坛版本下载对应的 DISCUZX2.5/X3扩展框架DXEXTEND(下载:http://www.discuz.net/thread-3334048-1-1.html
)另外,x3.1适用于x3.2,将解压出来的
source/class/class_core.php覆盖
discuz目录下该文件;
5、下载DISCUZX2.5/3/3.1云存储通用接口(下载:http://www.discuz.net/thread-3399569-1-1.html)将extend目录文件上传到discuz的根目录,如有提示覆盖即可;
6、在config/config_global.php 中新增以下内容:
$_config['extend']['storage']['curstorage'] = 'aliyun';//云接口,一旦确认,不可再改
$_config['extend']['storage']['aliyun']['access_id'] = 'xxx'; //你的Access Key ID
$_config['extend']['storage']['aliyun']['access_key'] = 'xxx'; //你的Access Key Secret
$_config['extend']['storage']['aliyun']['access_host'] = NULL;//默认即可
$_config['extend']['storage']['aliyun']['bucket'] = 'ithome';//你的bucket名字
$_config['extend']['storage']['aliyun']['attachurl'] = 'http://img.it-home.org';//访问域名,可以在oss后台设置自定义域名
7、在discuz 后台--全局--上传设置--远程附件--启用远程附件:是,并将 远程访问 URL 设置为 http://<YOUR QINIU DOMAIN>也就是6中的[font='Microsoft Yahei', '冬青黑体简体中文 w3', 宋体]attachurl,其他的都不用修改。
这样就修改完成了,去论坛上传附件发帖试试吧,再看看你的附件地址是不是已经是云存储的地址了
上面只是把我们新的图片上传到我们的云存储,但我们之前的图片怎么办呢?接着继续说明 discuz本地图片附件搬家迁移阿里云oss
1. 上传data/attachment下面的文件夹到你自己阿里云oss的bucket目录下(可以临时升级一下阿里云的带宽为10M也就几块钱一天,把源程序下面的图片下载下来)
2.完成步骤1操作后需要转换数据库的本地附件的数据为远程附件数据
涉及到的数据库表:
pre_forum_attachment
pre_home_pic
pre_portal_article_title
pre_portal_attachment
pre_portal_topic_pic
update pre_forum_attachment_0 set remote = '1';
update pre_forum_attachment_1 set remote = '1';
update pre_forum_attachment_2 set remote = '1';
update pre_forum_attachment_3 set remote = '1';
update pre_forum_attachment_4 set remote = '1';
update pre_forum_attachment_5 set remote = '1';
update pre_forum_attachment_6 set remote = '1';
update pre_forum_attachment_7 set remote = '1';
update pre_forum_attachment_8 set remote = '1';
update pre_forum_attachment_9 set remote = '1';
update pre_portal_article_title set remote=1;
update pre_portal_attachment set remote=1;
update pre_portal_topic_pic set remote=1;
update pre_home_pic set remote=remote+1;
UPDATE `pre_forum_post` SET `message` = replace(message, 'data/attachment', 'http://img.bcxue.com/data/attachment') WHERE `message` LIKE '%data/attachment/%';
UPDATE `pre_portal_article_content` SET `content` = replace(content, 'data/attachment', 'http://img.it-home.org') WHERE `content` LIKE '%data/attachment/%';
-------------------------
-------------------------
-------------------------
-------------------------
-------------------------
-------------------------
-------------------------
-------------------------
-------------------------
-------------------------
-------------------------
-------------------------
-------------------------
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。