728x90

OfficeMain 1732921 - Three index systems suspended on production server (Feeding Controller Bug)

현재 Exchange 2013에서는 Fix되지 않았으며 차기 버전(2016)에서 Fix되었습니다.

아래와 같이 Action Plan을 전달 드립니다.

1. 현재 실패하고 있는 Database 중에 가장 작은 DB를 확인합니다.

2. Active Database의 Content Index를 Rebuild 합니다.

1) Microsoft Exchange Search 서비스 중지

2) Microsoft Exchange Search Host Controller 서비스 중지

3) 선택한 하나의 DB Catalog Folder 이름 변경(탑재되어 있는 서버의 DB 폴더)

4) 위의 두 서비스 시작


728x90
728x90



1. 파워쉘 실행(관리자권한)

2. 역할 및 기능 추가 설치

    Install-WindowsFeature -Name Web-Server, Web-Mgmt-Tools

or


Import-Module ServerManager

Add-WindowsFeature Web-Static-Content,Web-Default-Doc,Web-Dir-Browsing,Web-Http-Errors,Web-Net-Ext,Web-Http-Logging,Web-Request-Monitor,Web-Http-Tracing,Web-Filtering,Web-Stat-Compression,Web-Mgmt-Console,NET-Framework-Core,NET-Win-CFAC,NET-Non-HTTP-Activ,NET-HTTP-Activation,RSAT-Web-Server,



728x90
728x90


Get-MailboxDatabaseCopyStatus * | where {$_.파라메터이름 -eq "검색값"}

예)

Get-MailboxDatabaseCopyStatus * | where {$_.ContentIndexState -eq "Failed"}

728x90
728x90

이벤트 ID : 1021

Source : MSExchangeTransport

내용

수신 커넷터 ****이(가) IP 주소 xxx.xxx.xxx.xxx에서 받는 연결을 거부했습니다.

이 원본 IP 주소에 의해 이 커넷터에 대한 원본(20)당 최대 연결 수에 도달 했습니다.


원인 수신커넥터의 최대인바운드 초과로 발생

해결 최대 인바운드를 무제한으로 설정


1. 수신커넥터 정보 확인

   Get-ReceiveConnector | Select Name,MaxInbound*

MaxInboundConnectionPerSource : 20

MaxInboundConnectionPercentagePerSource : 2

기본 설정값이 되어있음을 확인


2. 최대인바운드커넥터로 설정

Get-ReveiceConnector Lotteshopping* | Set-ReceiveConnector -MaxInboundConnectionPerSource unlimited -MaxInboundConnectionPercentagePerSource 100


감사합니다.

728x90
728x90

1. Debug CRT Heap의 기본 기능들 사용
 Win32 API에 탑재되어 있는 _CrtDumpMemoryLeaks()에 의한 메모리 누수 덤프 기능은 비록 정확히 어느 소스코드에 의해 leak 발생하는지까지 알려주지는 않으나 최소한 leak이 존재하는지 여부는 보고해준다. 따라서 어플리케이션의 검증용으로 매우 유용하다.
 이 기능을 응용하여 메모리 누수 위치까지 알기 위해서는 Microsoft의 Application Verifier를 통해 callstack trace를 활성화 시켜주면 된다. 다만, 작은 크기의 할당이 매우 많이 일어나는 경우를 추적하기 위해서는 프로세스의 메모리가 부족할 수 있다는 제약이 있다.
 위의 전 과정에 대한 더욱 상세한 안내를 위해서는, http://jpassing.com/2008/09/01/effective-leak-detection-with-the-debug-crt-and-application-verifier/ 링크가 많은 도움이 될 것이다.

 이 기법은 메모리 누수의 원인을 찾기 위해서라기 보다는, 개발중인 어플리케이션의 메모리 누수 검증용으로 코드의 exit 처리 부분에 삽입해 두면 유용하다.


2. UMDH
 Microsoft Windows SDK에 포함되어 있는 UMDH를 사용하면 원하는 시점에 메모리 할당 내역의 스냅샷을 덤프할 수 있으며, 두 스냅샷의 비교를 통해 구체적으로 메모리가 소스코드의 어느부분에서 할당되고 해제되었는지 그 상세한 내역을 확인할 수 있어, 메모리 누수의 확인에 매우 유용한 툴이다. 게다가 실행 성능 저하와 추가 메모리 부담이 매우 적으므로 반드시 숙지해야 할 툴이라 할 수 있다. (자세한 사용법은 http://support.microsoft.com/kb/268343/ko 참고)
 이 툴을 이용한 메모리 누수 위치 확인 방법은 일반적으로 다음과 같다.
  1. 개발중인 어플리케이션에 대해 UMDH의 추적기능을 활성화
  2. 첫번쨰 메모리 스냅샷 덤프
  3. 확인을 원하는 실행 지점에서 두번쨰 메모리 스냅샷 덤프
  4. 위의 두 메모리 스냅샷 간의 메모리 할당 증감 내역 비교
  5. (UMDH 추적기능 비활성화)


3. 자체 메모리 관리자
 메모리 사용의 내역을 추적하는 가장 확실한 방법은 자체 메모리 관리자와 할당 내역 프로파일러를 구현하는 것이다.
 자체 메모리 관리자는 일반적으로 다음과 같은 방식으로 구현될 수 있다.
  • new operator와 malloc 등을 override 하여 새로운 할당자(allocator)를 구현하고, 모든 소스코드가 이를 명시적으로 사용하도록 함. 그러나 할당자를 사용하는 코드가 실수로 다른 할당자를 사용하거나, 유사한 인자(arguments)를 받는 다른 할당자들이 혼재되어 include되는 경우 이에 의한 버그를 추적하기 매우 어려워지는 단점이있다. 반면, 소스코드 수준에서 다양한 할당자를 선택적으로 사용하거나 추가적인 힌트를 전달할 수 있다는 점에서 장기적으로는 추천할 만 하다.
  • HeapAlloc 등의 OS 함수를 후킹하여, 이에 들어오는 호출들이 자체 구현을 거쳐가도록 함. Windows DLL을 후킹하기 위한 절차가 다소 까다로우나, 한 번 구현하고 나면 소스코드의 실수로 다른 할당자와 혼재되는 것이 근본적으로 방지된다는 점에서 매우 강력하다.

4. 자체 프로파일러
 자체 메모리 관리자가 존재한다면, 여기에 어떤 방법으로든 프로파일러를 구현할 수 있다.
 다음과 같은 방식의 프로파일러들이 고려 가능할 것이다.
  • 모든 메모리 할당과 해제를 로그로 남겨서 외부 분석기를 이용해 사후 분석
  • 소스 코드에 카테고리 정보를 추가하여, 각 카테고리 별로 메모리 사용량 계측. 실시간 통계도 가능

5. 상용 툴들
MemoryValidator, Rational Purify 등의 상용 툴들을 사용하여 어플리케이션을 실행하면 다양한 정보를 자동으로 얻을 수 있다. 다만, 어플리케이션의 실행 성능이 현저하게 느려지므로 문제점 재현에 어려움이 따르는 경우가 많다.


6. 그 외 진단에 유용한 무료 툴들
  1. Process Explorer
 new 와 같이 명시적인 메모리 할당 요청 외에도, OS의 자원을 사용함에 의해 OS가 내부적으로 메모리를 할당하는 경우도 많다. 따라서 명시적인 할당에서 이상한 점이 발견되지 않는다면 어플리케이션의 OS handle 사용 내역을 점검할 필요가 있는데, 이 때  Process Explorer를 사용하면 그 정보를 상세하게 볼 수 있다.

  1. VMMap
 어플리케이션이 사용하는 메모리는 OS의 관점에서 다양한 종류와 상태로 분류된다.
 현재 프로세스가 사용하는 메모리의 상태의 큰 그림을 알아야 어플리케이션의 총체적인 메모리 이슈를 파악하는데에 유용하다. VMMap 툴은 프로세스의 메모리 사용 현황을 직관적인 다이어그램으로 보여준다. 

 이 툴의 다이어그램은 Windows 고유의 관점에 의해 메모리 할당 용도를 분류하는데, 각 할당의 상태와 그 의미에 대해서는 다음의 자료가 유용할 것이다.




FYI...

http://kuaaan.tistory.com/164

ProcessExplorer

http://kuaaan.tistory.com/128

http://byung.egloos.com/4877210

728x90
728x90



1. DB 인덱싱 Enable 확인

   Get-MailBoxDatabase "DB명" | select name, indexenabled 


2. DB 카피 상태 확인

   Get-MailboxDatabaseCopyStatus –Server 서버명 | fl Name,*Index*


3. 해당 DB Mailbox 사용자 Search 검색 테스트

   Test-ExchangeSearch <mailbox name>


4. Search Indexer service 중지

   net stop "Microsoft Exchange Search Indexer"


5. Database CatalogData 폴더 위치 확인

   GetSearchIndexForDatabase.ps1 –all


6. CatalogData 폴더 삭제(백업)


7. 해당 DB 인덱스 Reset 실행

   ResetSearchIndex.ps1 "DB명"


8. CatalogData 폴더 생성 확인



9. 해당 DB Mailbox 사용자 Search 검색 테스트

   Test-ExchangeSearch <mailbox name>


FYI...

https://technet.microsoft.com/ko-kr/library/ee633475(v=exchg.150).aspx

http://blogs.msdn.com/b/pepeedu/archive/2010/12/14/exchange-2010-database-copy-on-server-has-content-index-catalog-files-in-the-following-state-failed.aspx

http://exchangeserverpro.com/fix-failed-database-content-index-exchange-2013/

https://theucguy.net/fix-corrupted-content-index-catalog-of-a-mailbox-database-with-single-copy/


By default the Exchange 2010 DAG replication port is set to 64327 TCP.


You can change the port with the following command:



Set-DatabaseAvailabilityGroup -Identity YOURDAG -ReplicationPort YOURPORT


끝.

 


728x90
728x90

1. 레지스터리 키삭제 방법

reg delete HKEY_CURRENT_USER\Software\Microsoft\Office\15.0\Lync\user@sipdomain /force

또는 

reg delete HKEY_CURRENT_USER\Software\Microsoft\Office\15.0\Lync\%username%@sipdomain /force


2. 프로파일 폴더 삭제 방법 

RD /Q /S C:\Users\%username%\AppData\Local\Microsoft\Office\15.0\Lync\username@sip.domain

혹은

RD /Q /S C:\Users\사용자이름\AppData\Local\Microsoft\Office\15.0\Lync\username@sip.domain


끝.

728x90
728x90

H/W vendor에 따라 ASR NMI 기능이 있습니다. 이 기능들은 disable해야 memory dump가 생성 가능해지는 경우가 있습니다.

 

아래 기술 문서를 참조하세요.

https://support.microsoft.com/en-us/kb/927069

https://serversystems.wordpress.com/2012/05/10/troubleshooting-the-blue-screen-and-generatinganalyzing-manual-memory-dump/

 

끝.

728x90

'IT이야기 > OS' 카테고리의 다른 글

IIS 설치 파워쉘  (0) 2016.01.28
메모리 누수 유용한 툴  (0) 2016.01.21
Cluster Log 파일 생성하는 명령  (0) 2016.01.12
가상 VHD 파일 사이즈 압축  (0) 2016.01.08
dsquery, dsmod 사용 방법  (0) 2015.06.10
728x90

클러스터 이벤트는 성능모니터링에서 추적 되고 있어야 한다.

이것은 ETW라는 파일로 되어 있기때문에 Log파일로 변환 해서 보면 쉽게 볼수 있다.

 

실행창에서 아래와 같이 입력

cluster log /g /node:호스트명

 

참고

http://blogs.msdn.com/b/clustering/archive/2008/09/24/8962934.aspx

 

끝.

728x90
728x90

특정 VHD 사이즈가 대량으로 늘어서 찾아보고 정리 합니다.

사용전 필요 툴

sdelete 다운로드


1. diskpart 실행

   select vdisk file="e:\ex.vhd"

   attach vdisk


2. sdelete -z g: 


3. diskpart 실행

  select vdisk file="e:\ex.vhd"

  detach vdisk

  compact vdisk


실행 전 124.5G

실행 후 33.9G


실제 작업 화면

E:\htest\htest-ex>diskpart


Microsoft DiskPart 버전 6.3.9600


Copyright (C) 1999-2013 Microsoft Corporation.

컴퓨터: SJ-TS1


DISKPART> select vdisk file="E:\htest\htest-ex\hex.vhd"


DiskPart가 가상 디스크 파일을 선택했습니다.


DISKPART> attach vdisk


  100 퍼센트 완료


DiskPart가 가상 디스크 파일을 연결했습니다.


DISKPART>

E:\htest\htest-ex>sdelete -z g:


SDelete - Secure Delete v1.61

Copyright (C) 1999-2012 Mark Russinovich

Sysinternals - www.sysinternals.com


SDelete is set for 1 pass.

Free space cleaned on G:\

1 drives zapped



E:\htest\htest-ex>diskpart


Microsoft DiskPart 버전 6.3.9600


Copyright (C) 1999-2013 Microsoft Corporation.

컴퓨터: SJ-TS1


DISKPART> select vdisk file="E:\htest\htest-ex\hex.vhd"


DiskPart가 가상 디스크 파일을 선택했습니다.


DISKPART> detach vdisk


DiskPart가 가상 디스크 파일을 분리했습니다.


DISKPART> compact vdisk


  100 퍼센트 완료


DiskPart가 가상 디스크 파일을 압축했습니다.


DISKPART>




728x90

+ Recent posts