首页 web前端 js教程 Docker 的开发:第 1 集

Docker 的开发:第 1 集

Jan 10, 2025 am 11:23 AM

Docker in development: Episode 1

``在本系列中,我们将探讨在开发中使用 docker 的动机和好处。我们将提供日常技巧,帮助我们继续使用它,重点是 Ruby on Rails 和 React 开发。

本系列不会解释Docker的核心概念。如果你还不了解它们,我强烈建议你阅读 Docker 的官方文档,然后再回来。

动机
这是个人(和团队!)的经历。您可能会发现自己处于类似的情况,这可能会帮助您继续前进并迈出第一步。

直到几个月前,我开发 Ruby on Rails、简约 Ruby 应用程序和 React 应用程序的标准设置还非常简单。

对于 Ruby/Ruby on Rails,我刚刚安装了 chruby、ruby-install(以及我需要的 Ruby 版本,比如 2.3、2.5,甚至 2.6!),克隆了项目,使用捆绑器 Postgres 安装了 gem(因为我们主要使用 Postgres),我已经准备好了。当然,如果我需要 Redis 或其他数据库,我就必须安装它。

同样,对于 React 项目,我只是安装了节点并安装了依赖项。借助 homebrew(如果使用 Linux,则为 apt-get)来安装解释器、依赖项等的过程很简单,但需要一些时间。

一个月前,我有一个任务要完成:在 Ruby 1.9.3 之上修复 Rails 3 应用程序中的一个小错误!这比新版本的 Ruby 有点难。不是针对解释器本身,而是针对项目的依赖项。随着时间的推移,较旧的依赖项可能会因其依赖关系而更难安装。您的计算机中可能有更新版本的依赖项依赖项,安装旧版本可能会花费时间。

经过一番思考,我决定对应用程序进行 docker 化。老实说,我不知道这是否比与解释器/依赖项版本斗争花费的时间更长,但结果得到了回报。不仅这个错误很容易被修复,而且从那时起我就决定将我工作的每个应用程序都进行 docker 化(甚至是一些你可能每天使用的应用程序,我们稍后会看到),到目前为止,我只使用 docker 进行本地开发。不再需要本机设置。

好处
其中一些好处是显而易见的(特别是如果您已经开始使用 docker),但无论如何我们都会详细介绍它们,以便我们公开更强有力的案例。

您的整个项目从系统角度解释了如何设置:什么数据库、服务等
新开发人员可以轻松加入该项目,只需运行一个命令,他们就可以开始工作了。
您的应用程序不会随着本地环境的变化而变化。通常,对于捆绑程序来说,这不会成为问题,但您最终可能会在系统中使用其他二进制文件或库,这些二进制文件或库可能会随着时间的推移而发生变化。
问题
这些是我问自己的问题(你可能也有这些问题):

我的docker镜像会不会占用很多磁盘空间?
是的,你会的。但如果您愿意,您可以删除它们并在需要时重新创建它们。这没什么大不了的。如果您不想每次都构建,可以将镜像推送到存储库(docker hub 就是一个例子)。

表演怎么样?消耗资源多吗?
简短的回答:不。它们是常规进程,并且它们消耗的资源与您本地安装所有需求时消耗的资源相同。您可以通过运行 docker stats 自行查找!

您还有其他问题吗?联系我们吧!

结论
对我来说,这种平衡是积极的。自从我开始使用 docker 以来,在开发时间、启动和运行等方面,情况都是一样的。此外,还有我们已经提到的好处。

加入我们下一集!

以上是Docker 的开发:第 1 集的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Laravel 教程
1600
29
PHP教程
1502
276
如何在node.js中提出HTTP请求? 如何在node.js中提出HTTP请求? Jul 13, 2025 am 02:18 AM

在Node.js中发起HTTP请求有三种常用方式:使用内置模块、axios和node-fetch。1.使用内置的http/https模块无需依赖,适合基础场景,但需手动处理数据拼接和错误监听,例如用https.get()获取数据或通过.write()发送POST请求;2.axios是基于Promise的第三方库,语法简洁且功能强大,支持async/await、自动JSON转换、拦截器等,推荐用于简化异步请求操作;3.node-fetch提供类似浏览器fetch的风格,基于Promise且语法简单

JavaScript数据类型:原始与参考 JavaScript数据类型:原始与参考 Jul 13, 2025 am 02:43 AM

JavaScript的数据类型分为原始类型和引用类型。原始类型包括string、number、boolean、null、undefined和symbol,其值不可变且赋值时复制副本,因此互不影响;引用类型如对象、数组和函数存储的是内存地址,指向同一对象的变量会相互影响。判断类型可用typeof和instanceof,但需注意typeofnull的历史问题。理解这两类差异有助于编写更稳定可靠的代码。

JavaScript时间对象,某人构建了一个eactexe,在Google Chrome上更快的网站等等 JavaScript时间对象,某人构建了一个eactexe,在Google Chrome上更快的网站等等 Jul 08, 2025 pm 02:27 PM

JavaScript开发者们,大家好!欢迎阅读本周的JavaScript新闻!本周我们将重点关注:Oracle与Deno的商标纠纷、新的JavaScript时间对象获得浏览器支持、GoogleChrome的更新以及一些强大的开发者工具。让我们开始吧!Oracle与Deno的商标之争Oracle试图注册“JavaScript”商标的举动引发争议。Node.js和Deno的创建者RyanDahl已提交请愿书,要求取消该商标,他认为JavaScript是一个开放标准,不应由Oracle

处理诺言:链接,错误处理和承诺在JavaScript中 处理诺言:链接,错误处理和承诺在JavaScript中 Jul 08, 2025 am 02:40 AM

Promise是JavaScript中处理异步操作的核心机制,理解链式调用、错误处理和组合器是掌握其应用的关键。1.链式调用通过.then()返回新Promise实现异步流程串联,每个.then()接收上一步结果并可返回值或Promise;2.错误处理应统一使用.catch()捕获异常,避免静默失败,并可在catch中返回默认值继续流程;3.组合器如Promise.all()(全成功才成功)、Promise.race()(首个完成即返回)和Promise.allSettled()(等待所有完成)

什么是缓存API?如何与服务人员使用? 什么是缓存API?如何与服务人员使用? Jul 08, 2025 am 02:43 AM

CacheAPI是浏览器提供的一种缓存网络请求的工具,常与ServiceWorker配合使用,以提升网站性能和离线体验。1.它允许开发者手动存储如脚本、样式表、图片等资源;2.可根据请求匹配缓存响应;3.支持删除特定缓存或清空整个缓存;4.通过ServiceWorker监听fetch事件实现缓存优先或网络优先等策略;5.常用于离线支持、加快重复访问速度、预加载关键资源及后台更新内容;6.使用时需注意缓存版本控制、存储限制及与HTTP缓存机制的区别。

JS综述:深入研究JavaScript事件循环 JS综述:深入研究JavaScript事件循环 Jul 08, 2025 am 02:24 AM

JavaScript的事件循环通过协调调用栈、WebAPI和任务队列来管理异步操作。1.调用栈执行同步代码,遇到异步任务时交由WebAPI处理;2.WebAPI在后台完成任务后将回调放入相应的队列(宏任务或微任务);3.事件循环检查调用栈是否为空,若为空则从队列中取出回调推入调用栈执行;4.微任务(如Promise.then)优先于宏任务(如setTimeout)执行;5.理解事件循环有助于避免阻塞主线程并优化代码执行顺序。

了解事件在JavaScript DOM事件中冒泡和捕获 了解事件在JavaScript DOM事件中冒泡和捕获 Jul 08, 2025 am 02:36 AM

事件冒泡是从目标元素向外传播到祖先节点,事件捕获则是从外层向内传播到目标元素。1.事件冒泡:点击子元素后,事件依次向上触发父级元素的监听器,例如点击按钮后先输出Childclicked,再输出Parentclicked。2.事件捕获:设置第三个参数为true,使监听器在捕获阶段执行,如点击按钮前先触发父元素的捕获监听器。3.实际用途包括统一管理子元素事件、拦截预处理和性能优化。4.DOM事件流分为捕获、目标和冒泡三个阶段,默认监听器在冒泡阶段执行。

超越地图和过滤器的高阶功能的JS综述 超越地图和过滤器的高阶功能的JS综述 Jul 10, 2025 am 11:41 AM

JavaScript数组中,除了map和filter,还有其他强大且不常用的方法。1.reduce不仅能求和,还可计数、分组、展平数组、构建新结构;2.find和findIndex用于查找单个元素或索引;3.some和every用于判断是否存在或全部满足条件;4.sort可排序但会改变原数组;5.使用时注意复制数组避免副作用。这些方法使代码更简洁高效。

See all articles