Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

db2 - Password validation for user db2inst1 failed with rc = -2146500508

잘 쓰고 있던 db2 docker 컨테이너가,

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

어느 순간부터 Open 메서드에서 이렇게 SQL10007 오류 메시지가 발생합니다.

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() in D:\test\WebSiteTest4\DB2SQLTest.aspx.cs:line 495
   at WebSiteTest.Page_Load(Object sender, EventArgs e) in D:\test\WebSiteTest4\DB2SQLTest.aspx.cs:line 103

이와 함께 컨테이너 측 로그에는 다음과 같은 식의 메시지가 나오는데요,

2022-10-21-01.56.45.801683+000 I220891510E469        LEVEL: Warning,
PID     : 15667                TID : 140031876392704 PROC : db2sysc 0,
INSTANCE: db2inst1             NODE : 000            DB   : TESTDB,
APPHDL  : 0-198,
HOSTNAME: 40880c208891,
EDUID   : 23                   EDUNAME: db2agent (TESTDB) 0,
FUNCTION: DB2 UDB, bsu security, sqlexLogPluginMessage, probe:20,
DATA #1 : String with size, 67 bytes,
Password validation for user db2inst1 failed with rc = -2146500508,
,
2022-10-21-01.56.45.801860+000 I220891980E538        LEVEL: Warning,
PID     : 15667                TID : 140031876392704 PROC : db2sysc 0,
INSTANCE: db2inst1             NODE : 000            DB   : TESTDB,
APPHDL  : 0-198,
HOSTNAME: 40880c208891,
EDUID   : 23                   EDUNAME: db2agent (TESTDB) 0,
FUNCTION: DB2 UDB, bsu security, sqlexSlsSystemAuthenticate, probe:150,
MESSAGE : Failing connection IP address: 192.168.100.30,
TA #1 : String, 16 bytes,
application id: ,
DATA #2 : String with size, 31 bytes,
192.168.100.30.57114.221021015645,

Password validation에 실패했다고 합니다. 확인을 위해 db2 명령어 shell로 접속해 계정을 확인해 보면,

# export DB2INSTANCE=db2inst1
# /opt/ibm/db2/V11.5/bin/db2
db2 => CONNECT TO TESTDB USER db2inst1 USING testpw
SQL30082N  Security processing failed with reason "1" ("PASSWORD EXPIRED").  
SQLSTATE=08001

보는 바와 같이 EXPIRED라고 합니다. ^^ 그래서 변경하려고 하는데,

// https://www.ibm.com/docs/en/db2/10.5?topic=details-maintaining-password-information

db2 => CONNECT TO TESTDB USER db2inst1 USING testpw NEW dsfasvdfvas CONFIRM dsfasvdfvas
SQL30083N  Attempt to change password for user id "db2inst1" failed with security reason "24" ("USERNAME AND/OR PASSWORD INVALID").  SQLSTATE=08001

오류가 발생하는군요. ^^ 이건 DB2의 계정 정보가 리눅스와 연동하기 때문이라고.

Error while changing password DB2 Community Edition SQL30083N
; https://stackoverflow.com/questions/56023609/error-while-changing-password-db2-community-edition-sql30083n

따라서, docker bash 환경에서 해당 계정의 암호를 변경하는 식으로 처리하면 됩니다.

# su - db2inst1
$ passwd

// 또는

# passwd db2inst1




그런데 테스트 컨테이너의 계정이 1년마다 만료되는 것이 여간 귀찮은 일이 아닐 수 없습니다. 이게 싫다면 chage 명령을 이용해 암호 만료 시간을 변경할 수 있습니다.
# chage -I -1 -m 0 -M 99999 -E -1 db2inst1

#  chage -l db2inst1
Last password change                                    : Apr 20, 2023
Password expires                                        : never
Password inactive                                       : never
Account expires                                         : never
Minimum number of days between password change          : 0
Maximum number of days between password change          : 99999
Number of days of warning before password expires       : 7




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 4/20/2023]

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

비밀번호

댓글 작성자
 




... 91  92  93  94  95  96  97  98  99  100  101  102  103  [104]  105  ...
NoWriterDateCnt.TitleFile(s)
11325정성태10/14/201719233.NET Framework: 689. CLR 4.0 환경에서 DLL 모듈의 로드 주소(Base address) 알아내는 방법
11324정성태10/13/201720821디버깅 기술: 101. windbg - "*** WARNING: Unable to verify checksum for" 경고 없애는 방법
11322정성태10/13/201718256디버깅 기술: 100. windbg - .NET 4.0 응용 프로그램의 Main 메서드에 Breakpoint 걸기
11321정성태10/11/201719772.NET Framework: 688. NGen 모듈과 .NET Profiler
11320정성태10/11/201720550.NET Framework: 687. COR_PRF_USE_PROFILE_IMAGES 옵션과 NGen의 "profiler-enhanced images" [1]
11319정성태10/11/201728153.NET Framework: 686. C# - string 배열을 담은 구조체를 직렬화하는 방법
11318정성태10/7/201720911VS.NET IDE: 122. 비주얼 스튜디오에서 관리자 권한을 요구하는 C# 콘솔 프로그램 제작 [1]
11317정성태10/4/201726077VC++: 120. std::copy 등의 함수 사용 시 _SCL_SECURE_NO_WARNINGS 에러 발생
11316정성태9/30/201724126디버깅 기술: 99. (닷넷) 프로세스(EXE)에 디버거가 연결되어 있는지 아는 방법 [4]
11315정성태9/29/201740207기타: 68. "시작하세요! C# 6.0 프로그래밍: 기본 문법부터 실전 예제까지" 구매하신 분들을 위한 C# 7.0/7.1 추가 문법 PDF [8]
11314정성태9/28/201721969디버깅 기술: 98. windbg - 덤프 파일로부터 닷넷 버전 확인하는 방법
11313정성태9/25/201719283디버깅 기술: 97. windbg - 메모리 덤프로부터 DateTime 형식의 값을 알아내는 방법파일 다운로드1
11312정성태9/25/201722312.NET Framework: 685. C# - 구조체(값 형식)의 필드를 리플렉션을 이용해 값을 바꾸는 방법파일 다운로드1
11311정성태9/20/201716823.NET Framework: 684. System.Diagnostics.Process 객체의 명시적인 해제 권장
11310정성태9/19/201720233.NET Framework: 683. WPF의 Window 객체를 생성했는데 GC 수집 대상이 안 되는 이유 [3]
11309정성태9/13/201718365개발 환경 구성: 335. Octave의 명령 창에서 실행한 결과를 복사하는 방법
11308정성태9/13/201719411VS.NET IDE: 121. 비주얼 스튜디오에서 일부 텍스트 파일을 무조건 메모장으로만 여는 문제파일 다운로드1
11307정성태9/13/201721930오류 유형: 421. System.Runtime.InteropServices.SEHException - 0x80004005
11306정성태9/12/201719978.NET Framework: 682. 아웃룩 사용자를 위한 중국어 스팸 필터 Add-in
11305정성태9/12/201721493개발 환경 구성: 334. 기존 프로젝트를 Visual Studio를 이용해 Github의 신규 생성된 repo에 올리는 방법 [1]
11304정성태9/11/201718630개발 환경 구성: 333. 3ds Max를 Hyper-V VM에서 실행하는 방법
11303정성태9/11/201721922개발 환경 구성: 332. Inno Setup 파일의 관리자 권한을 제거하는 방법
11302정성태9/11/201718148개발 환경 구성: 331. SQL Server Express를 위한 방화벽 설정
11301정성태9/11/201717050오류 유형: 420. SQL Server Express 연결 오류 - A network-related or instance-specific error occurred while establishing a connection to SQL Server.
11300정성태9/10/201720885.NET Framework: 681. dotnet.exe - run, exec, build, restore, publish 차이점 [3]
11299정성태9/9/201719641개발 환경 구성: 330. Hyper-V VM의 Internal Network를 Private 유형으로 만드는 방법
... 91  92  93  94  95  96  97  98  99  100  101  102  103  [104]  105  ...