Microsoft MVP성태의 닷넷 이야기
오류 유형: 517. docker에 설치한 MongoDB 서버로 연결이 안 되는 경우 [링크 복사], [링크+제목 복사],
조회: 25225
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

docker에 설치한 MongoDB 서버로 연결이 안 되는 경우

docker에 MongoDB를 설치한 경우,

C:\> docker pull mongo

// docker run -d -p 27017:27017/tcp --name mongodb_inst --rm -it mongo
// docker exec --name mongodb_inst /bin/bash

(저처럼) 무심코 ^^; 27017 포트로 연결을 시도하면 다음과 같은 오류 메시지를 보게 되는데요.

failed to connect to server [127.0.0.1:27017] on first connect
[MongoError: connect ECONNREFUSED 127.0.0.1:27017]

이유는, 포트 매핑이 어떻게 되어 있는지 확인해 보면 됩니다. ^^

C:\> docker container ls
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                      NAMES
cf00331fdcbd        mongo:latest        "docker-entrypoint.s…"   3 minutes ago       Up 3 minutes        0.0.0.0:32768->27017/tcp   mongo




윈도우용의 압축 파일을 해제한 경우의 서비스 구동 방법

// 콘솔 실행 시 (대상이 되는 dbpath, 아래의 예에서는 d:\mongo\db 디렉터리를 미리 생성)
               (기본 dbpath는 mongodb가 설치된 드라이브의 "\data\db"이므로, 아래의 예에서는 d:\data\db" 디렉터리 생성 후 dbpath 옵션 없이 수행 가능)
d:\mongodb\bin> mongod --dbpath=d:\mongo\db --logpath=d:\mongo\log.txt

// 서비스 등록 시
d:\mongodb\bin> mongod --dbpath=d:\mongo\db --logpath=d:\mongo\log.txt --install

// 서비스 제거
d:\mongodb\bin> mongod --remove

mongo.exe 클라이언트 실행 후 기본 명령어
[데이터베이스 생성]
> use mydb
switched to db mydb

[컬렉션 생성]
> db.createCollection("users")
{ "ok" : 1 }

[컬렉션 확인]
> show collections
users

[문서 삽입]
> db.users.insert({name: "kevin" })
WriteResult({ "nInserted" : 1 })

> db.users.insert({name: "anders", age: 40})
WriteResult({ "nInserted" : 1 })

[문서 찾기]
> db.users.find()
{ "_id" : ObjectId("60f55e6772f24083840d4af6"), "name" : "kevin" }
{ "_id" : ObjectId("60f55ea172f24083840d4af7"), "name" : "anders", "age" : 40 }

// ObjectId: 문서 추가 시 _id 필드를 지정하지 않은 경우 default 값 체계
//           12바이트 - 타임스탬프(4바이트): 1970년 1월 1일 이후 초 단위로 시작한 값 (Sunday, 7 February 2106 06:28:16 GMT까지 표현할 수 있다고.)
//                     장비 식별자(3바이트), 프로세스 ID(2바이트), 카운터(3바이트)

[MongoDB 종료]
> use admin
switched to db admin
> db.shutdownServer()
server should be down...

// 공식 참조 문서
; https://docs.mongodb.com/manual/reference/

NoSQL 데이터베이스 타입
 - 데이터 모델 설계 방식
    1) 문서(Document) 모델: MongoDB,...
    2) 키-값(Key-value) 모델
    3) 칼럼(Column) 모델
    4) 그래프(Graph) 모델





오랜만에 이미지로부터 재실행한 mongodb가 구동이 안 되는데,

$ docker run --rm -it -p 27017:27017/tcp --name mongodb_inst -it mongo /bin/bash
WARNING: MongoDB 5.0+ requires a CPU with AVX support, and your current system does not appear to have that!
  see https://jira.mongodb.org/browse/SERVER-54407
  see also https://www.mongodb.com/community/forums/t/mongodb-5-0-cpu-intel-g4650-compatibility/116610/2
  see also https://github.com/docker-library/mongo/issues/485#issuecomment-891991814

오호~~~ 5.0 버전부터는 AVX 명령어 셋을 구현한 CPU가 필수적이라고 합니다. 그 와중에, 응용 프로그램을 시작하지도 못하면서 왜 저걸 ERROR가 아닌 WARNING 레벨로 처리한 것인지 궁금하군요. ^^;

어쨌든 테스트 환경의 CPU를 보면,

$ lscpu
Architecture:             x86_64
  CPU op-mode(s):         32-bit, 64-bit
  Address sizes:          40 bits physical, 48 bits virtual
  Byte Order:             Little Endian
CPU(s):                   20
  On-line CPU(s) list:    0-19
Vendor ID:                GenuineIntel
  Model name:             QEMU Virtual CPU version 2.5+
    CPU family:           15
    Model:                107
    Thread(s) per core:   1
    Core(s) per socket:   20
    Socket(s):            1
    Stepping:             1
    BogoMIPS:             5599.99
    Flags:                fpu de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush mmx fxsr sse sse2 ht syscall nx lm constant_tsc nopl xtopology cpuid tsc_known_freq pni ssse3 cx16 sse4_1 sse4_2 x2apic popcnt a
                          es hypervisor lahf_lm cpuid_fault pti
Virtualization features:  
  Hypervisor vendor:      KVM
  Virtualization type:    full
Caches (sum of all):      
  L1d:                    640 KiB (20 instances)
  L1i:                    640 KiB (20 instances)
  L2:                     80 MiB (20 instances)
  L3:                     16 MiB (1 instance)
NUMA:                     
  NUMA node(s):           1
  NUMA node0 CPU(s):      0-19
Vulnerabilities:          
  Gather data sampling:   Not affected
  Itlb multihit:          KVM: Mitigation: VMX unsupported
  L1tf:                   Mitigation; PTE Inversion
  Mds:                    Vulnerable: Clear CPU buffers attempted, no microcode; SMT Host state unknown
  Meltdown:               Mitigation; PTI
  Mmio stale data:        Unknown: No mitigations
  Reg file data sampling: Not affected
  Retbleed:               Not affected
  Spec rstack overflow:   Not affected
  Spec store bypass:      Vulnerable
  Spectre v1:             Mitigation; usercopy/swapgs barriers and __user pointer sanitization
  Spectre v2:             Mitigation; Retpolines; STIBP disabled; RSB filling; PBRSB-eIBRS Not affected; BHI Retpoline
  Srbds:                  Not affected
  Tsx async abort:        Not affected

가상 환경인데다 "QEMU Virtual CPU version 2.5+" 가상 CPU가 배정돼 있습니다. 이런 경우, 가상 환경의 CPU 구성을 AVX 가능한 설정으로 바꾸든가, 아니면 소프트웨어를 AVX에 제약 없는 버전으로 써야 합니다. 가령, 후자를 선택했다면 mongodb 이미지를 4.4.6 정도로 낮춰서 쓰면 됩니다. (검색해 보면 4.4.18까지 AVX 없이 구현돼 있다고 하는데, 실제로 해보면 4.4.18 역시 오류가 발생했습니다.)

$ docker run -d -p 27017:27017/tcp --restart=always --name mongodb_inst -it mongo:4.4.6




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







[최초 등록일: ]
[최종 수정일: 10/22/2025]

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

비밀번호

댓글 작성자
 




... 151  152  153  154  155  156  157  158  159  160  [161]  162  163  164  165  ...
NoWriterDateCnt.TitleFile(s)
1140정성태10/6/201133574.NET Framework: 242. 닷넷 개발자 입장에서 이해해 보는 자바의 서블릿, JSP
1138정성태10/1/201152458Java: 11. 웹 로직에서 MS-SQL 서버 연결 [2]
1137정성태9/30/201135689Java: 10. 닷넷 개발자가 설치해 본 Oracle WebLogic Server - 설치 및 기본 도메인 구성
1136정성태9/29/201131617개발 환경 구성: 131. Visual Studio - ASP.NET의 Code-behind처럼 cs 파일을 그룹핑하는 매크로 함수 [2]파일 다운로드1
1135정성태9/29/201128533오류 유형: 138. TF10216: Team Foundation services are currently unavailable
1134정성태9/27/201136360.NET Framework: 241. C# 5.0에 새로 추가된 Caller Info 특성 [5]
1133정성태9/25/201139934VC++: 54. C++로 만든 WinRT 프로그램 [2]
1132정성태9/24/201179879Java: 9. 자바의 keytool.exe 사용법과 Tomcat의 SSL 통신 설정
1131정성태9/23/201135770Java: 8. 닷넷 개발자가 구현해 본 자바 웹 서비스 (2)
1130정성태9/23/201143842Java: 7. 닷넷 개발자가 구현해 본 자바 웹 서비스 (1)파일 다운로드2
1129정성태9/22/201135255개발 환경 구성: 130. Hyper-V에 MS-DOS VM 만드는 방법 - MSDN 구독자 대상 [3]
1128정성태9/20/201135684오류 유형: 137. KB2449742 보안 업데이트로 인한 충돌 문제 해결 - 두 번째 이야기
1127정성태9/19/201138915Java: 6. Java에서 MySQL 사용 [2]
1126정성태9/18/201134268Math: 3. "유클리드 호제법"과 "Bezout's identity" 구현 코드(C#)파일 다운로드1
1125정성태9/17/201132072Windows: 54. Windows 8 개발자 Preview를 사용해 보고... [2]
1124정성태9/17/201131844.NET Framework: 240. System.Collections.ArrayList가 .NET 4.5에서 지원이 안된다??? [2]
1123정성태9/17/201171971Windows: 53. 2가지 모드의 Internet Explorer 10과 ActiveX [6]
1122정성태9/16/201138933Windows: 52. 새롭게 지원되는 WinRT 응용 프로그램 [7]
1121정성태9/12/201135596Java: 5. WTP 내에서 서블릿을 실행하는 환경
1120정성태9/11/201134589.NET Framework: 239. IHttpHandler.IsReusable 속성 이야기파일 다운로드1
1119정성태9/11/201132536Java: 4. 이클립스에 WTP SDK가 설치되지 않는다면? [2]
1118정성태9/11/201145288Java: 3. 이클립스에서 서블릿 디버깅하는 방법 [4]
1117정성태9/9/201131993제니퍼 .NET: 17. 제니퍼 닷넷 적용 사례 (2) - 웹 애플리케이션 hang의 원인을 알려주다.
1116정성태9/8/201162844Java: 2. 자바에서 "Microsoft SQL Server JDBC Driver" 사용하는 방법
1115정성태9/4/201136598Java: 1. 닷넷 개발자가 처음 실습해 본 서블릿
1114정성태9/4/201141236Math: 2. "Zhang Suen 알고리즘(세선화, Thinning/Skeletonization)"의 C# 버전 [4]파일 다운로드1
... 151  152  153  154  155  156  157  158  159  160  [161]  162  163  164  165  ...