mongodb的dockerfile的编写

1. 官方镜像

docker run --name mongo -d --rm mongo

1.1 连接mongoDB 容器

使用--link参数,连接新建的mongo容器

docker run -it --link mongo:db alpine sh

进入alpine系统容器后,可以使用ping指令测试mongo容器的连通性

/ # ping db
PING db (172.17.0.4): 56 data bytes
64 bytes from 172.17.0.4: seq=0 ttl=64 time=0.106 ms
64 bytes from 172.17.0.4: seq=1 ttl=64 time=0.094 ms

1.2 使用mongo cli指令

docker run -it --link mongo:db --entrypoint mongo mongo --host db

2. 编写Dockerfile

2.1.准备环境

mkdir /data/docker/ubuntu/mongodb

touch Dockerfile run.sh set_mongodb_password.sh

2.2 Dockerfile 的内容为

FROM sshd:dockerfile
MAINTAINER from www.csdn.com/wanchaopeng by wanchaopeng (chaopeng16@163.com)

RUN \
  apt-get update && \
  apt-get install -y mongodb pwgen && \
  apt-get clean && \
  rm -rf /var/lib/apt/lists/*

#创建mongodb存放数据文件的文件夹
RUN mkdir -p /data/db
VOLUME /data/db

ENV AUTH yes

#添加脚本
ADD run.sh /run.sh
ADD set_mongodb_password.sh /set_mongodb_password.sh
RUN chmod 755 ./*.sh

EXPOSE 27017
EXPOSE 28017

CMD ["/run.sh"]

2.2 set_mongodb_password.sh的内容为

#!/bin/bash
#这脚本主要是用来设置数据库的用户名和密码

#判断是否设置过密码
if [ -f /.mongodb_password_set ]; then
	echo "MongoDB password already set!"
	exit 0
fi

/usr/bin/mongod --smallfiles --nojournal &

PASS=${MONGODB_PASS:-$(pwgen -s 12 1)}
_word=$( [ ${MONGODB_PASS} ] && echo "preset" || echo "random" )

RET=1
while [[ RET -ne 0 ]]; do
    echo "=> Waiting for confirmation of MongoDB service startup"
    sleep 5
    mongo admin --eval "help" >/dev/null 2>&1
    RET=$?
done

#通过docker logs + id 查看下面的输出
echo "=> Creating an admin user with a ${_word} password in MongoDB"
mongo admin --eval "db.addUser({user: 'admin', pwd: '$PASS', roles: [ 'userAdminAnyDatabase', 'dbAdminAnyDatabase' ]});"
mongo admin --eval "db.shutdownServer();"

echo "=> Done!"
touch /.mongodb_password_set

echo "========================================================================"
echo "You can now connect to this MongoDB server using:"
echo ""
echo "    mongo admin -u admin -p $PASS --host <host> --port <port>"
echo ""
echo "Please remember to change the above password as soon as possible!"
echo "========================================================================"

2.3 run.sh 的内容为

#!/bin/bash
if [ ! -f /.mongodb_password_set ]; then
	/set_mongodb_password.sh
fi

if [ "$AUTH" == "yes" ]; then
    export mongodb='/usr/bin/mongod --nojournal --auth --httpinterface --rest'
else
    export mongodb='/usr/bin/mongod --nojournal --httpinterface --rest'
fi

if [ ! -f /data/db/mongod.lock ]; then
    eval $mongodb
else
    export mongodb=$mongodb' --dbpath /data/db' 
    rm /data/db/mongod.lock
    mongod --dbpath /data/db --repair && eval $mongodb
fi

3.创建镜像

docker build -t mongodb:ubuntu .

4. 使用

4.1 启动后台容器并映射27017和28017的端口到本地

docker run -d -p 27017:27017 -p 28017:28017 mongodb:ubuntu


docker logs +id  #查看密码

4.2 指定密码

docker run -d -p 27017:27017 -p 28017:28017 -e MONGODB_PASS="mmxcard" mongodb:ubuntu

4.3 指定不设置密码

docker run -d -p 27017:27017 -p 28017:28017 -e AUTH=no mongodb:ubuntu

可以-v 参数来映射本地目录到容器

完成 !!!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 我可以提供一种使用Apache DataX将MongoDB数据同步到Kudu的方法。步骤如下:1.安装Apache DataX和MongoDB Kudu Connector;2.在DataX中配置MongoDB Reader和Kudu Writer;3.运行DataX任务,将MongoDB中的数据同步到Kudu中。 ### 回答2: 编写datax从mongodb到kudu的数据迁移任务需要以下步骤: 1. 安装和配置datax:首先,需要在目标服务器上安装和配置datax,以确保其可以正常运行。可以从datax官方网站下载并安装相应版本的datax。 2. 配置mongodb读取器:在datax的配置文件中,需要指定mongodb作为数据源。可以使用mongodb读取器插件来实现数据的读取。配置文件需要指定mongodb的连接信息(如主机名、端口号、数据库名称和集合名称等)以及读取的字段。 3. 配置kudu写入器:在配置文件中,还需要指定kudu作为数据目标。可以使用kudu写入器插件来实现数据的写入。配置文件需要指定kudu的连接信息(如主机名、端口号和表名等)。 4. 定义字段映射和转换规则:根据需求,需要在配置文件中定义字段映射和转换规则,以使数据能够正确地从mongodb迁移到kudu。例如,可以指定如何映射mongodb中的字段到kudu表中的字段,以及如何进行数据类型转换和格式化等操作。 5. 运行datax任务:配置文件准备好后,可以使用datax命令行工具来运行任务。在命令行中指定配置文件的路径,datax将会读取配置文件并执行数据迁移任务。在执行过程中,可以查看日志来监控任务的运行情况。 总的来说,编写datax从mongodb到kudu的数据迁移任务,需要安装和配置datax,配置mongodb读取器和kudu写入器,定义字段映射和转换规则,最后通过datax命令行工具运行任务。这样就可以实现将mongodb中的数据迁移到kudu中。 ### 回答3: 编写datax将数据从MongoDB导入到Kudu需要以下几个步骤: 1. 确保已经安装好了MongoDB和Kudu,并且能够正常连接到它们。 2. 下载并安装DataX,DataX是一个开源的大数据同步工具,可以用于从不同的数据源导入和导出数据。 3. 创建DataX的配置文件,配置文件是一个json格式的文件,用于指定数据源和目标源的相关信息。 4. 在配置文件中,指定MongoDB和Kudu的连接地址、用户名和密码,以及需要导入的MongoDB的数据库和集合,以及Kudu的表和列的映射关系。 5. 配置数据转换规则,由于MongoDB和Kudu的数据类型可能不一致,需要使用DataX提供的转换规则来将数据进行格式转换和映射。 6. 运行DataX任务,将数据从MongoDB导入到Kudu。可以通过命令行或者图形界面来启动DataX任务。 7. 监控导入任务,可以通过DataX的日志来查看导入进度和错误情况,以及导入的数据量和时间。 需要注意的是,编写DataX任务需要一定的编程和配置经验,对MongoDB和Kudu的相关知识也有一定的了解。另外,由于DataX是一个通用的数据同步工具,还可以用来从其他数据源导入数据到Kudu,具体配置和步骤可能有所不同。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值