Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

서버 Remoting 개체에게 "참조"를 이용하여 개체를 전달하는 방법이 있을 수 있습니다.
예를 들어 다음과 같은 식이지요.

서버 개체
public void DoDBInsert( CallBackClass aClass )
{

   // 모든 DB 작업을 수행

  try {
      aClass.Test_Connect(); // 클라이언트가 연결되었는지 확인하기 위한 메서드 호출
    } catch ( Exception ex )
    {
      // 모든 DB 작업을 rollback
    }
}

public class CallBackClass : System.MarshalByRefObject
{
   void Test_Connect() {}
}

CallBackClass가 리모팅 개체이므로, 서버 측에서 클라이언트가 연결되었는지에
대한 테스트를 위해서 아무 메서드나 불러주면 되는 것이죠. 만약 정상적으로
호출이 되면 아직도 클라이언트가 살아 있는 것이고, 그렇지 않으면. ^^;

더 좋은 방법을 알고 계신 분들은.... 공유해 주십시오. ^^
예를 들어, Remoting에 의해서 제공되는 클래스들 중에서 IsClientConnected
라는 식의 프로퍼티를 제공해 주는 것이 있다거나... ^^

--
======= (c) .NETXpert ==========
url : http://www.dotnetxpert.com
eml : kevin@dotnetxpert.com
msn: kevin025@magicn.com

MCSD.NET, MVP[VC++]
==============================

"KapRyeong Kim" <ararion@hotmail.com> wrote in message
news:eRZPWMzlEHA.2216@cpmsftngsa05.privatenews.microsoft.com...
> 원격 개체(singleton이나 singlecall)가 자신을 호출한 프록시가 죽었는지 알

> 있는 방법이 있을 까요?
>
> 프록시가 원격 개체를 호출해 놓고 갑자기 죽어버릴 경우(네트웍이 끊겼거나
> 클라이언트가 다운), 호출된 원격 개체는 실컷 일하고 결과를 돌려 주지 못하는
> 경우가 생기는 군요.
>
> 단순히 돌려주지만 못하면 상관없는데.. 원격 서버 DB를 롤백할 방법이
> 막막하군요..
>
> 경험 있으신 분은 알려주시면 감사하겠습니다..
>
>
>









[최초 등록일: ]
[최종 수정일: 6/25/2021]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 16  17  18  19  20  [21]  22  23  24  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
13413정성태9/14/202312017닷넷: 2143. C# - 시스템 Time Zone 변경 시 이벤트 알림을 받는 방법
13412정성태9/14/202315511닷넷: 2142. C# 12 - 인라인 배열(Inline Arrays) [1]
13411정성태9/12/202311817Windows: 252. 권한 상승 전/후 따로 관리되는 공유 네트워크 드라이브 정보 [1]
13410정성태9/11/202313295닷넷: 2141. C# 12 - Interceptor (컴파일 시에 메서드 호출 재작성) [1]
13409정성태9/8/202312577닷넷: 2140. C# - Win32 API를 이용한 모니터 전원 끄기
13408정성태9/5/202312164Windows: 251. 임의로 만든 EXE 파일을 포함한 ZIP 파일의 압축을 해제할 때 Windows Defender에 의해 삭제되는 경우
13407정성태9/4/202311988닷넷: 2139. C# - ParallelEnumerable을 이용한 IEnumerable에 대한 병렬 처리
13406정성태9/4/202311775VS.NET IDE: 186. Visual Studio Community 버전의 라이선스
13405정성태9/3/202312873닷넷: 2138. C# - async 메서드 호출 원칙
13404정성태8/29/202313030오류 유형: 876. Windows - 키보드의 등호(=, Equals sign) 키가 눌리지 않는 경우
13403정성태8/21/202311674오류 유형: 875. The following signatures couldn't be verified because the public key is not available: NO_PUBKEY EB3E94ADBE1229CF
13402정성태8/20/202311894닷넷: 2137. ILSpy의 nuget 라이브러리 버전 - ICSharpCode.Decompiler
13401정성태8/19/202311817닷넷: 2136. .NET 5+ 환경에서 P/Invoke의 성능을 높이기 위한 SuppressGCTransition 특성 [1]
13400정성태8/10/202311531오류 유형: 874. 파이썬 - pymssql을 윈도우 환경에서 설치 불가
13399정성태8/9/202310451닷넷: 2135. C# - 지역 변수로 이해하는 메서드 매개변수의 값/참조 전달
13398정성태8/3/202313446스크립트: 55. 파이썬 - pyodbc를 이용한 SQL Server 연결 사용법
13397정성태7/23/202312457닷넷: 2134. C# - 문자열 연결 시 string.Create를 이용한 GC 할당 최소화
13396정성태7/22/202311856스크립트: 54. 파이썬 pystack 소개 - 메모리 덤프로부터 콜 스택 열거
13395정성태7/20/202311131개발 환경 구성: 685. 로컬에서 개발 중인 ASP.NET Core/5+ 웹 사이트에 대해 localhost 이외의 호스트 이름으로 접근하는 방법
13394정성태7/16/202310474오류 유형: 873. Oracle.ManagedDataAccess.Client - 쿼리 수행 시 System.InvalidOperationException
13393정성태7/16/202311200닷넷: 2133. C# - Oracle 데이터베이스의 Sleep 쿼리 실행하는 방법
13392정성태7/16/202310784오류 유형: 872. Oracle - ORA-01031: insufficient privileges
13391정성태7/14/202311174닷넷: 2132. C# - sealed 클래스의 메서드를 callback 호출했을 때 인라인 처리가 될까요?
13390정성태7/12/202311117스크립트: 53. 파이썬 - localhost 호출 시의 hang 현상
13389정성태7/5/202311472개발 환경 구성: 684. IIS Express로 호스팅하는 웹을 WSL 환경에서 접근하는 방법
13388정성태7/3/202311921오류 유형: 871. 윈도우 탐색기에서 열리지 않는 zip 파일 - The Compressed (zipped) Folder '[...].zip' is invalid. [1]파일 다운로드1
... 16  17  18  19  20  [21]  22  23  24  25  26  27  28  29  30  ...