1、用c#net做的,速度优化后的网站,该怎么解决
大部分不用优化性能已经很优秀了,毕竟不是脚本语言能比的性能。
大公司要优化不花月薪三到十万请架构师,到这里发帖?
给 5000rmb 可以考虑下
2、ASP.NET网站性能优化 需要考虑哪些方面
比如 1 数据库,数据量大,比如建立索引等等,优化数据库
2 有图片的页面,把图片压缩
3 尽量少用服务器控件,服务器控件要编译成html控件,导致速度不如纯html控件
4 代码,减少冗余的代码,减少重复性的代码,包括查询数据语句等等,可使用存储过程
5 分布式部署等等
还有很多,包括服务器的好坏呀等等
3、asp.net有些网站有后台seo优化功能,那是怎么实现的?需要对每个页面都修改关键字等等吗?
那个是要在开发的时候就考虑进去的,要实现相应的功能必须要有相关的程序支持。比如有中国博客网就支持这个功能,每篇文章都可以重定义标题、关键词。描述等seo设置
4、如何做ASP.NET网站的SEO优化提高推广力度?
你是需要推广关键词排名吗?我们找一款软件来推广我们公司网站的,
做百度竞价的费用投资成本大,很多人都是用SEO软件优化上首页的,
我在网上找了几款软件,对比了一下,觉得有款叫旺道的优化软件效果不错的,
经过几天深思熟虑,详细了解了一下旺道软件的功能后,购买他们一款软件
开通了他们的SEO排名功能,他们安排了技术教我怎么操作,经过了一个月的时间
网站关键词都排名第一页,而且很稳定的。你可以详细的了解下,或许可以对你有益。
5、asp.net网站源代码怎么优化
1.尽量的精简代码,删除无用的代码和样式,特别是首页代码不能太多,否则影响加载速度,对搜索引擎而言是极不友好的;
2.代码中尽量不要使用flash、js,禁止使用框架;
3.网页地址尽量静态化,少使用动态化网址。
代码可以优化的地方基本上就是这些,其它SEO方面需要SEO的专员去做。
6、asp.net wepapi发布到iis上,当访问量大时请求变得很慢很卡,有什么好的解决办法?
应该是你添加网站时候不对右击左边的网站,添加网站,填入网站名称(随便填)专,应用程序池要设置一下属(可以试试ASP.NETv4.0),设置好物理路径,端口要改一下(比如8001),最后确定访问直接在浏览器上输Contact
7、哪些方面可以对asp.net进行性能优化
1、使用值类型的ToString方法
在连接字符串时,经常使用"+"号直接将数字添加到字符串中。这种方法虽然简单,也可以得到正确结果,但是由于涉及到不同的数据类型,数字需要通过装箱操作转化为引用类型才可以添加到字符串中。但是装箱操作对性能影响较大,因为在进行这类处理时,将在托管堆中分配一个新的对象,原有的值复制到新创建的对象中。
使用值类型的ToString方法可以避免装箱操作,从而提高应用程序性能。
int num=1;
string str="go"+num.ToString();
2、运用StringBuilder类
String类对象是不可改变的,对于String对象的重新赋值在本质上是重新创建了一个String对象并将新值赋予该对象,其方法ToString对性能的提高并非很显著。
在处理字符串时,最好使用StringBuilder类,其.NET 命名空间是System.Text。该类并非创建新的对象,而是通过Append,Remove,Insert等方法直接对字符串进行操作,通过ToString方法返回操作结果。
其定义及操作语句如下所示:
int num;
System.Text.StringBuilder str = new System.Text.StringBuilder(); //创建字符串
str.Append(num.ToString()); //添加数值num
Response.Write(str.ToString); //显示操作结果
3、使用 HttpServerUtility.Transfer 方法在同一应用程序的页面间重定向
采用 Server.Transfer 语法,在页面中使用该方法可避免不必要的客户端重定向(Response.Redirect)。
4、避免使用ArrayList。
因为任何对象添加到ArrayList都要封箱为System.Object类型,从ArrayList取出数据时,要拆箱回实际的类型。建议使用自定义的集合类型代替ArrayList。asp.net 2.0提供了一个新的类型,叫泛型,这是一个强类型,使用泛型集合就可以避免了封箱和拆箱的发生,提高了性能。
5、使用HashTale代替其他字典集合类型
(如StringDictionary,NameValueCollection,HybridCollection),存放少量数据的时候可以使用HashTable.
6、为字符串容器声明常量,不要直接把字符封装在双引号" "里面。
//避免
MyObject obj = new MyObject();
obj.Status = "ACTIVE";
//推荐
const string C_STATUS = "ACTIVE";
MyObject obj = new MyObject();
obj.Status = C_STATUS;
7、不要用ToUpper(),ToLower()转换字符串进行比较,用String.Compare代替,它可以忽略大小写进行比较.
例:
const string C_VALUE = "COMPARE";
if (String.Compare(sVariable, C_VALUE, true) == 0)
{
Console.Write( "相同");
}
也可以用str == String.Empty或者str.Length == 0判断是否为空。(注意判断输入数据的长度,可防止sql注入式攻击)
将String对象的Length属性与0比较是最快的方法,避免不必要的调用 ToUpper 或 ToLower 方法。
8、类型转化Int32.TryParse()优于Int32.Parse()优于Convert.ToInt32()。
建议.NET1.1下用Int32.Parse();.NET2.0用Int32.TryParse()。
因为:
Convert.ToInt32 会把最终的解析工作代理给 Int32.Parse;
Int32.Parse 会把最终的解析工作代理给Number.ParseInt32;
Int32.TryParse 会把最终的解析工作代理给Number.TryParseInt32。
9、如果只是从XML对象读取数据,用只读的XPathDocument代替XMLDocument,可以提高性能
//避免
XmlDocument xmld = new XmlDocument();
xmld.LoadXml(sXML);
txtName.Text = xmld.SelectSingleNode( "/packet/child").InnerText;
//推荐
XPathDocument xmldContext = new XPathDocument(new StringReader(oContext.Value));
XPathNavigator xnav = xmldContext.CreateNavigator();
XPathNodeIterator xpNodeIter = xnav.Select( "packet/child");
iCount = xpNodeIter.Count;
xpNodeIter = xnav.SelectDescendants(XPathNodeType.Element, false);
while(xpNodeIter.MoveNext())
{
sCurrValues += xpNodeIter.Current.Value+ ",";
}
8、ASP.NET如何进行性能优化问题
一、SqlDataRead和Dataset的选择
Sqldataread优点:读取数据非常快。如果对返回的数据不需做大量处理的情况下,建议使用SqlDataReader,其性能要比datset好很多。缺点:直到数据读完才可close掉于数据库的连接
(SqlDataReader 读数据是快速向前的。SqlDataReader 类提供了一种读取从 SQL Server 数据库检索的只进数据流的方法。它使用 SQL Server 的本机网络数据传输格式从数据库连接直接读取数据。DataReader需及时显式的close。可及时的释放对数据的连接。)
Dataset是把数据读出,缓存在内存中。缺点:对内存的占用较高。如果对返回的数据需做大量的处理用Dataset比较好些可以减少对数据库的连接操作。优点:只需连接一次就可close于数据库的连接
*一般情况下,读取大量数据,对返回数据不做大量处理用SqlDataReader.对返回数据大量处理用datset比较合适.对SqlDataReader和Dataset的选择取决于程序功能的实现。
二、ExecuteNonQuery和ExecuteScalar
对数据的更新不需要返回结果集,建议使用ExecuteNonQuery。由于不返回结果集可省掉网络数据传输。它仅仅返回受影响的行数。如果只需更新数据用ExecuteNonQuery性能的开销比较小。
ExecuteScalar它只返回结果集中第一行的第一列。使用 ExecuteScalar 方法从数据库中检索单个值(例如id号)。与使用 ExecuteReader 方法, 返回的数据执行生成单个值所需的操作相比,此操作需要的代码较少。
*只需更新数据用ExecuteNonQuery.单个值的查询使用ExecuteScalar数据绑定的选择
三、数据的绑定DataBinder
一般的绑定方法用DataBinder.eval 绑定不必关心数据来源(Dataread或dataset)。不必关心数据的类型eval会把这个数据对象转换为一个字符串。在底层绑定做了很多工作,使用了反射性能。正因为使用方便了,但却影响了数据性能。来看下。当于dataset绑定时,DataItem其实式一个DataRowView(如果绑定的是一个数据读取器(dataread)它就是一个IdataRecord。)因此直接转换成DataRowView的话,将会给性能带来很大提升。
*对数据的绑定建议使用。数据量大的时候可提高几百倍的速度。使用时注意2方面:1.需在页面添加.2.注意字段名的大小写(要特别注意)。如果和查询的不一致,在某些情况下会导致比还要慢。如果想进一步提高速度,可采用的方法。不过其可读性不高。
以上的是vb.net的写法。在c#中:<@% ((DataRowView)Container.DataItem)["字段名"] %>
对查看页面每个执行过程状态最简单的办法:其页面的trace属性为true就可查看细节。
一、使用存储过程:
1、性能方面:存储过程提供了许多标准sql语言中所没有的高级特性。其传递参数和执行逻辑表达式的功能,有助于应用程序设计者处理复杂任务。另外,存储过程存储在本地服务器上,减少了执行该过程所需的网络传输宽带和执行时间。(存储过程已经对sql语句进行了预编译,所以其执行速度比在程序里执行sql语句快很多)
2、程序结构方面:从程序的可扩展性看,使用存储过程会对程序以后的修改带来方便。比如数据库的结构改变了,只需修改相对应的存储结构,和程序中的调用部分即可。这部分不属于本文探讨范围,属于程序结构设计方面。所以不在此展开。
3、程序安全性:使用存储过程可避免SQL Injection攻击。
二、查询语句的优化(针对sql server2000)
很多人只为目的写出sql语句,而不考虑sql语句的执行效率。在这我只提供一优化表顺序的方法,(sql语句的优化和原则将会在我的sql server2000学习笔记中专题讨论)
对sql语句执行效率可用sql server2000的查询分析器来查看语句的执行过程。
优化表顺序:一般情况下,sqlserver 会对表的连接作出自动优化。例如:select name,no from A join B on A. id=B.id join C on C.id=A.id where name=’wang’
尽管A表在From中先列出,然后才是B,最后才是C。但sql server可能会首先使用c表。它的选择原则是相对于该查询限制为单行或少数几行,就可以减少在其他表中查找的总数据量。绝大多数情况下,sql server 会作出最优的选择,但如果你发觉某个复杂的联结查询速度比预计的要慢,就可以使用SET FORCEPLAN语句强制sql server按照表出现顺序使用表。如上例加上:SET FORCEPLAN ON…….SET FORCEPLAN OFF 表的执行顺序将会按照你所写的顺序执行。在查询分析器中查看2种执行效率,从而选择表的连接顺序。
*使用SET FORCEPLAN选择表联结顺序
三、页面的优化(.aspx)
主要针对几个页面属性
1、EnableViewState(页面的视图状态)。如果无特殊要求设置为false。使用ViewState ,每个对象都必须先序列化到 ViewState 中,然后再通过回传进行反序列化,因此使用 ViewState是没有代价的。尽量减少使用对象,如果可能,尽量减少放入 ViewState 中的对象的数目。下面情况基本上可以禁用viewstate:
(1)页面控件 (.ascx)
(2)页面不回传给自身。
(3)无需对控件的事件处理。
(4)控件没有动态的或数据绑定的属性值(或对于每个postpack都在代码中处理)
单个页面或每个页面都禁用 ViewState,如下所示:单个页面: 每个页面:在 web.config 中 EnableSessionState保持默认值即可(如果页面用到sessionstate它才会占用资源)。EnableViewStateMac如果无安全上的特殊要求,保持默认值。
2、Pagelayout.页面布局模型。建议使用Flowlayout(元素不带绝对定位属性添加).Gridlayout(绝对定位属性)由于采用绝对定位,将会比Flowlayout生产更多的代码,主要是控件的定位信息。
3、项目发布的时候切记解除页面的Debug状态。
4、Html语言的优化。我的建议是熟练掌握Html/javascript,少用vs.net2003自动生产的代码,它会自动生成一些无用的html代码。
5、smart navigation设置为true能让用户明显的感觉性能提高。启用此属性后对客户端和服务端影响不大.它能智能涮新需要涮新需涮新的部分.
四、控件的选择:
Html控件和服务器控件的选择。服务器控件带来的方便和功能上的实现是html控件所不能比拟的。但是是以牺牲服务器端的资源来取得的。我个人建议:如果html控件达不到所要实现的功能,而且和一些脚本语言(如javascrpt/vbscript)结合也不能实现的话。才会选择服务器控件。选择服务器控件后,也尽量对其控件优化,如取消一些页面状态等(具体看控件的优化)
服务器控件的选择:主要针对几个常用数据控件说明一下:
DataGrid:自带最强大的数据显示控件,内置了对数据的修改、删除、添加、分页等很多实用功能。如果你只需对数据显示的话,尽量不要选择DataGrid(它把数据都存储在viewstate中).也不要使用自带的分页功能,microsoft在自动分页的底层做了很多工作,虽然使用方便了,但性能开销大了。
DataList:比DataGrid功能少了很多。但自定义性强了很多。特有的多行数据显示,给我们带来了很多方便。DataGrid能实现的功能,它基本能实现。所以建议使用它。
Repeater:功能最少,但自定义性非常强。如果只需对数据显示,建议使用。由于减少了很多功能,对服务器的性能带来消耗最小。因此,如果是对数据显示的话,我基本上都是选择Repeater然后DataList最后DataGrid
*尽量选择html控件。能在客户端实现的功能就在客户端实现(熟练掌握javascript),减少服务器的压力。数据控件选择顺序:Repeater、DataList、DataGrid
五、服务器控件的优化:
1、Viewstate
控件的viewstate与页面的viewstate基本是一致的。用来保存控件的一些状态。处理原则和处理页面的viewstate一样。有兴趣的可以用Datagrid绑定数据测试下viewstate保存的数据量有多大,它所保存的数据基本和Datagrid显示的数据量大小是等同的。
2、Ispostpack
默认false.需要产生事件的时候才需设置为true.
控件的优化,主要看你对此控件的熟悉情况。对控件内部运作的原理越了解,就会对其作出合适的优化。
9、asp.net网页主要用table布局的话如何优化页面加载的速度?
不会有太大影响的。
你是企业内部用的,流量不会太大。所以不会有任何实质上的影响。
而且,TABLE 用得好,效果未必比 DIV 差。
你可以想像,在 W3C 标准流行以前,人们都使用TABLE ,不见得网站会很慢。
所以,标准只存在于人们自己的心目中。。。
就像 W3C认为 <strong> 比 <b> 更好一样。。。
TABLE 的问题,主要在于嵌套。你少嵌套几个表格就没有事情了。
一般不要超过三层以上就可以了。
另外,不要把所有内容都放在一个大表格里。应该适当的分开。
10、两个域名,.com .net都指向一个网站,对优化好吗?
分个主次,.com为主 .net为铺,com主要来优化,net只是备用而已,不必去优化。
从百度的SEO手册上来看,同一个网站,如果域名过多,对优化是有影响的。所以,一个网站,可以有多个备用的域名,但优化只集中力量优化一个。