手摸手教学 - Docker(五) 超级爽!持久化数据库-bind mounts!

若有疑问参考前面几篇Docker文章,循序渐进
不懂算我输,话不多说,实战为主!

作者变优秀的小白

Github关注YX-XiaoBai

爱好Americano More Ice !

QQ学习交流群(new): 811792998

目录

使用bind mounts

  • nodemon
    • 一款很好的监视文件改动和启动应用的工具

对比两种volume类型

Named VolumesBind Mounts
主机位置Docker选择自主选择
安装例子(-v)my-volume:/usr/local/data/path/to/data:/user/local/data
使用容器内容填充新volumeYesNo
支持Volume驱动YesNo

启动一个dev模式容器

为了我们的容器支持发展工作流,我们将会做这几件事

  • 安装我们的源码进容器
  • 下载所有依赖,包括dev的依赖
  • 启动nodemon去监视文件系统的改动

话不多说,实战为主!

  1. 确保你没有运行以前getting-started的容器

  2. 运行下面的命令

docker run -dp 3000:3000 \
    -w /app -v "$(pwd):/app" \
    node:12-alpine \
    sh -c "yarn install && yarn run dev"

分析下所有的flag

  • -dp 3000:3000: d在后台运行隔离模式和p创建一个端口映射
  • -w /app: 设置工作目录或者说是命令运行的目录
  • -v "$(pwd):/app": 将当前目录从容器绑定到/app目录
  • node:12-apline: 使用的镜像。这个Dockerfile中我们应用的基本镜像
  • sh -c "yarn install && yarn run dev: 我们使用sh启动一个shell终端(alpine没有bash),接着运行命令yarn install下载所有依赖,然后yarn run dev运行应用。如果我们看package.json会发现dev脚本正在启动nodemon
  1. 通过docker logs -f <container-id>查看日志

在这里插入图片描述

  1. 修改文件src/static/js/app.js,然后保存

在这里插入图片描述
容器会自动重启,刷新页面http://localhost:3000即可看到效果
在这里插入图片描述

在这里插入图片描述

  1. 完成后,停止容器并使用docker build -t getting-started .构建一个新镜像

结束语:不懂算我输,当然~如果遇到什么疑问或者建议的,可直接留言评论!作者看到会马上一一回复!

如果觉得小白此文章不错或对你有所帮助,期待你的一键三连💫!❤️ni!
为了安装Redis并使用Docker Compose进行持久化,您可以按照以下步骤进行操作: 1. 首先,确保您已经安装了DockerDocker Compose。如果还没有安装,您可以参考中提供的命令来安装。 2. 创建一个目录来存储Redis的持久化文件和配置文件。您可以使用以下命令来创建所需的目录: ``` mkdir -p /root/redis/data /root/redis/conf ``` 3. 在您的项目中创建一个docker-compose.yml文件,并在该文件中添加以下内容来配置Redis的容器: ```yaml version: '3' services: redis: image: redis container_name: health_redis restart: always command: redis-server /usr/local/etc/redis/redis.conf ports: - 6399:6379 expose: - 6379 volumes: - ./redis.conf:/usr/local/etc/redis/redis.conf - ./redis_data/:/data/ ``` 4. 将您的自定义Redis配置文件(redis.conf)放置在与docker-compose.yml文件相同的目录中。确保在docker-compose.yml文件中的volumes部分将配置文件映射到容器中。 5. 最后,使用以下命令在后台启动Redis容器,并确保它以持久化方式运行: ``` docker-compose --compatibility up -d ``` 这样,您就成功安装了Redis,并使用Docker Compose进行了持久化配置。您的数据将存储在宿主机的redis_data目录中,并且Redis容器将在后台持续运行以保持数据的持久化。请确保您的项目目录中包含了正确的redis.conf配置文件,并根据需要进行相应的自定义配置。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [docker-compose 安装 Redis 6.X 配置远程连接,持久化RDB AOF](https://blog.csdn.net/weixin_40461281/article/details/111291847)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [docker-compose 持久化redis](https://blog.csdn.net/myth_g/article/details/86096568)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值