通用大型网站页面静态化解决方案

大型网站架构技术系列收藏文章更新列表

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中,然后通过调度中心异步执行,可用我在博客中说道的另外一篇文章解决即可

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。