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

SQL10007N Message "-1390" could not be retrieved. Reason code: "3".

이번엔 docker로 ibmcom/db2 인스턴스를 실행했는데,

docker - ibmcom/db2 컨테이너 실행
; https://www.sysnet.pe.kr/2/0/13009

$ docker run -itd --name mydb2 --restart=always --privileged=true -p 50000:50000 -e LICENSE=accept -e DB2INST1_PASSWORD=testusr -e DBNAME=testdb -v db2db_shared:/database ibmcom/db2:11.5.7.0

접속이 안 됩니다.

DB2: IBM.Data.DB2.DB2Exception (0x80004005): ERROR [08001] [IBM] SQL10007N Message "0" could not be retrieved.  Reason code: "3".

   at IBM.Data.DB2.DB2ConnPool.Open(DB2Connection connection, String& szConnectionString, DB2ConnSettings& ppSettings, Object& ppConn)
   at IBM.Data.DB2.DB2Connection.Open()
   at WebSiteTest.DB2Test()
   at WebSiteTest.Page_Load(Object sender, EventArgs e)

직접 컨테이너에 들어가 db2 CLI로 들어가도,

# /opt/ibm/db2/V11.5/bin/db2
SQL10007N Message "-1390" could not be retrieved.  Reason code: "3".

역시나 오류가 발생합니다. (다양한 원인이 있을 수 있지만) 이런 경우 분명한 것은 DB2 인스턴스가 실행되지 않았기 때문입니다. 따라서, -d 옵션을 사용하지 말고 컨테이너가 실행 시 출력하는 메시지를 잘 봐야 합니다.

$ docker run -it --name mydb2 --restart=always --privileged=true -p 50000:50000 -e LICENSE=accept -e DB2INST1_PASSWORD=testusr -e DBNAME=testdb -v db2db_shared:/database ibmcom/db2:11.5.7.0 /bin/bash
(*) Restoring global registry file ...
(*) Previous setup has not been detected. Creating the users... 
(*) Creating users ...
useradd: warning: the home directory already exists.
Not copying any file from skel directory into it.
useradd: warning: the home directory already exists.
Not copying any file from skel directory into it.
(*) Preparing the environment before updating the instance ... 
(*) Fixing /etc/services file for DB2 ... 
(*) Fixing db2nodes file configuration ... 
rm: cannot remove 'sqllib/.ftok': Permission denied
db2ftok.C:87: Failed to generate seed, rc = 0x90000001.
SQL1652N  File I/O error occurred.
(*) Creating instance ... 
DBI1446I  The db2icrt command is running.


DB2 installation is being initialized.

 The instance home directory "/database/config/db2inst1" is invalid because it 
is not owned by the user "db2inst1". Change the ownership of the home directory 
to be owned by the instance user and its primary group.

A major error occurred during the execution that caused this program to 
terminate prematurely. If the problem persists, contact your technical service 
representative.

For more information see the DB2 installation log at "/tmp/db2icrt.log.810".
DBI1264E  This program failed. Errors encountered during execution were
      written to the installation log file. Program name:
      db2icrt. Log file name: /tmp/db2icrt.log.810.

Explanation: 

This message is returned when some processes and operations have failed.
Detailed information about the error was written to the log file.

User response: 

Contact IBM support to get assistance in resolving this issue. Keep the
log file intact as this file is an important reference for IBM support.


   Related information:
   Contacting IBM Software Support


(!) There was a problem configuring the instance. Copying over logs and traces to /database/config ...
mkdir: cannot create directory '/database/config/db2icrt': File exists


              _______   D B 2  S u p p o r t   ______


This program generates information about a DB2 server, including information
about its configuration and system environment. The output of this program
is stored in a file named 'db2support.zip'. If possible, run this program
while the problem is occurring.


For the most complete output, this utility should be invoked with root
authority. Users with more limited privileges on the system can run this tool,
however, some of the data collection actions will result in reduced reporting
and reduced output.

Output file is "/database/config/db2icrt/db2support.zip"
Time and date of this collection: 2025-11-10-07.16.53.437509

Starting collection on host 30aa29d9bf32
 Creating directory /database/config/db2icrt/DB2SUPPORT/30aa29d9bf32_IIH
Collecting resources group information
   The following file was not found or could not be executed during diagnostic
   data collection: /usr/bin/lssam
   The following file was not found or could not be executed during diagnostic
   data collection: /usr/bin/lsrsrc
   The following file was not found or could not be executed during diagnostic
   data collection: /usr/bin/lsrsrc
Collecting user identity information
Collecting current process information
Collecting active interprocess communications facilities information
Collecting system information
Collecting detailed data on system and hardware errors
   The following file was not found or could not be executed during diagnostic
   data collection: /usr/bin/errpt
Collecting registry contents
Collecting GPFS information
   The following file was not found or could not be executed during diagnostic
   data collection: /usr/lpp/mmfs/bin/gpfs.snap
Collecting configuration, log and trace information for RSCT
   The following file was not found or could not be executed during diagnostic
   data collection: /usr/bin/ctsnap
Collecting information about installed DB2 products
Collecting information about state of db2 instance
Collecting information about DB2 product prerequisites
Collecting /etc/services 
Collecting /tmp/db2icrt.log.810
Collection on host 30aa29d9bf32 completed
Compressing files in /database/config/db2icrt/DB2SUPPORT directory 
Collecting /database/config/db2icrt/db2support.log 
Collecting db2support.out 


db2support is now complete.
 An archive file has been produced: "/database/config/db2icrt/db2support.zip"

"15" warnings found during db2support collection

중간에 보면, "/database/config/db2inst1" 디렉터리를 "db2inst1" 사용자가 접근할 수 없어 문제가 발생했음을 알 수 있습니다. 즉 이런 경우가 바로 docker 볼륨 연결 시 권한 문제가 발생한 사례 중의 하나입니다.

실제로 볼륨 디렉터리의 권한을 확인하고,

$ docker volume inspect db2db_shared
[
    {
        "CreatedAt": "2025-09-29T13:54:07+09:00",
        "Driver": "local",
        "Labels": null,
        "Mountpoint": "/mnt/docker-data/docker/volumes/db2db_shared/_data",
        "Name": "db2db_shared",
        "Options": null,
        "Scope": "local"
    }
]

$ ls -l "/mnt/docker-data/docker/volumes/db2db_shared/_data"
ls: cannot access '/mnt/docker-data/docker/volumes/db2db_shared/_data': Permission denied

$ sudo ls -l "/mnt/docker-data/docker/volumes/db2db_shared/_data"
total 0
drwxr-xr-x 2 testusr testusr  66 Mar 18  2022 backup
drwxr-xr-x 7 testusr testusr 159 Nov 10 13:31 config
drwxr-xr-x 3 testusr testusr  30 Mar 18  2022 data
drwxr-xr-x 3 testusr testusr  30 Mar 18  2022 logs

저 사용자 권한을 DB2 container의 db2inst1 사용자로 맞춰야 하는데요,

// db2 컨테이너 내에서 실행한 결과

# id db2inst1
uid=1000(db2inst1) gid=1000(db2iadm1) groups=1000(db2iadm1)

따라서 docker 호스트 측의 볼륨 권한을 이렇게 변경하고,

$ sudo chown -R 1000:1000 /mnt/docker-data/docker/volumes/db2db_shared

docker run을 다시 실행해 주면 이제 정상적으로 db2 데이터베이스가 올라오게 됩니다.




혹시나 db2 인스턴스가 올라왔는데도 여전히 ERROR [08001] [IBM] SQL10007N Message "0" could not be retrieved. Reason code: "3". 오류가 계속 발생한다면? db2 접속 계정(id/pw)이 올바른지 확인해 보세요. ^^




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 11/12/2025]

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

비밀번호

댓글 작성자
 




... 121  122  123  124  125  126  127  128  129  130  131  [132]  133  134  135  ...
NoWriterDateCnt.TitleFile(s)
2874정성태2/26/201525205디버깅 기술: 71. windbg + 닷넷 디버깅 (2) - null 체크 패턴
2873정성태2/25/201543655.NET Framework: 501. FtpWebRequest 타입을 이용해 FTP 파일 업로드 [4]파일 다운로드1
2872정성태2/25/201527010디버깅 기술: 70. windbg + 닷넷 디버깅 (1) - 배열 인덱스 사용 패턴
2871정성태2/24/201530603개발 환경 구성: 258. 윈도우 8.1에서 방화벽과 함께 FTP 서버 여는 (하지만, 권장하지 않는) 방법 [1]
2870정성태2/24/201532312개발 환경 구성: 257. 윈도우 8.1에서 방화벽과 함께 FTP 서버 여는 방법
2869정성태2/23/201525543.NET Framework: 500. struct로 정의한 값 형식(Value Type)의 경우 Equals 재정의를 권장합니다.파일 다운로드1
2868정성태2/23/201530975VS.NET IDE: 97. Visual C++ 프로젝트 디버깅 시에 Step-Into(F11) 동작이 원치 않는 함수로 진입하는 것을 막는 방법 [2]
2867정성태2/23/201524309오류 유형: 273. File History - Failed to initiate user data backup (error 80070005)
2866정성태2/23/201526761오류 유형: 272. WAT080 : Failed to locate the Windows Azure SDK. Please make sure the Windows Azure SDK v2.1 is installed.
1868정성태2/20/201523851오류 유형: 271. The type '...' cannot be used as type parameter 'TContext' in the generic type or method 'System.ServiceModel.DomainServices.EntityFramework.LinqToEntitiesDomainService<T>
1866정성태2/20/201524601오류 유형: 270. "aspnet_regiis -i" 실행 시 0x00000006 오류 해결 방법
1865정성태2/20/201525963.NET Framework: 499. 특정 닷넷 프레임워크 버전 이후부터 제공되는 타입을 사용해야 한다면?
1864정성태2/18/201530732.NET Framework: 498. C#으로 간단하게 만들어 본 ASCII Art 프로그램 [2]파일 다운로드1
1862정성태2/18/201535338.NET Framework: 497. .NET Garbage Collection에 대한 정리 [6]
1861정성태2/18/201530712.NET Framework: 496. 마우스 커서가 놓인 지점의 문자열 얻는 방법 [1]파일 다운로드1
1860정성태2/18/201530530.NET Framework: 495. CorElementType의 요소 값 설명파일 다운로드1
1859정성태2/17/201531865Windows: 106. 컴퓨터를 재부팅하면 절전(Power Saver) 전원 모드로 돌아가는 경우
1858정성태2/16/201541201Windows: 105. 자동으로 로그아웃/잠김 화면 상태로 전환된다면? [2]
1857정성태2/16/201528046.NET Framework: 494. 값(struct) 형식의 제네릭(Generic) 타입이 박싱되는 경우의 메타데이터 토큰 값파일 다운로드1
1856정성태2/15/201526771.NET Framework: 493. TypeRef 메타테이블에 등록되는 타입의 조건파일 다운로드1
1855정성태2/10/201526680개발 환경 구성: 256. WebDAV Redirector - Sysinternals 폴더 연결 시 "The network path was not found" 오류 해결 방법
1854정성태2/10/201527716Windows: 104. 폴더는 삭제할 수 없지만, 그 하위 폴더/파일은 생성/삭제/변경하는 보안 설정
1853정성태2/6/201558635웹: 29. 여신금융협회 웹 사이트의 "Netscape 6.0은 지원하지 않습니다." 오류 메시지 [5]
1852정성태2/5/201529068.NET Framework: 492. .NET CLR Memory 성능 카운터의 의미파일 다운로드1
1851정성태2/5/201530896VC++: 88. 하룻밤의 꿈 - 인텔 하스웰의 TSX Instruction 지원 [3]
1850정성태2/4/201550259Windows: 103. 작업 관리자에서의 "Commit size"가 가리키는 메모리의 의미 [4]
... 121  122  123  124  125  126  127  128  129  130  131  [132]  133  134  135  ...