성태의 닷넷 이야기
홈 주인
모아 놓은 자료
프로그래밍
질문/답변
사용자 관리
사용자
메뉴
아티클
외부 아티클
유용한 코드
온라인 기능
MathJax 입력기
최근 덧글
[정성태] VT sequences to "CONOUT$" vs. STD_O...
[정성태] NetCoreDbg is a managed code debugg...
[정성태] Evaluating tail call elimination in...
[정성태] What’s new in System.Text.Json in ....
[정성태] What's new in .NET 9: Cryptography ...
[정성태] 아... 제시해 주신 "https://akrzemi1.wordp...
[정성태] 다시 질문을 정리할 필요가 있을 것 같습니다. 제가 본문에...
[이승준] 완전히 잘못 짚었습니다. 댓글 지우고 싶네요. 검색을 해보...
[정성태] 우선 답글 감사합니다. ^^ 그런데, 사실 저 예제는 (g...
[이승준] 수정이 안되어서... byteArray는 BYTE* 타입입니다...
글쓰기
제목
이름
암호
전자우편
HTML
홈페이지
유형
제니퍼 .NET
닷넷
COM 개체 관련
스크립트
VC++
VS.NET IDE
Windows
Team Foundation Server
디버깅 기술
오류 유형
개발 환경 구성
웹
기타
Linux
Java
DDK
Math
Phone
Graphics
사물인터넷
부모글 보이기/감추기
내용
<div style='display: inline'> <h1 style='font-family: Malgun Gothic, Consolas; font-size: 20pt; color: #006699; text-align: center; font-weight: bold'>ORA-28000: the account is locked</h1> <p> 테스트 머신에서 이런 오류가 발생하는군요. ^^;<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > Server Error in '/' Application. ORA-28000: the account is locked Description: An unhandled exception occurred during the execution of the current web request. Please review the stack trace for more information about the error and where it originated in the code. Exception Details: Oracle.ManagedDataAccess.Client.OracleException: ORA-28000: the account is locked Source Error: An unhandled exception was generated during the execution of the current web request. Information regarding the origin and location of the exception can be identified using the exception stack trace below. Stack Trace: [OracleException (0x80004005): ORA-28000: the account is locked] OracleInternal.ConnectionPool.PoolManager`3.Get(ConnectionString csWithDiffOrNewPwd, Boolean bGetForApp, String affinityInstanceName, Boolean bForceMatch) +4833 OracleInternal.ConnectionPool.OraclePoolManager.Get(ConnectionString csWithNewPassword, Boolean bGetForApp, String affinityInstanceName, Boolean bForceMatch) +1115 OracleInternal.ConnectionPool.OracleConnectionDispenser`3.Get(ConnectionString cs, PM conPM, ConnectionString pmCS, SecureString securedPassword, SecureString securedProxyPassword) +1297 Oracle.ManagedDataAccess.Client.OracleConnection.Open() +3344 ...[생략]... </pre> <br /> <a target='tab' href='https://www.sysnet.pe.kr/2/0/1316#ora28000'>예전에도 설명했듯이</a>, 실제로 해당 Oracle DB에 접속해 로그인을 (연결 문자열의 계정이 hr이라고 가정) 하면,<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > # <span style='color: blue; font-weight: bold'>sqlplus</span> SQL*Plus: Release 11.2.0.2.0 Production on Wed Jan 3 05:45:57 2024 Copyright (c) 1982, 2011, Oracle. All rights reserved. Enter user-name: <span style='color: blue; font-weight: bold'>hr</span> Enter password: ERROR: <span style='color: blue; font-weight: bold'>ORA-28000: the account is locked</span>9 </pre> <br /> ORA-28000 오류가 발생합니다. 자, 그럼 이 문제를 해결하기 위해 system 계정으로 로그인하고, (<a target='tab' href='https://www.sysnet.pe.kr/2/0/1316#ora28000'>그때는 sqlplus로 로그인이 안 됐었는데</a>, 이제는 잘 되는군요. ^^;)<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > # <span style='color: blue; font-weight: bold'>sqlplus</span> SQL*Plus: Release 11.2.0.2.0 Production on Wed Jan 3 05:52:44 2024 Copyright (c) 1982, 2011, Oracle. All rights reserved. Enter user-name: <span style='color: blue; font-weight: bold'>system</span> Enter password: Connected to: Oracle Database 11g Express Edition Release 11.2.0.2.0 - 64bit Production SQL> </pre> <br /> 이후, ALTER USER 명령어를 실행해 주면 끝!<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > // 사용자 hr, 암호는 testpw라고 가정 SQL> <span style='color: blue; font-weight: bold'>ALTER USER hr IDENTIFIED BY testpw ACCOUNT UNLOCK;</span> User altered. </pre> <br /> <hr style='width: 50%' /><br /> <br /> 그런데, 계정이 왜 잠기는지 모르겠군요. ^^; 혹시나 싶어, (hr이 속한) DEFAULT 프로파일에 대해 다음의 설정을 추가했습니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > # <span style='color: blue; font-weight: bold'>su - oracle</span> oracle@4e072ccfdbf6:~$ <span style='color: blue; font-weight: bold'>sqlplus</span> SQL*Plus: Release 11.2.0.2.0 Production on Wed Jan 3 06:48:33 2024 Copyright (c) 1982, 2011, Oracle. All rights reserved. Enter user-name: <span style='color: blue; font-weight: bold'>system</span> Enter password: (기본 암호: oracle) Connected to: Oracle Database 11g Express Edition Release 11.2.0.2.0 - 64bit Production SQL> </pre> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > SQL> <span style='color: blue; font-weight: bold'>select username, profile, expiry_date from dba_users;</span> USERNAME PROFILE EXPIRY_DA ------------------------------ ------------------------------ --------- SYS DEFAULT SYSTEM DEFAULT ANONYMOUS DEFAULT <span style='color: blue; font-weight: bold'>HR DEFAULT</span> ...[생략]... </pre> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > // 혹은 SQL> <span style='color: blue; font-weight: bold'>select username, profile, expiry_date from dba_users where username='HR';</span> USERNAME PROFILE EXPIRY_DA ------------------------------ ------------------------------ --------- <span style='color: blue; font-weight: bold'>HR DEFAULT</span> </pre> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > ALTER PROFILE DEFAULT LIMIT PASSWORD_LIFE_TIME UNLIMITED; ALTER PROFILE DEFAULT LIMIT PASSWORD_LOCK_TIME UNLIMITED; ALTER PROFILE DEFAULT LIMIT PASSWORD_GRACE_TIME UNLIMITED; ALTER PROFILE DEFAULT LIMIT FAILED_LOGIN_ATTEMPTS UNLIMITED; // 확인 // select profile, RESOURCE_NAME, LIMIT from dba_profiles where RESOURCE_NAME='PASSWORD_LIFE_TIME'; </pre> <br /> <hr style='width: 50%' /><br /> <br /> 참고로, 최초 컨테이너를 실행 시,<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > docker run --rm -it --name=DB-oraclexe11g -p 1521:1521 <a target='tab' href='https://www.sysnet.pe.kr/2/0/12191'>oracleinanutshell/oracle-xe-11g:latest</a> </pre> <br /> docker exec로 접근하면 root 계정에는 아무런 설정이 없어 sqlplus도 직접 실행해야 하고, 기타 설정들도 추가해야 합니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > # <span style='color: blue; font-weight: bold'>/u01/app/oracle/product/11.2.0/xe/bin/sqlplus</span> Error 6 initializing SQL*Plus SP2-0667: Message file sp1<lang>.msb not found SP2-0750: You may need to set ORACLE_HOME to your Oracle software directory # <span style='color: blue; font-weight: bold'>export ORACLE_HOME=/u01/app/oracle/product/11.2.0/xe</span> # <span style='color: blue; font-weight: bold'>/u01/app/oracle/product/11.2.0/xe/bin/sqlplus</span> SQL*Plus: Release 11.2.0.2.0 Production on Wed Jan 3 06:45:58 2024 Copyright (c) 1982, 2011, Oracle. All rights reserved. Enter user-name: system Enter password: ERROR: ORA-12162: TNS:net service name is incorrectly specified </pre> <br /> 그러느니, 그냥 oracle 사용자로 바꿔서 접속하시면 편안하게 실습할 수 있습니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > # <span style='color: blue; font-weight: bold'>su - oracle</span> oracle@4e072ccfdbf6:~$ <span style='color: blue; font-weight: bold'>sqlplus</span> SQL*Plus: Release 11.2.0.2.0 Production on Wed Jan 3 06:48:33 2024 Copyright (c) 1982, 2011, Oracle. All rights reserved. Enter user-name: <span style='color: blue; font-weight: bold'>system</span> Enter password: (기본 암호: oracle) Connected to: Oracle Database 11g Express Edition Release 11.2.0.2.0 - 64bit Production SQL> </pre> <br /> 기본적으로는 hr 계정이 비활성 상태이므로, 명시적으로 해제를 해야합니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > SQL> <span style='color: blue; font-weight: bold'>ALTER USER hr IDENTIFIED BY hr ACCOUNT UNLOCK;</span> </pre> </p><br /> <br /> <br /><hr /><span style='color: Maroon'>[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]</span> </div>
첨부파일
스팸 방지용 인증 번호
7316
(왼쪽의 숫자를 입력해야 합니다.)