标签:
大型网站架构技术系列收藏文章更新列表
http://www.cnblogs.com/ruthon/p/4477899.html
多个文件服务器读写,这里可采用SMB协议
页面静态化,可采用freemarker开源框架
如果考虑到大量的读写请求,则将请求分布式或采用调度的办法来解决
第一点我们首先应该考虑文件服务器与静态页面的映射关系,即什么文件应该读写到哪台服务器,这个关系最简单的办法是随机映射,然后将映射关系保存到数据库中即可,SMB常用的操作代码如下:
public static boolean exists(String filepath,String username,String pwd) throws Exception { SmbFile file = new SmbFile("smb://"+username+":"+pwd+"@"+filepath); try{ return file.exists(); }catch(Exception ex){ return false; } } public static boolean fileRename(String filepath,String newFilename,String username,String pwd) { try{ SmbFile f=new SmbFile("smb://"+username+":"+pwd+"@"+filepath); if(f.isFile()){ String str=filepath.substring(0,filepath.lastIndexOf("/")); str="smb://"+username+":"+pwd+"@"+str+"/"+newFilename; f.renameTo(new SmbFile(str)); }else if(f.isDirectory()){ String str=filepath.substring(0,filepath.length()-1); str=filepath.substring(0,str.lastIndexOf("/")); str="smb://"+username+":"+pwd+"@"+str+"/"+newFilename; f.renameTo(new SmbFile(str)); } return true; }catch(Exception ex){ return false; } } public static void mkdir(String dir,String username,String pwd) { try{ SmbFile f=new SmbFile("smb://"+username+":"+pwd+"@"+dir); if(!f.exists()) f.mkdir(); }catch(Exception ex) { } } public static void mkfile(String filepath,String username,String pwd) { try { SmbFile f=new SmbFile("smb://"+username+":"+pwd+"@"+filepath); if(!f.exists()) f.createNewFile(); }catch(Exception ex) { } } public static void mkfile(String filepath,String username,String pwd,String content) { try { SmbFile f=new SmbFile("smb://"+username+":"+pwd+"@"+filepath); if(!f.exists()) f.createNewFile(); writeFile(filepath,content,username,pwd); }catch(Exception ex) { } } public static boolean isdir(String filepath,String username,String pwd) throws Exception { String dir="smb://"+username+":"+pwd+"@"+filepath; SmbFile f=new SmbFile(dir); return f.isDirectory(); }
第二点,页面静态化可由freemarker生成,freemarker的使用比较简单,我这里不再啰嗦,重复说了
第三点,调度中心,或把静态化的请求先保存到Task中,然后通过调度中心异步执行,可用我在博客中说道的另外一篇文章解决即可
标签:
原文地址:http://www.cnblogs.com/ruthon/p/4478179.html