Docker-Compose安装MongoDB并设置密码
注:为什么安装MongoDB要设置密码?当然,如果你是在本机上安装MongoDB用于简单的测试学习,没有必要设置密码。但如果是在服务器上安装MongoDB,还是得做好安全保障。任何在公网上暴露的服务都会被恶意攻击者扫描到漏洞,如果没有密码屏障,那后果是很难预料的。本文介绍了一种可行的带有超级管理员账号与密码的MongoDB容器的安装方法,主要借助docker-compose实现。本文基于Docker环境和Docker-Compose环境,安装教程在我的博客里有。
docker-compose.yml文件
version: "3.1"
services:
mongodb:
image: daocloud.io/library/mongo:2.7.6
container_name: "mongodb"
restart: always
ports:
- 27017:27017
environment:
- MONGO_DATA_DIR=/data/db
- MONGO_LOG_DIR=/data/logs
command: mongod --auth
volumes:
- ./mongodb_data:/data/db
- ./mongodb_logs:/data/logs
- ./mongodb_conf:/etc/mongo
进入docker容器,创建超级管理员
#查看mongoDB容器的id
docker ps
#进入mongoDB容器
docker exec -it 容器id bash
#连接mongoDB服务
mongo
#尝试显示所有数据库,结果会报错
show dbs
#使用admin,创建超级管理员
use admin
#此处设置123456的密码进攻参考,实际安装过程中要设置复杂一点的密码,不然跟没设置密码没有区别
db.createUser({user: "root",pwd: "123456",roles: [ { role: "root", db: "admin" } ]})
#退出mongo服务
exit
用超级管理员重新进入mongoDB
#admin是连接的数据库,但实质上连接后是可以查看其他数据库的
mongo admin -u root -p 123456
#尝试再次显示所有数据库
show dbs
#尝试显示admin数据库中的所有集合
use admin
show collections
附录
docker compose安装mysql5.0、mysql8.0、tomcat8
version: "3.1"
services:
mysql:
restart: always
image: daocloud.io/library/mysql:5.7.4
container_name: mysql5.0
ports:
- 3307:3306
environment:
MYSQL_ROOT_PASSWORD: 123456
TZ: Asia/Shanghai
volumes:
- ./mysql_data:/var/lib/mysql
version: "3.1"
services:
mysql:
restart: always
image: daocloud.io/library/mysql:8.0.1
container_name: mysql8.0
ports:
- 3308:3306
environment:
MYSQL_ROOT_PASSWORD: InternetCenterStudio
TZ: Asia/Shanghai
volumes:
- ./mysql_data:/var/lib/mysql
version: "3.1"
services:
tomcat:
restart: always
image: daocloud.io/library/tomcat:8.5.15-jre8
container_name: tomcat8
ports:
- 8081:8080
environment:
TZ: Asia/Shanghai
volumes:
- ./tomcat_webapps:/usr/local/tomcat/webapps
- ./tomcat_logs:/usr/local/tomcat/logs