여기서 Duration 및 VaryByP"/> 여기서 Duration 및 VaryByP">

>백엔드 개발 >C#.Net 튜토리얼 >asp.net 페이지 캐싱 기술에 대한 간략한 분석

asp.net 페이지 캐싱 기술에 대한 간략한 분석

怪我咯
怪我咯원래의
2017-03-31 11:55:581305검색

저는 오랫동안 기술에 대해 더 많은 글을 쓰고 싶었습니다
첫째, 더 많은 지식을 쌓기 위해서입니다쿼리 물론 다들 곧 업데이트되겠죠. 하
잡담은 하지 마세요
오늘은 그냥 시간 좀 내서 정리해보겠습니다


페이지캐시
OutputCache 지시문 사용
<%@ OutputCache Duration="3600"
Location="Any"
VaryByCustom="browser"
VaryByParam="RequestID" %>
Duration 및 VaryByParam 속성이 필요합니다.

위치는 페이지 캐시의 위치를 ​​제어합니다

<.tbody>이 페이지에 대해 출력 캐싱이 비활성화되었음을 나타냅니다.
위치
Location
含义
Any
默认值。意味着页面的输出可以缓存在客户端浏览器,缓存在任何“下游”的客户端(如代理服务器),或缓存在Web服务器本身
Client
指明输出缓存只能存储在发出请求的客户端(即浏览器)的本地缓存中
Downstream
指明输出缓存能存储在任何支持HTTP1.1缓存的设备(如代理服务器)中
Server
指明输出缓存将存储在Web服务器上
None
指明该页面禁用输出缓存
의미
모두 기본값은 페이지 출력이 클라이언트 브라우저에 캐시되거나, 모든 "다운스트림" 클라이언트(예: 프록시 서버)에 캐시되거나, 웹 서버 자체에 캐시될 수 있음을 의미합니다.
클라이언트 출력 캐시가 요청 클라이언트(예: 브라우저)의 로컬 캐시에만 저장될 수 있음을 지정합니다.
다운스트림 HTTP1.1 캐싱을 지원하는 모든 장치(예: 프록시 서버)에 출력 캐시를 저장할 수 있음을 지정합니다.
서버 출력 캐시가 웹 서버에 저장되도록 지정합니다
없음


기간을 사용하면 페이지가 캐시에 있는 기간(초)을 제어할 수 있습니다.

VaryByParam을 사용하면 페이지의 다양한 버전을 캐시할 수 있습니다. 위 예에서 VaryByParam은 RequestID로 설정되어 있으므로 ASP.NET은 HTTP GET 쿼리 문자열 에 전달되는 RequestID 매개변수의 다른 값을 사용합니다. 또는 HTTP POST의 매개변수로 전달됩니다. 페이지의 OutputCache 지시문에 VaryByParam="RequestID"를 배치하여 RequestID 매개 변수 값을 확인하여 응용 프로그램이 여러 사용자를 구별하도록 할 수 있으며 ASP.NET에서 각 사용자에 대해 페이지의 다른 버전을 캐시하도록 할 수 있습니다.
매개변수 값에 따라 페이지의 독립적인 버전을 캐시하지 않으려면 VaryByParam을 없음으로 설정하세요.
또한 가능한 각 매개변수 배열 조합에 대한 페이지 버전을 캐시하도록 ASP.NET에 요청할 수도 있습니다. 이렇게 하려면 VaryByParam을 *로 설정합니다.

VaryByHeader 및 VaryByCustom 속성은 페이지의 새 캐시 버전을 생성해야 하는 시기를 지정할 수 있다는 점에서 VaryByParam과 유사합니다.
VaryByHeader를 사용하면 세미콜론으로 구분된 HTTP 헤더 목록을 기반으로 페이지의 방향이 지정되지 않은 버전을 캐시할 수 있습니다.
VaryByCustom을 브라우저로 설정하면 브라우저 이름과 주요 버전 정보를 기반으로 다양한 버전을 캐시할 수 있습니다. 또한 이를 사용자 정의 메소드의 이름으로 설정하여 자체 로직을 구현하고 캐시된 버전을 제어할 수도 있습니다.

조각 캐시
는 사용자 control을 사용하여 페이지를 분할하고 aspx 파일에 캐시된 문을 작성하는 대신 ascx 파일에 캐시된 문을 작성할 수 있으므로 ASP.NET은 ascx 조각의 출력만 캐시할 수 있습니다. 일반적으로 머리글이나 바닥글이 기본적으로 동일하다면 다시 로드할 필요가 없습니다. 그러나 동적으로 변경되는 데이터가 있는 경우 캐시할 수 없습니다. 일단 캐시되면 프로그램은 데이터 표시를 업데이트하기 위해 해당 인스턴스를 생성하지 않으므로 수명이 만료될 때까지만 기다릴 수 있습니다. 이 상황은 페이지 조각 캐싱에 적합하지 않습니다.
참고:
1. 조각 캐싱은 위치 기능을 지원하지 않으며 페이지 조각을 캐시할 수 있는 유일한 합법적인 장소는 웹 서버입니다. 이는 조각 캐싱이 ASP.NET의 새로운 기능이므로 브라우저와 프록시 서버가 이를 지원하지 않기 때문입니다.
2. 조각 캐시에는 페이지 캐시에는 없는 또 다른 기능인 VaryByControl이 있습니다. VaryByControl 특성을 사용하면 사용자 컨트롤 내에서 사용되는 컨트롤의 이름을 나타내는 세미콜론으로 구분된 문자열 목록을 지정할 수 있습니다. ASP.NET은 각각의 다양한 값 조합에 대해 캐시된 버전의 사용자 위젯을 생성합니다.

데이터 캐시
저수준 API는 Cache 클래스로, System.web.Caching네임스페이스에 있습니다. ASP.NET을 사용하여 리소스 집약적인 데이터를 캐시할 수 있습니다. Cache 클래스의 사용은 Session 및 Application 객체만큼 간단합니다. 애플리케이션당 하나의 Cache 개체만 있습니다. 즉, Cache 개체를 사용하여 캐시에 저장된 데이터는 애플리케이션 수준 데이터입니다. 작업을 더욱 간단하게 만들기 위해 Page 클래스의 Cache속성을 사용하면 응용 프로그램의 Cache 개체 인스턴스를 코드에서 사용할 수 있습니다.
Cache 객체를 통해 캐시된 데이터는 애플리케이션의 메모리에 저장됩니다. 이는 이 데이터의 수명이 애플리케이션 재시작을 초과하지 않는다는 것을 의미합니다(실제로 이는 StateService 또는 SQL 상태 세션 모드를 사용하여 세션 데이터를 저장하지 않는 한 애플리케이션 및 세션 개체에 저장된 데이터와 동일합니다).
구체적인 사용법과 구문은 Session 및 Application과 동일합니다. 다시 변환할 때에는 해당 타입의 강제 타입 변환에 주의해야 합니다.

이것이 ASP.NET 캐시에 캐시 항목을 추가하는 유일한 방법은 아닙니다. Cache 개체에는 더 유연한 Insert() 메서드와 Add() 메서드라는 두 가지 메서드가 있습니다. 사용법은 비슷하지만 약간 다릅니다.
Insert() 메서드는 ASP.NET 캐시의 기존 캐시 항목을 덮어쓰는 데 사용됩니다.
Add() 메서드는 ASP.NET 캐시에 새 캐시 항목을 추가하는 데만 사용됩니다(기존 캐시 항목을 덮어쓰는 데 사용하면 실패합니다).
각 메소드에는 7개의 매개변수가 있으며, 두 메소드의 매개변수는 동일합니다.
항목을 캐싱할 때 관련성을 지정하여 캐시된 항목이 특정 이벤트가 발생할 때까지 캐시에 남아 있음을 ASP.NET에 알릴 수 있습니다.

相关性值
含义
CacheDependency
允许指定一个文件或缓存键。如果文件发生变化,对象就被删除。如果缓存键发生变化,对象也被删除。
DateTime
这是一个DataTime值,指明缓存数据过期的时间(绝对过期时间)
TimeSpan
这是一个时间间隔,指明缓存数据在上一次访问后可以在缓存中保留多长时间(弹性过期时间)

캐시가 가득 차면 우선순위가 낮은 데이터가 삭제될 수 있도록 CacheItemPriority를 ​​사용하여 캐시된 데이터의 우선순위를 지정하세요.

tr>으로 설정된 캐시 항목 이전에만 유지됩니다.
우선순위 값
优先级值
含义
High
设为此优先级的缓存项是最不可能在内存不足时被删除的
AboveNormal
设为此优先级的缓存项比优先级为Normal或以下的缓存项更优先保留
Normal
设为此优先级的缓存项比优先级为BelowNormal和Low的缓存项更优先保留
BelowNormal
这是倒数第二级的优先级;设为此优先级的缓存项只比优先级设为Low的缓存项更优先保留
Low
设为此优先级的缓存项是最有可能在内存不足时被删除的
Default
缓存项的优先级的默认值是Normal
NotRemovable
当缓存项设为此优先级时,是在告诉ASP.NET即使是内存不足,也不要从缓存中删除它
의미

높음
이 우선순위로 설정된 캐시 항목은 메모리가 부족할 때 삭제될 가능성이 가장 낮습니다
AboveNormal
이 우선순위로 설정된 캐시 항목은 우선순위가 보통 이하인 캐시 항목보다 우선순위가 높습니다.
보통
이 우선순위로 설정된 캐시 항목은 우선순위가 BelowNormal 및 Low
BelowNormal
인 캐시 항목보다 먼저 유지됩니다. 이는 두 번째 우선순위 수준입니다. 이 우선순위로 설정된 캐시 항목은 낮은 우선순위
낮음
이 우선순위로 설정된 캐시 항목은 메모리가 부족할 때 삭제될 가능성이 가장 높은 항목입니다.
기본값
기본값 캐시 항목 우선 순위 값은 Normal
NotRemovable
캐시 항목이 이 우선 순위로 설정되면 ASP에 알리는 것입니다. NET에서는 메모리가 부족해도 캐시에서 삭제하지 않도록 합니다

DateTime dt = new DateTime(DateTime.Now.Year,12, 31);
Cache.Add("MembersDataSet",dsMembers,null,
dt,TimeSpan.Zero,
CacheItemPriority.Normal,null);
첫 번째 매개변수는 캐시를 참조하는 키입니다. 객체이고, 두 번째 매개변수는 캐시할 객체입니다. 세 번째 매개변수는 null입니다(상관관계가 없음을 나타냄).
네 번째와 다섯 번째 매개변수는 절대 만료 시간과 유연한 만료 시간입니다. 여기서는 캐시가 올해 마지막 날(dt)에 만료되도록 지정합니다. 유연하지 않은 만료 시간을 지정하려고 하므로 다섯 번째 매개 변수에 TimeSpan.Zero를 사용합니다. 여섯 번째 매개 변수는 System.Web.Caching.CacheItemPriority 열거형의 값을 사용하여 우선 순위를 Normal로 설정합니다.

5분의 유연한 만료 시간 지정, 절대 만료 시간은 지정되지 않음
Cache.Add("MembersDataSet",dsMembers,null,
DateTime.MaxValue,TimeSpan.FromMinutes(5),
CacheItemPriority.Normal,null);

상관 관계를 추가합니다. 이 예에서 만료 시간은 test.xml 파일의 수정에 따라 달라집니다.
CacheDependency dep = new CacheDependency(@"C:/test.xml");
Cache.Add(" MembersDataSet ",dsMembers,dep,
DateTime.MaxValue,TimeSpan.FromMinutes(5),
CacheItemPriority.Normal,null);

만료 시간은 캐시의 다른 항목 수정에 따라 달라집니다. :
String[] dependencyKeys = new String[1];
dependentKeys[0] = "MembersChanged";
CacheDependency dependency = new CacheDependency(null, dependencyKeys);Cache.Add("MembersDataSet ",dsMembers ,dependent,
DateTime.MaxValue,TimeSpan.Zero,
CacheItemPriority.Normal,null);

위 내용은 asp.net 페이지 캐싱 기술에 대한 간략한 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.