[英]command terminated with non-zero exit code: Error executing in Docker Container: 137 (Mongo Manager)
根據本指南:
https://docs.opsmanager.mongodb.com/current/tutorial/install-simple-test-deployment/
我試圖在OpenShift中運行MongoDB和MongoDB Ops Manager。 我已經對MongoDB和MongoDB Ops Manager進行了對接 ,並且MongoDB正在成功運行偵聽端口27017和所有接口:
# network interfaces
net:
port: 27017
bindIp: 0.0.0.0
我還設法初始化 MongoDB Ops Manager意味着以下步驟成功完成(包括連接到我的mongodb實例):
Generating new Ops Manager private key...
Starting pre-flight checks
Successfully finished pre-flight checks
Migrate Ops Manager data
Running migrations...[ OK ]
Start Ops Manager server
Instance 0 starting..................[ OK ]
tput: No value for $TERM and no -T specified
Starting pre-flight checks
Successfully finished pre-flight checks
Start Backup Daemon...[ OK ]
但隨后它突然失敗了:
tail -f /opt/mongodb/mms/logs/mms0.log
...
2019-04-25T14:30:42.616+0000 [main] INFO com.xgen.svc.mms.svc.ping.PingRequest$Observable [Observable.java.addObserver:19] - Registering observer: class com.xgen.svc.mms.svc.ping.TotalStorageCacheSvc
2019-04-25T14:30:42.618+0000 [main] INFO com.xgen.svc.mms.svc.ping.PingRequest$Observable [Observable.java.addObserver:19] - Registering observer: class com.xgen.svc.mms.svc.ping.NDSAutoScalingIngestionSvc
2019-04-25T14:31:00.536+0000 [main] INFO com.xgen.svc.core.ServerMain [ServerMain.java.setUpProxyServer:620] - Started queryable backup proxy server on port 25999
2019-04-25T14:31:00.537+0000 [ProxyServer-25999] INFO backup.jobs.queryable.ProxyServer.25999 [ProxyServer.java.run:96] - Waiting for Proxy Server PEM File to be specified in the configuration
2019-04-25T14:31:00.559+0000 [main] INFO com.xgen.svc.core.ServerMain [ServerMain.java.start:537] - Started mms at build ed64653d5f@on-prem-4.0 in: 51476 (ms)
command terminated with non-zero exit code: Error executing in Docker Container: 137
並且啟用了DEBUG級別的其他日志記錄:
2019-04-27T13:46:35.035+0000 [job-consumer-214366356] DEBUG org.mongodb.driver.protocol.command [SLF4JLogger.java.debug:56] - Sending command {findandmodify : BsonString{value='data.jobsProcessor'}} to database mmsdbjobs on connection [connectionId{localValue:13, serverValue:31}] to server mongo-db:27017
2019-04-27T13:46:35.036+0000 [job-consumer-214366356] DEBUG org.mongodb.driver.protocol.command [SLF4JLogger.java.debug:56] - Command execution completed
2019-04-27T13:46:35.476+0000 [mms_QuartzSchedulerThread] DEBUG org.quartz.simpl.PropertySettingJobFactory [SimpleJobFactory.java.newJob:51] - Producing instance of Job 'DEFAULT.dbRollupSchedulerJob', class=com.xgen.svc.core.svc.cron.SimpleJob
2019-04-27T13:46:35.477+0000 [mms_QuartzSchedulerThread] DEBUG org.quartz.core.QuartzSchedulerThread [QuartzSchedulerThread.java.run:291] - batch acquisition of 1 triggers
2019-04-27T13:46:35.477+0000 [mms_Worker-31] DEBUG org.quartz.core.JobRunShell [JobRunShell.java.run:201] - Calling execute on job DEFAULT.dbRollupSchedulerJob
2019-04-27T13:46:35.478+0000 [mms_Worker-31] DEBUG org.mongodb.driver.protocol.command [SLF4JLogger.java.debug:56] - Sending command {count : BsonString{value='config.customers'}} todatabase mmsdbconfig on connection [connectionId{localValue:13, serverValue:31}] to server mongo-db:27017
2019-04-27T13:46:35.480+0000 [mms_Worker-31] DEBUG org.mongodb.driver.protocol.command [SLF4JLogger.java.debug:56] - Command execution completed
2019-04-27T13:46:35.481+0000 [mms_Worker-31] DEBUG com.xgen.svc.core.svc.cron.CronJob [CronJob.java.canProceed:47] - Not proceeding with CronJob dbRollupScheduler. No Projects.
command terminated with non-zero exit code: Error executing in Docker Container: 137
但對導致Docker容器終止的原因沒什么幫助。
可能導致這種情況的任何想法?
請注意,在我的本地ubuntu盒(具有8 GB RAM的機器)上使用普通docker時,它工作正常。
編輯:
基於以下建議,我還嘗試在Mongo Manager的部署配置中設置以下資源:
kind: DeploymentConfig
metadata:
name: ${NAME}
spec:
replicas: 1
selector:
app: ${NAME}
strategy:
type: Recreate
...
containers:
- name: ${NAME}
image: ${IMAGE}
ports:
- containerPort: 8080
resources:
limits:
cpu: 8
memory: 15Gi
requests:
cpu: 8
memory: 15Gi
但結果仍然相同。
和Dockerfile
FROM centos:latest
RUN yum update -y && \
yum install -y openssl iproute nano net-tools
COPY run.sh /
RUN chmod 750 /run.sh
ENTRYPOINT ["/run.sh"]
和run.sh
是:
#!/bin/bash
export TERM="xterm"
curl -k https://downloads.mongodb.com/on-prem-mms/rpm/mongodb-mms-4.0.10.50461.20190403T1841Z-1.x86_64.rpm -o tmp/mongodb-mms-4.0.10.50461.20190403T1841Z-1.x86_64.rpm
cd /tmp \
&& rpm -ivh mongodb-mms-4.0.10.50461.20190403T1841Z-1.x86_64.rpm \
&& rm mongodb-mms-4.0.10.50461.20190403T1841Z-1.x86_64.rpm
cp /opt/configmap/conf-mms/conf-mms.properties /opt/mongodb/mms/conf/
cp /opt/configmap/mms/mms.conf /opt/mongodb/mms/conf/
cp /opt/configmap/logback/logback.xml /opt/mongodb/mms/conf/
chown -R mongodb-mms:mongodb-mms /opt/mongodb/mms/
/bin/bash /opt/mongodb/mms/bin/mongodb-mms start
從configmaps掛載/ opt / configmap中的文件的位置。
我認為您最好按照文檔安裝MongoDB Enterprise Kubernetes Operator ,然后通過Kubernetes安裝MongoDB 。
這是在OpenShift中安裝的更現代和首選的方法。 這應該考慮到您問題中概述的大部分復雜性。
由於沒有關於如何在OpenShift中成功停靠和部署Mongo Ops Manager的建議/答案,做一個簡單的非容器安裝似乎是目前唯一的解決方案,例如:
https://docs.opsmanager.mongodb.com/current/tutorial/install-simple-test-deployment/
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.