Docker 如何安装、启动、配置 MongoDB?


前提已安装docker和docker-compose

安装mongodb

# 此处我将mongodb安装在/home/mongotest下
cd /home/
mkdir mongotest
cd mongotest/

# 创建docker-compose.yml文件
vi docker-compose.yml
# 进入编辑状态
i
# 粘贴以下内容
version: '3.1'
services:
  mongo:
    image: mongo
    restart: always
    environment:
      MONGO_INITDB_ROOT_USERNAME: root   # 这里设置管理员账户为root
      MONGO_INITDB_ROOT_PASSWORD: example  # 密码example
    ports:
      - 27017:27017
    # mongo数据持久化
    volumes:
      - /home/mongotest:/data/db
# 退出编辑状态
esc 
# 保存
:wq

# 运行
docker-compose up -d

# 防火墙放行端口27017
# 查看firewalld状态,若为dead状态,则需要开启防火墙systemctl start firewalld
systemctl status firewalld
# 让防火墙永久放行27017端口
firewall-cmd --add-port=27017/tcp --permanent
# 重启防火墙
firewall-cmd --reload

初始化配置

cd mongotest/

# 连接数据库
# 注意:mongo5.0以下的版本使用mongo来替换mongosh,即docker exec -it mongotest_mongo_1 mongo
docker exec -it mongotest_mongo_1 mongosh

# 切换到管理员用户
use admin
db.auth('root','example') # 管理员授权登录
 
# 创建一个数据库testdb
use testdb

# 创建一个用户,用户名为test,密码123456。
db.createUser({user:'test',pwd:'123456',roles:[{role:'dbOwner',db:'testdb'}]})

# 测试下上面添加的用户是否可以登录数据库testdb
use testdb
db.auth('test','123456')

# 测试插入数据
db.users.insertOne({'name':'sue',age:30,email:'test@foxmail.com'})
show collections
db.users.find({})
db.users.insertOne({name:'soft',age:20})
db.users.find({})

# 测试更新
db.users.updateOne({name:'sue'},{$set:{email:'test1@foxmail.com'}})
db.users.find({})

# 测试删除
db.users.deleteOne({'name':'sue'})
db.users.find({})

GUI工具连接数据库(Robo 3T)

:连接之前,确保云服务器 端口27017已放行,详见《云服务设置端口放行》
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

备份与恢复

备份方式:docker cp + mongodump
恢复方式:docker cp + mongorestore

# mongotest_mongo_1 容器
# mongodump 指令
# -h 连接的mongodb的host
# -u 用户
# -p 密码
# -d 指定备份哪个数据库,不接的话代表备份所有数据库
# -o 指定备份到哪个目录

# 1.备份
docker exec -it mongotest_mongo_1 mongodump -h localhost -u root -p example -o /tmp/test
cd /tmp/
docker cp e401dcb60416:/tmp/test /tmp/test

# 2.恢复
docker exec -it mongotest_mongo_1 mongorestore -h localhost -u root -p example --dir /tmp/test

Nodejs中的Mongoose库

  • 比较
分类Oralce/MysqlMongoDBMongoose
1数据库实例MongoDB实例Mongoose
2模式(schema)数据库(database)mongoose
3表(table)集合(collection)模板(Schema) 模型(Model)
4行(row)文档(document)实例(instance)
5Prinary keyObject(_id)Object(_id)
6表字段ColumnFieldField
mkdir mongoose-demo
cd mongoose-demo
npm init -y
npm install -s mongoose
// app.js
const mongoose = require('mongoose')
mongoose.connect('mongodb://test:123456@121.199.33.98:27017/testdb',{useNewUrlParser: true})

// 连接数据库的Connection
const User = mongoose.model('users', {name: String, age: Number, email: String})

const imooc = new User({
  name: 'imooc-test',
  age:30,
  email: 'imooc@imooc.com'
})
imooc.save().then(() => {console.log('save OK!')})

node app.js

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
config-keeper是一个基于Spring Boot 和Spring Cloud开发的配置中心,无缝兼容Spring Boot 和 Spring Cloud应用。 在微服务架构中,配置中心是个必不可少的基础服务。应用部署到生产环境后,由于各种原因,需要调整一些配置。如果每次修改配置都需要经过修改代码、重新打包、重新部署等过程,为了避免重新部署造成请求错误,还需要将应用从负载均衡中下线,部署成功后再重新上线,当部署的实例比较多的情况下,那就会严重影响投产效率,如果是为了解决生产上的问题而调整配置,那么这个过程耗时越多,带来的风险也就越大。所以我们需要在不停机、不重新打包、不重新部署的情况下,可以动态修改配置(比如:功能开关、性能参数等)。为了方便动态更新应用配置,需要把配置放到应用执行包之外的配置中心。配置文件不需要打进应用执行包中后,可以带来以下几个好处:一个可执行包就可以在不同的环境下运行,可以降低包的版本管理成本,也可以降低docker镜像的版本管理成本。 Spring cloud 虽然已经为我们提供了基于git或mongodb等实现的配置中心,但是这些方案实现都过于简单,没有达到实际可用的标准,比如:没有提供统一的管理页面,不便于操作和使用;没有权限管理功能;没有数据验证功能等等。但Spring cloud config的核心技术还是可以为我们所有,没有必要重新造轮子。 ConfigKeeper 是由随行付架构部基于Spring Cloud研发的分布式配置中心。基于Spring Cloud开发。与Spring Boot、Spring Cloud应用无缝兼容。下面我们将详细介绍ConfigKeeper配置中心(有图有真像): 1. 支持权限管理,保证数据的安全 角色设计比较简单,只有管理员和普通用户两种,管理员拥有最高权限,而普通用户只能查看和操作为其分配的配置,以保证数据的安全。 2. 支持多环境部署,也支持多环境配置集中管理 企业可以根据自身的情况设置不同的环境,比如:测试、rc以及生产环境。可以多环境共用一个配置中心,也可以每个环境单独使用一个配置中心,根据企业需求灵活部署。 3. 配置管理简单实用 为了避免配置内容耦合问题,我们只设计了全局配置(global config)和应用配置(application config)两种类型的配置,并没有设计”组配置“。全局配置是指某一环境下所有应用都能生效的配置,但它的优先及低于应用配置,一个运行环境下有且只有一个全局配置。如果应用可执行包已经有相同的配置,那么会被配置中心的配置所覆盖。 3.1 自带版本管理功能:自动生成版本号以及回退功能 3.2 使用Yml在线编辑器,能实时检查配置格式是否正确; 3.3 支持修改前后内容对比功能,保证修改内容的正确性 4. 客户端使用简单并兼容Spring Boot和Spring Cloud应用 配置中心提供http接口拉取配置,所以只要支持http协议的应用都是可以使用的。我们已经实现了Spring Boot和Spring Cloud应用的客户端,接下来说明其一些特性及使用方法。 4.1 无缝兼容Spring boot、Spring Cloud应用 4.2 支持灰度发布 4.3 支持客户端缓存,即使配置中心服务不可用,也不会影响应用的启动
# docker搭建lnmp环境 <!-- TOC --> - [docker搭建lnmp环境](#docker搭建lnmp环境) - [一、Dockerfile定制镜像](#一dockerfile定制镜像) - [二、docker-compose](#二docker-compose) - [三、docker-compose编排lnmp环境](#三docker-compose编排lnmp环境) - [1、mysql](#1mysql) - [2、redis](#2redis) - [3、mongo](#3mongo) - [4、nginx](#4nginx) - [5、php](#5php) - [6、完整版](#6完整版) - [四、参考](#四参考) <!-- /TOC --> 有收获的话请**加颗小星星**,没有收获的话可以 **反对** **没有帮助** **举报**三连 ## 一、Dockerfile定制镜像 ```bash # FROM 指定基础镜像 FROM 镜像 FROM php:7.2-fpm # RUN 执行 RUN or RUN ["可执行文件", "参数1", "参数2"] RUN echo 'Hello, Docker!' > /usr/share/nginx/html/index.html RUN ["php", "-S", "0.0.0.0:8080"] # COPY 复制文件 COPY ... COPY swoole-4.2.10.tgz /home COPY nginx.conf /etc/nginx/nginx.conf # ADD 复制文件或目录,如果是.tgz,会被解压缩 ADD ... ADD nginx.conf /etc/nginx/nginx.conf # CMD 容器启动 CMD echo $HOME => CMD [ "/bin/sh", "-c", "echo $HOME" ] CMD [ "redis-server", "/usr/local/etc/redis/redis.conf" ] # ENTRYPOINT 入口点 ENTRYPOINT ["docker-entrypoint.sh"] 存在 ENTRYPOINT 后,CMD 的内容将会作为参数传给 ENTRYPOINT # ENV 环境变量 ENV ENV MYSQL_ROOT_PASSWORD root # ARG与ENV差不多 ARG 所设置的构建环境的环境变量,在将来容器运行时是不会存在这些环境变量的 ENV MYSQL_ROOT_PASSWORD root # VOLUME 匿名卷 VOLUME ["", ""...] VOLUME ["/data"] # EXPOSE 暴露端口 EXPOSE [...] EXPOSE 80 443 # WOEKDIR 指定工作目录,进入容器后的落地目录 WORKDIR WORKDIR /var/www # USER 指定当前用户 USER USER root ``` ## 二、docker-compose - 服务 (service):一个应用的容器,实际上可以包括若干运行相同镜像的容器实例。 - 项目 (project):由一组关联的应用容器组成的一个完整业务单元,在 docker-compose.yml 文件中定义。 ## 三、docker-compose编排lnmp环境 ### 1、mysql 这里我们使用了mysql5.5版本,没其它用意,相比5.7以上版本,占内存和硬盘最小的一个版本 我们准备了一个`my.cnf`作为额外配置,这里我修改了数据库的时区 ```cnf [mysqld] default-time-zone = '+8:00' ``` ```Dockerfile FROM mysql:5.5 COPY my.cnf /etc/mysql/conf.d EXPOSE 3306 ``` ### 2、redis 我们使用准备的配置文件`redis.conf`覆盖容器默认启动配置文件,修改了`ip绑定`和`密码` ```conf bind 0.0.0.0 requirepass root ``` ```Dockerfile FROM redis:latest COPY redis.conf /usr/local/etc/redis/redis.conf CMD [ "redis-server", "/usr/local/etc/redis/redis.conf" ] EXPOSE 6379 ``` ### 3、mongo mongodb我们没有特殊处理 ```Dockerfile FROM mongo:latest EXPOSE 27017 ``` ### 4、nginx 我们准备了一份`nginx.conf`和虚拟目录`conf.d`,为了以后可以动态的配置网站的代理和负载均衡 还有一个日志目录,放在外层`logs`目录里面,记录nginx的访问日志 特别注意的是`fastcgi_pass php:9000;`而不是`fastcgi_pass 127.0.0.1:9000;`,目前自己也没明白 ```Dockerfile FROM nginx:alpine COPY nginx.conf /etc/nginx/nginx.conf EXPOSE 80 ``` ### 5、php php算是这里面最难搞定的,因为我们需要额外的添加php扩展,虽然php的docker官方提供了`docker-php-ext-configure`, `docker-php-ext-install`, `docker-php-ext-enable`,还是有些扩展需要通过`手动编译`或者`pecl`安装 由于pecl官网下载慢,我们事先下载好了几个需要的扩展 php-fpm用的是debian的linux系统,下载也很慢,我们备用了阿里云的镜像`sources.list` 我们还准备了php的默认配置`php.ini`和`opcache.ini` 比如swoole扩展安装,记得安装包用完后清理,还有得用`COPY`命令,`ADD`会解压缩 ```Dockerfile # swoole COPY swoole-4.2.10.tgz /home RUN pecl install /home/swoole-4.2.10.tgz && \ docker-php-ext-enable swoole && \ rm /home/swoole-4.2.10.tgz ``` ### 6、完整版 ```yml version: '3' networks: frontend: driver: bridge backend: driver: bridge volumes: mysql: driver: local mongo: driver: local redis: driver: local services: php: build: ./php volumes: - ${WORKER_DIR}:/var/www ports: - 9100:9000 depends_on: - mysql - redis - mongo networks: - backend nginx: build: ./nginx volumes: - ${WORKER_DIR}:/var/www - ./logs/nginx:/var/log/nginx - ./nginx/conf.d:/etc/nginx/conf.d ports: - 8000:80 depends_on: - php networks: - frontend - backend mysql: build: ./mysql environment: - MYSQL_ROOT_PASSWORD=root volumes: - ${DATA_PATH}/mysql:/var/lib/mysql ports: - 3310:3306 networks: - backend mongo: build: ./mongo environment: - MONGO_INITDB_ROOT_USERNAME=root - MONGO_INITDB_ROOT_PASSWORD=root ports: - 27010:27017 volumes: - ${DATA_PATH}/mongo:/data/db networks: - backend redis: build: ./redis volumes: - ${DATA_PATH}/redis:/data ports: - 6310:6379 networks: - backend ```
### 回答1: 1. 使用命令 "docker pull mongo" 下载 MongoDB 镜像。 2. 使用命令 "docker run -d -p 27017:27017 --name mongodb mongo" 启动 MongoDB 容器。 3. 使用命令 "docker exec -it mongodb bash" 进入 MongoDB 容器。 4. 使用命令 "mongo" 连接 MongoDB 数据库。 5. 使用命令 "use admin" 切换到 admin 数据库。 6. 使用命令 "db.createUser({user: 'username', pwd: 'password', roles: [{role: 'root', db: 'admin'}] })" 创建超级用户。 7. 使用命令 "exit" 退出 MongoDB 容器。 8. 使用命令 "docker stop mongodb" 停止 MongoDB 容器。 9. 使用命令 "docker start mongodb" 启动 MongoDB 容器并使用创建的超级用户登录。 注意:在实际操作时,请将 "username" 和 "password" 替换为您自己的用户名和密码。 ### 回答2: Docker 是一个容器化技术,可以使得应用在不同的环境下得以快速部署。MongoDB 是一种流行的非关系型数据库,在 Docker 中使用 MongoDB 可以加速开发和测试过程。下面是在 Docker安装 MongoDB 的步骤: 1. 安装 Docker 首先需要安装 Docker安装方法可以参考官方文档:https://docs.docker.com/engine/install/ 2. 下载 MongoDB 镜像 在 Docker安装 MongoDB,需要下载 MongoDB 镜像。在终端中输入以下命令即可下载 MongoDB 镜像: ``` docker pull mongo ``` 3. 运行 MongoDB 容器 下面的命令将启动一个名为 mongodb容器,并在其内部运行 MongoDB: ``` docker run -d —name mongodb -p 27017:27017 mongo:latest ``` 其中,-d 告诉 Docker 在后台运行容器,--name 指定容器名称为 mongodb,-p 27017:27017 表示将容器内部的 27017 端口映射到主机的 27017 端口,最后的 mongo:latest 是镜像名称和版本号。 4. 连接 MongoDB 使用以下命令连接容器内的 MongoDB: ``` docker exec -it mongodb mongo ``` 其中,-it 表示以交互式会话进入容器内,mongo 是进入容器后要执行的命令。 5. 配置 MongoDB容器内部,执行以下命令可以配置 MongoDB: ``` use testdb db.stats() ``` 其中,use testdb 创建了一个名为 testdb 的数据库,db.stats() 可以查看数据库状态。可以在容器内部使用 MongoDB 的标准命令行工具进行操作。 以上就是在 Docker安装 MongoDB 并进行配置的详细步骤。通过 Docker,可以快速创建 MongoDB 环境,方便快捷地进行开发和测试。 ### 回答3: Docker是一个开源的容器化平台,它可以让开发者把应用程序和服务打包到一个容器中,并部署到任何支持Docker的机器上。Docker中最常用的应用就是MongoDB数据库,因为MongoDB可以轻松地扩展和存储大量数据。下面我们就来看看如何在Docker安装MongoDB并进行配置。 1.安装Docker 首先,你需要在你的服务器上安装Docker。如果你还没有安装Docker,请先在官方网站上下载并安装Docker。 2.拉取MongoDBDocker镜像 在安装配置之前,你需要拉取MongoDBDocker镜像。可以使用以下命令拉取MongoDB镜像: docker pull mongo 3.创建MongoDB容器 接下来,你需要创建一个MongoDB容器。可以使用以下命令创建MongoDB容器docker run -it -d --name mongo -p 27017:27017 mongo 通过上述命令,我们创建了名为“mongo”的容器,并将容器的端口映射到主机的端口27017上。这表示,当你连接到主机的端口27017时,实际上连接的是容器的端口27017,因此可以访问MongoDB。 4.连接MongoDB 现在,MongoDB容器已经准备就绪。你可以尝试连接到MongoDB容器来检查是否能成功连接。可以使用以下命令连接到MongoDBdocker exec -it mongo mongo 通过上述命令,你将进入到mongodb容器中,并成功连接到mongodb服务器上。 5.更改MongoDB配置 为了更强大的功能,可以修改一些MongoDB配置项,而Docker容器中的MongoDB配置文件类似于Linux系统上的MongoDB配置。因此,可以使用以下命令来编辑MongoDB配置文件: docker exec -it mongo vi /etc/mongodb.conf 然后你可以根据需要进行更改,并将更改保存到配置文件中。 6.重启MongoDB容器 最后,你需要重启MongoDB容器,以确保更改得到保存。可以使用以下命令来重启MongoDB容器docker restart mongo 经过以上步骤,你就完成了在Docker安装MongoDB并进行配置的操作。在完成此过程之后,你可以实现大规模部署和使用MongoDB数据库。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值