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

비밀번호

댓글 작성자
 




[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
14012정성태9/9/2025182닷넷: 2362. C# - Windows.Media.Ocr: 윈도우 운영체제에 포함된 OCR(Optical Character Recognition)파일 다운로드1
14011정성태9/7/2025734닷넷: 2361. C# - Linux 환경의 readlink 호출
14010정성태9/1/20251183오류 유형: 983. apt update 시 "The repository 'http://deb.debian.org/debian buster Release' does not have a Release file." 오류
14009정성태8/28/20251315닷넷: 2360. C# 14 - (11) Expression Tree에 선택적 인수와 명명된 인수 허용파일 다운로드1
14008정성태8/26/20251598닷넷: 2359. C# 14 - (10) 복합 대입 연산자의 오버로드 지원파일 다운로드1
14007정성태8/25/20252021닷넷: 2358. C# - 현재 빌드에 적용 중인 컴파일러 버전 확인 방법 (#error version)
14006정성태8/23/20252335Linux: 121. Linux - snap 패키지 관리자로 설치한 소프트웨어의 디렉터리 접근 제한
14005정성태8/21/20251855오류 유형: 982. sudo: unable to load /usr/libexec/sudo/sudoers.so: libssl.so.3: cannot open shared object file: No such file or directory
14004정성태8/21/20252042오류 유형: 981. dotnet 실행 시 No usable version of the libssl was found
14003정성태8/21/20252205닷넷: 2357. C# 14 - (9) 새로운 지시자 추가 (Ignored directives)
14002정성태8/20/20252374오류 유형: 980. C# - appsettings.json 파일의 설정값이 적용 안 된다면?
14001정성태8/19/20253301닷넷: 2356. .NET SDK 10 - 단일 소스 코드 파일을 빌드/실행하는 기능을 "dotnet" 명령어에 추가 [1]
14000정성태8/18/20252446오류 유형: 979. ERROR: failed to solve: failed to read dockerfile: open Dockerfile: no such file or directory
13999정성태8/15/20252453닷넷: 2355. C# 14 - (8) null 조건부 연산자 개선 - 대입문에도 사용 가능파일 다운로드1
13998정성태8/14/20252399닷넷: 2354. C# 14 - (7) 확장 메서드에 정적 메서드와 속성 지원을 위한 전용 구문 추가파일 다운로드1
13997정성태8/14/20252524Linux: 120. docker 컨테이너로 매핑된 볼륨에 컨테이너 측의 사용자 ID를 유지하면서 복사하는 방법
13996정성태8/13/20251993오류 유형: 978. Unable to find the requested .Net Framework Data Provider.
13995정성태8/13/20252146개발 환경 구성: 754. Visual C++ - 리눅스 빌드를 위한 Ubuntu 18 docker 컨테이너 설정
13994정성태8/12/20251941오류 유형: 977. SQL Server - User, group, or role '...' already exists in the current database. (Microsoft SQL Server, Error: 15023)
13993정성태8/11/20252680오류 유형: 976. Microsoft.ML.OnnxRuntimeGenAI 패키지 사용 시 "cublasLt64_12.dll" which is missing. (Error 126: "The specified module could not be found.") 오류
13992정성태8/11/20252740닷넷: 2353. C# - Foundry Local을 이용한 gpt-oss-20b 모델 사용파일 다운로드1
13991정성태8/9/20252463오류 유형: 975. winget - Foundry Local 패키지 업데이트가 안 되는 문제
13990정성태8/8/20251983Windows: 283. Time zone 설정이 없는 Windows Server 2025
13989정성태8/8/20252630닷넷: 2352. C# - Windows S-mode 환경인지 체크하는 방법파일 다운로드1
13988정성태8/8/20252659오류 유형: 974. 비주얼 스튜디오 업데이트 시 잠김 파일 경고 - Visual Studio Standard Collector Service 150 (VSStandardCollectorService150)
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...