JavaScriptSerializer.MaxJsonLength PropertyGets or sets the maximum length of JSON strings that are accepted by the JavaScriptSerializer class. Assembly: System.Web.Extensions (in System.Web.Extensions.dll)
The value of the MaxJsonLength property applies only when you explicitly create an instance of the JavaScriptSerializer class. Use the jsonSerialization element of the configuration file to set the maximum length for the internal serializer instance that is used by the asynchronous communication layer. For more information about the configuration elements for serialization, see How to: Configure ASP.NET Services in Microsoft Ajax. Windows 7, Windows Vista SP1 or later, Windows XP SP3, Windows Server 2008 (Server Core Role not supported), Windows Server 2008 R2 (Server Core Role not supported), Windows Server 2003 SP2 The .NET Framework does not support all versions of every platform. For a list of the supported versions, see .NET Framework System Requirements. |
'Study/MSDN'에 해당되는 글 10건
- 2011.07.08 JavaScriptSerializer.MaxJsonLength Property
- 2011.07.08 Mapping CLR Parameter Data
- 2011.07.08 Internet Information Services (IIS) 7.5 for Developers
- 2011.07.08 ASP.NET MVC 응용 프로그램 배포
- 2011.07.08 HttpPostedFile Class
- 2008.03.04 Internal Coding Guidelines
- 2008.02.20 기본 XML Web Services
- 2008.02.20 서버 측 비동기 웹 메소드
- 2008.02.16 [MSDN Magazine] Visual Studio와 Subversion의 통합
- 2008.02.14 .NET Framework 기술별 설명서
출처 : http://msdn.microsoft.com/en-us/library/ms131092.aspx
Mapping CLR Parameter DataThe following table lists Microsoft SQL Server data types, their equivalents in the common language runtime (CLR) for SQL Server in the System.Data.SqlTypes namespace, and their native CLR equivalents in the Microsoft .NET Framework.
A CLR method can return information to the calling code or program by marking an input parameter with the out modifier (Microsoft Visual C#) or <Out()> ByRef (Microsoft Visual Basic) If the input parameter is a CLR data type in the System.Data.SqlTypes namespace, and the calling program specifies its equivalent SQL Server data type as the input parameter, a type conversion occurs automatically when the CLR method returns the data type. For example, the following CLR stored procedure has an input parameter of SqlInt32 CLR data type that is marked with out (C#) or <Out()> ByRef (Visual Basic): <Microsoft.SqlServer.Server.SqlProcedure> _ Public Shared Sub PriceSum( <Out()> ByRef value As SqlInt32) … End Sub After the assembly is built and created in the database, the stored procedure is created in SQL Server with the following Transact-SQL, which specifies a SQL Server data type of int as an OUTPUT parameter: CREATE PROCEDURE PriceSum (@sum int OUTPUT) AS EXTERNAL NAME TestStoredProc.StoredProcedures.PriceSum When the CLR stored procedure is called, the SqlInt32 data type is automatically converted to an int data type, and returned to the calling program. Not all CLR data types can be automatically converted to their equivalent SQL Server data types through an out parameter, however. The following table lists these exceptions.
|
Internal Coding Guidelines
Table of Contents
1. Introduction.......................................................................................................................................... 1
2. Style Guidelines.................................................................................................................................... 2
2.1 Tabs & Indenting................................................................................................................................ 2
2.2 Bracing............................................................................................................................................... 2
2.3 Commenting........................................................................................................................................ 2
2.3.1 Documentation Comments............................................................................................................. 2
2.3.2 Comment Style............................................................................................................................. 3
2.4 Spacing............................................................................................................................................... 3
2.5 Naming............................................................................................................................................... 4
2.6 Naming Conventions............................................................................................................................ 4
2.6.1 Interop Classes............................................................................................................................. 4
2.7 File Organization................................................................................................................................. 5
1. Introduction
First, read the .NET Framework Design Guidelines. Almost all naming conventions, casing rules, etc., are spelled out in this document. Unlike the Design Guidelines document, you should treat this document as a set of suggested guidelines. These generally do not effect the customer view so they are not required.
2. Style Guidelines
2.1 Tabs & Indenting
Tab characters (\0x09) should not be used in code. All indentation should be done with 4 space characters.
2.2 Bracing
Open braces should always be at the beginning of the line after the statement that begins the block. Contents of the brace should be indented by 4 spaces. For example:
if (someExpression)
{
DoSomething();
}
else
{
DoSomethingElse();
}
“case” statements should be indented from the switch statement like this:
switch (someExpression)
{
case 0:
DoSomething();
break;
case 1:
DoSomethingElse();
break;
case 2:
{
int n = 1;
DoAnotherThing(n);
}
break;
}
Braces should never be considered optional. Even for single statement blocks, you should always use braces. This increases code readability and maintainability.
for (int i=0; i<100; i++) { DoSomething(i); }
2.3 Single line statements
Single line statements can have braces that begin and end on the same line.
public class Foo
{
int bar;
public int Bar
{
get { return bar; }
set { bar = value; }
}
}
It is suggested that all control structures (if, while, for, etc.) use braces, but it is not required.
2.4 Commenting
Comments should be used to describe intention, algorithmic overview, and/or logical flow. It would be ideal, if from reading the comments alone, someone other than the author could understand a function’s intended behavior and general operation. While there are no minimum comment requirements and certainly some very small routines need no commenting at all, it is hoped that most routines will have comments reflecting the programmer’s intent and approach.
2.4.1 Copyright notice
Each file should start with a copyright notice. To avoid errors in doc comment builds, you don’t want to use triple-slash doc comments, but using XML makes the comments easy to replace in the future. Final text will vary by product (you should contact legal for the exact text), but should be similar to:
//-----------------------------------------------------------------------
// <copyright file="ContainerControl.cs" company="Microsoft">
// Copyright (c) Microsoft Corporation. All rights reserved.
// </copyright>
//-----------------------------------------------------------------------
2.4.2 Documentation Comments
All methods should use XML doc comments. For internal dev comments, the <devdoc> tag should be used.
public class Foo
{
/// <summary>Public stuff about the method</summary>
/// <param name=”bar”>What a neat parameter!</param>
/// <devdoc>Cool internal stuff!</devdoc>
///
public void MyMethod(int bar) { … }
}
However, it is common that you would want to move the XML documentation to an external file – for that, use the <include> tag.
public class Foo
{
/// <include file='doc\Foo.uex' path='docs/doc[@for="Foo.MyMethod"]/*' />
///
public void MyMethod(int bar) { … }
출처 : http://blogs.msdn.com/brada/articles/361363.aspx
Roger Wolter
Microsoft Corporation
요약: 이 기사는 SOAP, WSDL, UDDI 소개 및 개발자용 XML Web services 값의 개요를 설명합니다(6페이지/인쇄 페이지 기준).
목차
XML Web Service
XML Web services는 인터넷상에서 분산된 컴퓨팅으로 이동하는 데 기본이 되는 빌딩 블록입니다. 열린 표준과 통신 중심, 작업자 및 응용 프로그램간의 공동 작업으로 응용 프로그램을 통합하는 데 XML Web services가 플랫폼이 되는 환경을 만들었습니다. 응용 프로그램은 위치나 구현 방법과 상관없이 함께 작동하는 다양한 소스의 여러 XML Web services를 사용하여 구성됩니다.
XML Web Service를 만드는 회사가 많은 만큼 XML Web Service의 정의도 다양하겠지만 모든 정의에는 다음과 같은 공통점이 있습니다.
- XML Web Services는 표준 웹 프로토콜을 통해 웹 사용자들에게 유용한 기능을 표시합니다. 대부분의 경우 SOAP 프로토콜이 사용됩니다.
- XML Web services는 사용자와 대화할 수 있는 클라이언트 응용 프로그램을 만들 수 있는 인터페이스를 세부적으로 설명하는 방법을 제공합니다. 일반적으로 이 설명은 Web Services 설명 언어(WSDL) 문서라고 하는 XML 문서에 제공됩니다.
- XML Web services는 잠재적인 사용자가 XML Web services를 쉽게 찾을 수 있도록 등록됩니다. XML Web services는 UDDI(Universal Discovery Description and Integration)에 등록됩니다.
본 기사에서 위의 세가지 기술을 모두 설명하겠지만 XML Web services에 주의를 기울여야 하는 이유를 먼저 설명하겠습니다.
XML Web services 아키텍처의 주요 장점 중 하나는 별도의 플랫폼에 별도의 언어로 작성된 프로그램들이 표준 기반으로 서로 통신할 수 있다는 점입니다. 이 점에 대해 산업 분야에 종사했던 사람들은 DEC 이전과 CORBA에서도 같은 내용이 있었기 때문에 차이점이 없을 것 같다는 의문이 생길 수 있습니다. 첫 번째 차이점은 SOAP가 이전의 접근 방법보다 훨씬 간단하여 표준 규격의 SOAP 구현을 입력하는 작업이 더욱 용이하다는 것입니다. Paul Kulchenko는 79항목이 포함된 마지막 카운트인 http://www.soapware.org/directory/4/implementations 에서 SOAP 구현 목록을 유지 관리합니다. SOAP 구현은 규모가 큰 소프트웨어 회사에서 찾을 수 있지만 개인 개발자가 작성하고 유지 관리하는 구현도 많이 찾을 수 있습니다. 이전에 비해 XML Web services가 갖는 또 다른 큰 장점은 표준 웹 프로토콜인 XML, HTTP 및 TCP/IP와 작동한다는 것입니다. 수 많은 회사들이 웹 인프라와 이를 유지 관리하는 지식과 경험이 있는 직원들을 갖추었기 때문에 XML Web services에 대한 항목에 소모되는 비용이 이전 기술에 비해 현저히 감소됩니다.
지금까지 WSDL 파일에 설명되고 UDDI에 등록된 XML Web service를 SOAP를 통해 웹에 나타나는 소프트웨어 서비스로 정의했습니다. 그 다음 논리적인 질문은 XML Web services로 무엇을 할 수 있는가 하는 것입니다. 처음에 XML Web services는 주식 시세, 일기 예보, 스포츠 등 응용 프로그램에 쉽게 통합될 수 있는 정보원이었습니다. 원하는 정보를 분석하고 집계하여 다양한 방법으로 표시하도록 작성할 수 있는 응용 프로그램이 있습니다. 예를 들어, Microsoft® Excel 스프레드시트를 사용하여 주식, 401K, 은행 계좌, 대출 등의 전체 금융 상태를 요약할 수 있습니다. 이 정보를 XML Web services에서 사용할 수 있는 경우 Excel은 이 Web services를 계속 업데이트합니다. 이 정보 중 일부는 무료이며 어떤 정보는 서비스 구독이 필요할 수도 있습니다. 대부분의 정보는 웹에서 현재 사용할 수 있지만 XML Web services는 더욱 쉽고 안정적인 프로그래밍 방식으로 액세스됩니다.
기존 응용 프로그램을 XML Web services로 나타내면 XML Web services를 빌딩 블록으로 사용하는 더욱 강력한 새 응용 프로그램을 작성할 수 있습니다. 예를 들어, 여러 공급업체의 가격 정보를 자동으로 얻을 수 있고 공급업체를 선택할 수 있으며 주문한 다음 제품이 도착할 때까지 배달 과정을 확인할 수 있습니다. 공급업체 응용 프로그램은 웹상에 서비스를 표시한 다음 XML Web services를 사용하여 고객의 신용 확인, 요금 부과 및 배달 회사에 배달을 의뢰할 수도 있습니다.
앞으로 몇몇 중요한 XML 웹 서비스를 사용하면 웹을 사용하는 응용 프로그램을 지원하여 오늘날에는 실행하지 못하는 사항들을 실행할 수 있게 될 것입니다. 예를 들어, 일정 관리 서비스는 Microsoft .NET My Services 프로젝트가 지원하는 서비스 중 하나입니다. 치과 의사나 정비사가 XML Web service를 사용하여 일정을 관리하는 경우 고객이 온라인으로 시간 약속을 예약하거나, 고객이 원할 경우 치과 의사나 정비사가 직접 고객과 청소 및 정기 점검 약속을 할 수 있습니다.조금만 생각해 보면, 웹을 프로그램할 수 있는 능력이 있기만 하면 작성할 수 있는 응용 프로그램이 많이 있습니다.
XML Web services 및 응용 프로그램 작성에 대한 더 자세한 내용은 MSDN Web services 홈 페이지를 참조하십시오.
SOAP
SOAP는 XML Web services용 통신 프로토콜입니다. SOAP를 통신 프로토콜로 설명하면 대부분의 사람들은 DCOM 또는 CORBA를 생각하고 "SOAP가 객체를 활성화하는 방법은 " 또는 "SOAP가 사용하는 이름 서비스는 " 등과 같은 질문을 합니다. SOAP 구현에 이러한 내용이 포함되기는 하지만 SOAP 표준은 이 내용을 지정하지 않습니다. SOAP는 메시지 즉, 요청된 사양의 일부에 대한 XML 형식을 정의하는 사양입니다. 몇몇 SOAP 요소에 포함된 올바른 형식의 XML 조각이 있는 경우 SOAP 메시지가 나타납니다. 간단합니다.
SOAP 사양의 다른 부분은 프로그램 데이터를 XML로 표시하고 SOAP를 사용하여 원격 프로시저 호출을 수행하는 방법을 설명합니다. 이러한 사양의 선택적 부품은 클라이언트에서 전송되는 SOAP 메시지에 호출 가능한 함수와 해당 함수에 전달되는 매개 변수가 포함되어 있는 RPC 스타일 응용 프로그램을 구현하는 데 사용되며 서버는 실행된 함수의 결과와 함께 메시지를 반환합니다. COM 또는 CORBA 응용 프로그램을 실행하는 프로그래머들은 RPC 스타일을 이해하기 때문에 현재 대부분의 SOAP 구현은 RPC 응용 프로그램을 지원합니다. 또한 SOAP는 SOAP 메시지가 XML 문서에서 래퍼 기능만 수행하는 문서 스타일 응용 프로그램도 지원합니다. 문서 스타일 SOAP 응용 프로그램은 매우 융통성이 있으며 여러 새 XML Web services는 이 장점을 활용하여 RPC를 사용하여 구현하기 어려운 서비스를 만듭니다.
SOAP 사양의 마지막 선택 부분은 SOAP 메시지를 포함한 HTTP 메시지의 형식을 정의합니다. HTTP 바인딩은 HTTP가 거의 모든 현재 OS 및 현재가 아닌 여러 OS에 의해 지원되기 때문에 중요합니다. HTTP 바인딩은 선택 사항이지만 SOAP에 대해 유일하게 표준화된 프로토콜이기 때문에 거의 모든 SOAP 구현은 HTTP 바인딩을 지원합니다. 이러한 이유로 인해 SOAP에 HTTP가 필요한 것으로 잘못 생각하는 경우가 있습니다. 몇몇 구현은 MSMQ, MQ 시리즈, SMTP 또는 TCP/IP 전송을 지원하지만 거의 모든 현재 XML Web services는 흔히 사용되는 HTTP를 사용합니다. HTTP는 핵심 웹 프로토콜이므로 대부분의 회사는 HTTP를 지원하는 네트워크 인프라와 이를 관리하는 인력을 갖추고 있습니다. 보안, 모니터링 및 HTTP에 대한 로드 균형 인프라는 오늘날 쉽게 사용할 수 있습니다.
SOAP를 시작할 때 혼동되는 주요 원인은 SOAP 사양과 여러 SOAP 사양 구현간의 차이점입니다. SOAP를 사용하는 대부분의 사람들은 SOAP 메시지를 직접 작성하지는 않지만 SOAP 도구 키트를 사용하여 SOAP 메시지를 만들고 구문 분석합니다. 일반적으로 이러한 도구 키트는 함수 호출을 몇몇 종류의 언어에서 SOAP 메시지로 변환합니다. 예를 들어, Microsoft SOAP Toolkit 2.0은 COM 함수 호출을 SOAP로 전환하고 Apache Toolkit는 JAVA 함수 호출을 SOAP로 변환합니다. 함수 호출의 유형과 지원되는 매개 변수의 데이터 유형은 각 SOAP 구현에 따라 다양하기 때문에 한 개의 도구 키트와 함께 작동하는 함수는 다른 도구 키트와 작동하지 않을 수도 있습니다. 이것은 SOAP의 제한 사항이 아니라 사용자가 사용하는 특정 구현입니다.
훨씬 강제적인 SOAP의 기능은 많은 별도의 하드웨어 및 소프트웨어 플랫폼에 구현되었다는 점입니다. 이것은 사용자의 회사 내부, 외부의 서로 다른 시스템을 연결하는 데 SOAP를 사용할 수 있다는 의미입니다. 과거에 시스템을 통합하는 일반 통신 프로토콜을 개발하려는 노력은 많았지만 아무도 SOAP를 일반적으로 채택하지는 않았습니다. 왜냐하면, SOAP는 이전의 많은 프로토콜에 비해 구현하는 데 훨씬 작고 단순했기 때문입니다. 예를 들어, DCE 및 CORBA는 구현하는 데 수 년이 걸렸기 때문에 소수의 구현만이 출시되었습니다. 그러나 SOAP는 기존의 XML 파서 및 HTTP 라이브러리를 사용하여 대부분의 힘든 작업을 수행하므로 수 개월 내에 SOAP 구현을 완료할 수 있습니다. 따라서 70종류의 SOAP 구현을 사용할 수 있습니다. SOAP는 DCE 또는 CORBA가 수행하는 작업을 모두 수행하지는 않지만 기능 교환이 복잡하지 않기 때문에 SOAP를 쉽게 사용할 수 있습니다.
HTTP의 보편성와 SOAP의 간소성이 동시에 존재하면 거의 모든 환경에서 호출할 수 있는 XML Web services를 구현하는 데 있어 이상적인 기반이 됩니다. SOAP에 대한 더 자세한 내용은 MSDN SOAP 홈 페이지를 참조하십시오.
보안
SOAP를 처음 사용하는 사람들의 첫 번째 질문 중 하나는 SOAP가 보안을 다루는 방법입니다. SOAP 개발 초기에는 SOAP가 HTTP 기반 프로토콜로 표시되어 HTTP 보안이 SOAP에 충분했습니다. 오늘날 수 많은 웹 응용 프로그램이 HTTP 보안을 사용하여 실행되므로 HTTP 보안은 SOAP에 충분합니다. 따라서 현재 SOAP 표준은 보안 문제보다는 전송 문제를 다룹니다.
SOAP가 여러 전송 작업에서 제대로 실행되는 보다 일반적인 용도의 프로토콜로 확장되면 보안은 더욱 큰 문제가 됩니다. 예를 들어, HTTP는 SOAP를 호출하는 사용자를 인증하는 몇 가지 방법을 제공하지만 메시지가 HTTP에서 SMTP로 전송될 때 해당 ID의 전파 방법에 대한 문제가 발생합니다. 다행히 SOAP는 빌딩 블록 프로토콜로 디자인되었기 때문에 SOAP를 작성하는 작업에 이미 사양이 포함되어 Web services에 대한 추가 보안 기능을 제공합니다. WS-Security specification 은 전체 암호화 시스템을 정의하고 WS-License specification 은 호출자의 ID와 권한이 부여된 사용자만 Web service를 사용할 수 있도록 하는 기술을 정의합니다.
WSDL
whiz-dull이라고도 하는 WSDL는 Web Services Description Language의 약어입니다. 편의상, WSDL 파일을 SOAP 메시지 집합 및 해당 메시지가 교환되는 방법을 설명하는 XML 문서라고 할 수 있습니다. 다시 말해서 WSDL은 IDL이 CORBA 또는 COM인 SOAP입니다. WSDL은 XML이기 때문에 읽을 수 있고 편집할 수 있지만 대부분의 경우에는 소프트웨어에 의해 작성되고 사용됩니다.
WSDL의 값을 보려면 비즈니스 파트너가 제공하는 SOAP 메서드를 호출해야 합니다. 비즈니스 파트너에게 몇몇 예제 SOAP 메시지를 요청하고 해당 예제와 같은 메시지를 작성하고 사용하는 응용 프로그램을 작성할 수 있으나, 오류가 발생하기 쉽습니다. 예를 들어, 고객 ID가 2387인 경우 메시지가 문자열이면 ID는 정수입니다. WSDL은 요청 메시지에 포함되는 사항과 응답 메시지의 형식을 명백한 노테이션으로 지정합니다.
WSDL 파일이 메시지 형식을 설명하기 위해 사용하는 노테이션은 XML 스키마 표준을 기반으로 하며, 이것은 프로그래밍 언어 중립적이며 또한 표준 기반이어서 다양한 플랫폼과 프로그래밍 언어에서 액세스할 수 있는 XML Web services 인터페이스를 설명하기에 적합하다는 것을 의미합니다. WSDL은 메시지 컨텐트를 설명할 뿐만 아니라 서비스를 사용할 수 있는 위치 및 서비스와 대화하는 데 사용되는 통신 프로토콜을 정의합니다. 즉, WSDL 파일은 XML Web service와 함께 작동하는 프로그램을 쓰는 데 필요한 모든 사항을 정의합니다. WSDL 파일을 읽고 XML Web service와 통신하는 데 필요한 코드를 생성할 수 있는 몇 가지 도구가 있습니다. 그 중에서 성능이 뛰어난 몇몇 도구들이 Microsoft Visual Studio® .NET에 있습니다.
많은 현재 SOAP 도구 키트에는 기존 프로그램 인터페이스에서 WSDL 파일을 생성하는 도구가 포함되지만 WSDL을 직접 작성하는 도구는 거의 없으며 WSDL에 대해 필요한 만큼 도구가 지원되지 않습니다. WSDL 파일 작성자에게 도구가 지원되어 COM IDL과 같은 프록시 및 스텁을 작성하는 것은 대부분의 SOAP 구현의 일부분이 됩니다. 이런 점에서 WSDL은 XML Web services에 대한 SOAP 인터페이스를 만드는 데 좋은 방법입니다.
http://www.w3.org/TR/wsdl 에서 WSDL 사양을 볼 수 있으며 우수한 description of WSDL을 사용할 수 있습니다.
UDDI
UDDI(Universal Discovery Description 및 Integration)는 Web services의 옐로 페이지입니다. 전통적인 옐로 페이지에서는 필요한 서비스를 제공하는 회사를 찾아 제공된 서비스를 검토한 후에 담당자와 연락하여 자세한 정보를 구할 수 있습니다. 지하실에서 비즈니스를 시작하고 말로 광고를 할 수 있는 것처럼 UDDI에 등록하지 않고도 Web service를 제공할 수는 있습니다. 그러나 시장을 넓히기 위해서는 고객이 Web services를 찾을 수 있도록 UDDI에 등록해야 합니다.
UDDI 디렉터리 항목은 비즈니스 및 제공되는 서비스를 설명하는 XML 파일입니다. UDDI 디렉터리의 항목은 세 부분으로 되어 있습니다. "화이트 페이지"는 서비스를 제공하는 회사의 이름, 주소, 연락처 등을 설명합니다. "옐로 페이지"에는 북미 산업 분류 시스템 및 표준 산업 분류 등과 같은 표준 분류법을 기반으로 하는 산업 범주가 나와 있습니다. "그린 페이지"는 Web service를 사용하는 응용 프로그램을 작성할 수 있도록 서비스에 인터페이스를 세부적으로 설명합니다. 서비스 방법은 유형 모델 또는 tModel이라고도 하는 UDDI 문서를 통해 정의됩니다. 많은 경우에, tModel에는 XML Web service에 SOAP 인터페이스를 설명하는 WSDL 파일이 포함되어 있지만 tModel은 융통성이 있어 거의 모든 종류의 서비스를 설명할 수 있습니다.
또한 UDDI 디렉터리에는 사용자의 응용 프로그램을 작성하는 데 필요한 서비스를 검색하는 몇 가지 방법이 있습니다. 예를 들어, 지정된 지역 및 지정된 유형의 비즈니스로 서비스 공급자를 검색할 수 있습니다. 그런 다음 UDDI 디렉터리는 정보, 연락처, 링크 및 기술적인 데이터를 공급하여 사용자의 요구 사항에 맞는 서비스를 평가할 수 있도록 합니다.
UDDI를 사용하여 Web services를 얻을 수 있는 비즈니스를 찾을 수 있습니다. 비즈니스 파트너는 알고 있지만 제공되는 서비스가 무엇인지 모를 경우에는 WS-Inspection specification 을 사용하여 특정 서버에 제공된 XML Web services의 컬렉션을 검색하여 필요한 서비스를 찾을 수 있습니다.
UDDI에 대한 더 자세한 내용은 http://www.uddi.org/about.html 를 참조하십시오.
기타
지금까지 XML Web services와의 대화 방법(SOAP), XML Web services 설명 방법(WSDL) 및 XML Web services 찾는 방법(UDDI)에 대해 설명했습니다. 이러한 사항들은 응용 프로그램 통계 및 집계에 대한 기초를 제공하는 기준 사양 집합을 구성합니다. 회사는 기준 사양을 이용하여 실제 솔루션을 구축하고 실제 값을 얻습니다.
실제 XML Web services를 만드는 데 많은 노력을 해왔지만 앞으로 더욱 많은 노력이 필요합니다. 오늘날 XML Web services를 성공적으로 작성하고는 있지만 보안, 운영 관리, 트랜잭션, 안정된 메시징과 같이 개발자가 개발해야 할 사항들이 여전히 남아 있습니다. 전역 XML Web Services 아키텍처는 모듈화 및 확장 가능한 XML Web services에 새 고급 기능을 추가하는 데 정확한 다용도 모델을 제공하여 XML Web services를 다음 단계로 이동할 수 있도록 도와줍니다.
위에서 언급한 보안 모듈(WS-Security 및 WS-License) 은 전역 Web Services 아키텍처의 사양 중 일부입니다. 운영 관리를 프로세싱하려면 여러 서버 간에 메시지를 라우팅하고 해당 서버를 동적으로 구성해야 하는데 이러한 작업도 전역 Web Services 아키텍처의 일부이며 WS-Routing specification 및 WS-Referral specification 과 일치합니다. 전역 Web Services 아키텍처가 발전함에 따라 해당 사양 및 기타 필요 사항이 소개됩니다.
더 자세한 내용은 Global XML Web Services Architecture 를 참조하십시오.
Matt Powell
Microsoft Corporation
2002년 10월
요약: Matt Powell은 높은 성능의 Microsoft ASP.NET 웹 서비스를 생성하기 위해 서버 쪽에서 비동기 웹 메소드를 사용하는 방법을 보여줍니다.
소개
9월의 3번째 컬럼 (영문) 에서, Microsoft .NET Framework의 서버쪽 특성을 사용해서 HTTP를 통한 비동기 웹서비스 호출에 관해 썼습니다. 이 방법은 많은 백그라운드 쓰레드나 응용 프로그램에 락을 거는 것 없이도 웹 서비스를 호출하는 매우 유용한 방법입니다. 이제 우리는 서버 쪽에서 비슷한 특성을 제공하는 비동기 웹 메소드에 대해 살펴보고자 합니다. 비동기 웹 메소드는 ISAPI extension에서 사용하는 HSE_STATUS_PENDING로써 제공되는 높은 성능의 방식과 비슷하지만, 쓰레드 풀을 직접 관리하는 부담없이 관리되는 코드 안에서 동작되는 모든 이점을 누릴 수 있습니다.
첫째로 일반적인, 동기적 Microsoft ASP.NET의 웹 메소드를 살펴봅시다. 동기적인 웹 메소드에 대한 응답은 메소드로부터 반환이 되었을 때 전송됩니다. 만일 요청을 완료하기에 상대적으로 긴 시간이 걸린다면, 메소드 호출이 끝났을 때까지 요청을 처리하는 쓰레드를 사용하게 됩니다. 불행히도, 오랜 시간이 걸리는 것은 데이터베이스에 질의를 하는 경우와 같은 작업이거나, 다른 웹 서비스를 호출하는 경우입니다. 예를 들면 만일 데이터베이스 호출을 하는 경우, 현재 쓰레드는 데이터베이스에 대한 호출을 완료할 때까지 기다리게 됩니다. 현재 쓰레드는 질의로부터 응답이 올 때까지 아무것도 하지 못하고 기다리게 됩니다. 비슷한 문제들이 TCP 소켓에 대한 호출을 기다리거나 최후위의 웹 서비스를 완료할 때까지 기다리는 일이 일어납니다.
쓰레드들이 대기 중이라는 것을 좋지 않은 일입니다 - 특별히 스트레스를 받는 서버 시나리오에서는 더욱 그러합니다. 대기중인 쓰레드는 다른 요청들을 서비스하는 것과 같은, 생산적인 어떠한 것도 처리할 수 없기 때문입니다. 우리가 서버에서 오랜 시간이 걸리는 백그라운드 프로세스를 시작할 때 필요한 것, 그러나 ASP.NET 프로세스 풀로 현재 쓰레드를 반환하는 것입니다. 그리고 오랜 시간이 걸리는 백그라운드 프로세스가 종료되었을 때, 우리는 ASP.NET에 대한 요청의 완료 신청을 받고 요청에 대한 처리를 마치도록 호출된 콜백 함수를 가지는 것입니다. 이것은 ASP.NET에서 비동기 웹 메소드를 통해 제공되는 특징입니다.
어떻게 비동기 웹 메소드가 동작하는가
웹 메소드를 사용하는 전형적인 ASP.NET 웹 서비스를 우리가 작성할 때, Microsoft Visual Studio .Net은 단순하게 웹 메소드들에 대한 요청을 받았을 때 호출될 수 있는 어셈블리를 생성하도록 코드를 컴파일해 줍니다. 이 어셈블리는 SOAP에 관한 어떤 것도 알지 못합니다. 당신의 응용 프로그램이 처음 실행 될 때, ASMX 핸들러는 어느 웹 메소드가 노출되었는지를 검사하도록 어셈블리를 나타내야 합니다. 일반적인, 동기적 요청에 대해서 이것은 단순히 연관된 WebMethod 속성을 가진 어던 메소드를 발견하는 문제이고, 그리고 SOAPAction HTTP 헤더에 기초해서 올바른 메소드를 호출하도록 로직을 설정하면 됩니다.
비동기 요청에 대해서는, 비동기 적이라고 알 수 있는 특정한 종류의 시그니처를 가진 웹 메소드를 ASMX 핸들러가 리플렉션(Reflection) 동안 찾게 됩니다. 이 경우, 다음의 규칙을 따르는 한 쌍의 메소드들을 찾게 됩니다:
- BeginXXX와 EndXXX의 이름을 가지는 웹 메소드가 있으며 여기서 XXX는 노출하기를 원하는 메소드의 이름을 나타냅니다.
- BeginXXX 함수는 IAsyncResult 인터페이스를 반환하며 마지막 두 개의 입력 파라메터는 AsyncCallback과 객체를 취합니다.
- The EndXXX 함수는 IAsyncResult인터페이스형 파라미터를 취합니다.
- 양쪽 모두 WebMethod 속성으로 표시되어야 합니다.
만일 ASMX 핸들러가 이러한 모든 요구 조건에 맞는 2개의 메소드를 발견했다면, 일반 웹 메소드처럼 WSDL에 XXX메소드를 노출시킵니다. 입력으로써 BeginXXX에 대한 시그니처안에 AsyncCallback 파라미터에 정의된 파라미터들을 받게 되며, EndXXX함수에 의해 반환되는 것을 반환하게 됩니다. 만일 우리가 동기적인 선언형태의 웹 메소드를 가졌다면 이와 같이 보일 겁니다:
[WebMethod] public string LengthyProcedure(int milliseconds) {...}
비동기적인 선언의 경우 아래와 같이 보입니다:
[WebMethod] public IAsyncResult BeginLengthyProcedure( int milliseconds, AsyncCallback cb, object s) {...} [WebMethod] public string EndLengthyProcedure(IAsyncResult call) {...}
각각에 대한 WSDL은 동일합니다.
ASMX핸들러가 어셈블리를 리플렉션하고 비동기적인 웹 메소드를 감지한 후에, 반드시 그 메소드에 대한 요청을 동기적인 요청과는 다르게 처리해야 합니다. 단순하게 메소드를 호출하는 것 대신에, BeginXXX 메소드를 호출합니다. 이것은 함수로 전달된 파라미터에서 입력 요청을 직렬해제(deserialize)합니다. 그러나 여기서는 BeginXXX메소드로 여분의 AsyncCallback파라메터로써 내부 콜백 함수에 대한 포인터를 전달합니다.
이러한 접근은 웹 서비스 클라이언트 응용 프로그램에서 .NET Framework에 있는 비동기적 프로그래밍 페러다임과 비슷합니다. 비동기적 웹 서비스 호출에 대한 클라이언트 지원의 경우에, 클라이언트 컴퓨터에 대한 쓰레드를 블록처리하는 것에서 자유로울 수 있으며, 반면에 서버 쪽에서도 서버에서의 쓰레드를 블록처리하지 않고 사용합니다. 여기에는 두 가지 다른 점이 있습니다. 첫 번째로 직접 BeginXXX와 EndXXX 함수를 호출하는 코드를 작성하는 것 대신에, ASMX핸들러가 대신 이들을 호출해 줍니다. 두 번째로, Visual Studio .NET "웹 참조 추가"마법사나 WSDL.EXE를 사용해서 생성된 코드를 사용하는 것 대신에 BeginXXX와 EndXXX 함수에 대한 코드를 작성할 수 있습니다. 그러나, 결과적으로 다른 어떤 작업을 수행할 수 있도록 쓰레드를 자유롭게 하는 것은 동일합니다.
ASMX핸들러가 서버의 BeginXXX 함수를 호출한 후에, 받게 되는 어느 다른 요청들을 처리할 수 있도록 프로세스의 쓰레드 풀로 쓰레드를 반환합니다. ASMX 핸들러는 BeginXXX함수로 전달된 콜백 함수가 요청에 대한 처리를 마치고 호출되기까지 대기하게 됩니다.
한번 콜백 함수가 호출되면, ASMX 핸들러는 웹 메소드가 수행하기에 필요한 어떤 처리를 완료할 수 있도록 EndXXX 함수를 호출하게 되며, 그리고 반환 데이터는 SOAP응답 안에 직렬화되도록 제공됩니다. EndXXX함수가 반환된 후 응답이 보내지며 요청에 대한 HttpContext가 해지됩니다.
단순한 비동기 웹 메소드
비동기 웹 메소드를 설명하기 위해서, 필자는 아래에 보여준 코드처럼 LengthyProcedure라고 불리는 단순한 동기 메소드부터 시작합니다. 우리는 어떻게 비동기적으로 동일한 것을 처리하는 지를 볼 것입니다. LengthyProcedure는 수천 분의 몇 초 동안만 블록킹 됩니다.
[WebService] public class SyncWebService : System.Web.Services.WebService { [WebMethod] public string LengthyProcedure(int milliseconds) { System.Threading.Thread.Sleep(milliseconds); return "Success"; } }
이제 우리는 LengthyProcedure를 비동기 웹 메소드로 변환합니다. 우리는 반드시 BeginLengthyProcedure 함수를 생성해야 하며 그리고 앞에서 기술한 것처럼 EndLengthyProcedure 함수를 생성해야 합니다. 우리의 BeginLengthyProcedure는 IAsyncResult 인터페이스를 반환해야 함을 기억해야 합니다. 이 경우에 필자는 우리의 BeginLengthyProcedure가 위임자(delegate)를 사용하는 비동기적 메소드 호출을 하도록 하며 그 위임자에 대해 BeginInvoke 메소드를 갖도록 하려 합니다. 콜백 함수는 우리의 델리게이트에서 BeginInvoke 메소드를 통해 처리될 수 있도록 BeginLengthyProcedure로 전달되며, BeginInvoke로부터 반환되는 IAsyncResult는 BeginLenthyProcedure 메소드에서 반환됩니다.
EndLengthyProcedure는 우리의 델리게이트가 완료될 때 호출됩니다. 우리는 IAsyncResult에서 전달된 델리게이트에서 EndInvoke메소드를 호출하며 EndLenghyProcedure호출에 대한 입력으로써 받게 됩니다. 반환된 문자열은 우리의 웹 메소드로부터 반환된 문자열이 됩니다. 여기에 코드가 있습니다:
[WebService] public class AsyncWebService : System.Web.Services.WebService { public delegate string LengthyProcedureAsyncStub( int milliseconds); public string LengthyProcedure(int milliseconds) { System.Threading.Thread.Sleep(milliseconds); return "Success"; } public class MyState { public object previousState; public LengthyProcedureAsyncStub asyncStub; } [ System.Web.Services.WebMethod ] public IAsyncResult BeginLengthyProcedure(int milliseconds, AsyncCallback cb, object s) { LengthyProcedureAsyncStub stub = new LengthyProcedureAsyncStub(LengthyProcedure); MyState ms = new MyState(); ms.previousState = s; ms.asyncStub = stub; return stub.BeginInvoke(milliseconds, cb, ms); } [ System.Web.Services.WebMethod ] public string EndLengthyProcedure(IAsyncResult call) { MyState ms = (MyState)call.AsyncState; return ms.asyncStub.EndInvoke(call); } }
비동기 웹 메소드가 사용될 때
응용 프로그램에 비동기적 웹 메소드를 사용할지를 결정해야 할 때 고려해야 할 몇 가지 문제가 있습니다. 첫 번째로, 호출에 대해 BeginXXX 함수는 IAsyncResult 인터페이스를 반환해야 합니다. IAsyncResult는 스트림, Microsoft Windows Sockets호출, 파일 I/O를 실행, 다른 하드웨어 디바이스와 교류, 비동기적 메소드의 호출, 그리고 물론 다른 웹 서비스를 호출하는 것과 같은 다양한 비동기적 I/O작업들로부터 반환됩니다. 이러한 종류의 비동기적 작업들 중의 하나로부터 IAsyncResult를 얻기를 원한다면, BeginXXX 함수로부터 반환할 수 있습니다. 다른 옵션은 IAsyncResult 인터페이스를 구현하는 고유의 클래스를 생성하는 것인데, 앞에서 언급한 I/O 구현중의 하나를 포장하는 것 이상을 해야만 합니다.
우리가 언급했던 비동기적 작업들 중 대부분의 경우, 백그라운드 비동기적 호출을 감싸는 비동기적 웹 메소드의 사용을 주의 깊게 만들고 더 효율적인 웹 서비스 코드로 결과를 주게 됩니다. 위임자를 사용하는 비동기적 메소드 호출을 사용할 경우 예외가 있습니다. 위임자는 프로세스의 쓰레드 풀에 있는 쓰레드를 실행해서 비동기적 메소드 호출을 하도록 합니다. 불행히도, 이러한 것들은 입력된 요청들을 서비스하기 위해 ASMX 핸들러에서 사용된 것과 동일한 쓰레드여야 합니다. 하드웨어나 네트워킹 리소스에 대한 실제 I/O 오퍼레이션을 수행하는 호출들과는 달리, 위임자를 사용하는 비동기적 메소드 호출은 실행 중에 프로세스 쓰레드 중의 하나를 여전히 블록킹하게 됩니다. 원래 쓰레드를 블록킹하고 동기적으로 실행되는 웹 메소드를 갖도록 해야 합니다.
다음의 예제는 최후위 웹 서비스를 호출하는 비동기적 웹 메소드를 보여줍니다. 비동기적으로 실행되는 WebMethod 속성으로 BeginGetAge와 EndGetAge 메소드를 표시합니다. 이러한 비동기적 웹 메소드에 대한 코드는 반환될 정보를 얻기 위해 UserInfoQuery라 불리는 최후위 웹 메소드를 호출합니다. UserInfoQuery에 대한 호출은 비동기적으로 실행되며 BeginGetAge 메소드로 전달되는 AsyncCallback 함수를 전달합니다. 이것은 최후위 요청이 완료될 때 호출되는 내부 콜백 함수가 실행되도록 합니다. 콜백 함수는 요청을 완료하도록 EndGetAge 메소드를 호출합니다. 이 경우 코드는 앞에서의 예제보다 더 간단해지며, 그리고 우리의 중간 계층의 웹 메소드 요청을 서비스하는 동일한 쓰레드 풀에서 최후위 프로세스을 실행하지 않는 추가적인 이점을 가지게 됩니다.
[WebService] public class GetMyInfo : System.Web.Services.WebService { [WebMethod] public IAsyncResult BeginGetAge(AsyncCallback cb, Object state) { // 비동기적인 웹 서비스 호출 localhost.UserInfoQuery proxy = new localhost.UserInfoQuery(); return proxy.BeginGetUserInfo("User's Name", cb, proxy); } [WebMethod] public int EndGetAge(IAsyncResult res) { localhost.UserInfoQuery proxy = (localhost.UserInfoQuery)res.AsyncState; int age = proxy.EndGetUserInfo(res).age; // 웹 서비스 호출로부터의 결과에 추가적인 프로세싱을 수행합니다. return age; } }
웹 메소드 내부에서 일어나는 가장 공통적인 형태의 I/O작업중의 하는 SQL 데이터베이스에 대한 호출입니다. 불행히도, Microsoft ADO.NET은 2002년 현재 좋은 비동기적인 호출 메카니즘을 가지고 있지 않으며, 단순하게 비동기적인 위임자 호출 안에서 SQL호출을 감싸는 것은 효율성 부분에서 도움이 되지 않습니다. 웹 서비스로 데이터베이스를 노출시키기를 원한다면 Microsoft SQL Server 2000 Web Services Toolkit (영문)을 사용을 고려해 볼 수 있습니다. 데이터베이스를 업데이트하거나 질의하는 비동기적인 웹 서비스를 호출하기 위해서 .NET Framework의 지원을 받을 수 있습니다.
웹 서비스 호출을 통해 SQL을 액세스하는 것은 많은 최후위 리소스들에 사용해야 할 방법 중 하나입니다. 만일 유닉스 서버와 커뮤니케이션을 하기 위해 TCP소켓을 사용한다면, 또는 적절한 데이터베이스 드라이버들을 통해 다른 SQL플랫폼중의 어던 것을 액세스한다면 - 또는 DCOM을 사용해서 액세스하는 리소스를 가지고 있다면 -웹 서비스로써 리소스를 노출시켜주는 현 시점에서 가능한 다양한 웹 서비스 툴킷들의 사용을 고려해 볼 수 있습니다.
이러한 접근법을 취하는 것의 장점 중의 하나는, .NET Framework에서 비동기적 웹 서비스 호출과 같은 클라이언트 쪽 웹 서비스 인프라구조에서의 장점들을 취하는 것입니다. 비용이 들지 않는 비동기적 호출을 얻는다면, 클라이언트 액세스 메커니즘은 비동기적 웹 메소드와 함께 효율적으로 작업할 수 있게 될 겁니다.
비 동기적 웹 메소드를 사용해서 데이터를 집계
오늘날의 많은 웹 서비스들은 최후위 쪽에 있는 다중의 리소스들을 액세스하며 최전위 웹 서비스에 대한 정보들을 집계합니다. 심지어 웹 메소드 모델을 더욱 복잡하게 만드는 여러 개의 최후위 리소스들을 호출하는 것은, 상당한 양의 효율성을 얻게 됩니다.
서비스 A와 서비스 B인, 두 개의 최후위 웹 서비스를 호출하는 웹 메소드가 있다고 합시다. BeginXXX 함수로부터, 비동기적으로 서비스 A를 호출하고 서비스 B를 비동기적으로 호출합니다. 당신은 이러한 비동기적 호출의 각각에 대해서 고유의 콜백 함수를 전달할 수 있습니다. 서비스 A와 서비스 B 양쪽에서 결과를 받은 후에 웹 메소드의 완료를 자동 동작시키기 위해, 당신이 제공한 콜백 함수는 양쪽의 요청이 완료되었는지를 검사하며, 반환된 데이터에 대한 처리를 실행하며, 그리고 BeginXXX 함수에 대해 전달된 콜백 함수를 호출하게 됩니다. 이것은 비동기적 웹 메소드가 완료되도록 반환되는, EndXXX 함수를 호출하도록 자동 동작시킵니다.
결론
비동기적인 웹 메소드는 프로세스 쓰레스 풀 안에 귀중한 쓰레드가 아무것도 하지 않으면서 블록되도록 두지 않고 ASP.NET 웹 서비스에서 최후위 서비스를 호출하는 효율적인 메커니즘을 제공합니다. 최후위 리소스들에 대한 비동기적인 요청들과의 결합하여, 서버는 그들의 웹 메소드들을 최대로 처리할 수 있게 됩니다. 고성능의 웹 서비스 응용 프로그램을 개발하기 위해서는 이러한 접근방법을 고려해 보아야 합니다.
저자에 대해
Subversion은 지난 수년간 인기를 얻어온 공개 소스 소스 제어 시스템입니다. Subversion은 단순하고 사용자에게 익숙한 방식으로 분기, 태그 지정 및 병합과 같은 여러 가지 일반적인 소스 제어 기능을 처리합니다. Subversion이 인기를 얻고 있는 이유는 무료 공개 소스이고, 설치와 사용이 쉬우며, TortoiseSVN과 같은 탁월한 도구가 있기 때문입니다. Windows® 탐색기 확장 기능인 TortoiseSVN을 사용하면 별도의 도구를 사용하지 않고도 표준 탐색기 창에서 바로 모든 소스 제어 기능을 수행할 수 있습니다.
SourceForge에서는 Subversion 호스팅을 제공하기 시작했으며, CodePlex에서도 TortoiseSVN을 사이트에서 사용할 수 있도록 Subversion 에뮬레이션을 제공합니다. Subversion으로 전환하는 일부 .NET 회사에서 가장 자주 놓치는 기능 중 하나로 Visual Studio와의 밀접한 통합이 있지만 이러한 통합을 가능하게 해 주는 다른 유명한 소스 제어 시스템이 있습니다.
Visual Studio와 Subversion 간의 탁월한 통합 기능을 제공하는 Visual Studio 추가 기능인 VisualSVN을 사용해 보십시오. VisualSVN을 사용하면 Visual Studio에서 제공하는 솔루션 탐색기의 각 파일 옆에 쉽게 알 수 있는 마커가 표시됩니다(솔루션이 Subversion 리포지토리에 저장되어 있어야 함). 이 마커는 파일이 수정되었거나 수정되지 않았거나 충돌이 발생할 때 표시됩니다. 파일을 마우스 오른쪽 단추로 클릭한 다음 변경 내용을 보거나 이전 상태로 되돌리거나 업데이트하거나 커밋할 수 있습니다.
VisualSVN 메뉴를 사용하여 전체 프로젝트의 변경 내용을 관리할 수 있습니다. VisualSVN 메뉴에는 리포지토리 탐색기, 패치 만들기 및 적용, Subversion 로그 보기, 리포지토리 분기, 병합 및 전환과 같은 일반적인 TortoiseSVN 기능에 대한 바로 가기도 있습니다.
가장 중요한 기민성 개념 중 하나는 초기에 자주 체크 인하는 것입니다. 가능한 한 신속하게 통합하여 잠재적인 병합 문제를 찾을 수 있으며, 지속적인 통합을 구현하는 경우 모든 코드가 빌드되고 테스트가 실행됩니다. Visual Studio와 밀접하게 통합되어 있는 VisualSVN은 수정한 후 아직 체크 인하지 않은 변경 내용에 대한 알림을 지속적으로 제공하므로 초기에 자주 체크 인할 수 있습니다. 이러한 변경 내용을 Visual Studio에서 직접 체크 인할 수 있으므로 더 이상 미룰 이유가 없습니다.
발췌 : http://msdn.microsoft.com/msdnmag/issues/08/LA/Toolbox/default.aspx?loc=ko#S2