- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我可能会参与一个项目,其中一个重要的组件是存储大量文件(在这种情况下是图像,但它应该只是作为文件存储)。
预计每周传入文件的数量约为 500,000 个(平均每个约为 100 Kb),峰值约为每天 100,000 个文件和每秒 5 个。
文件总数预计将达到数千万,然后达到平衡,即文件因各种原因以输入速率过期。
所以我需要一个系统,它可以在高峰时段每秒存储大约 5 个文件,同时读取大约 4 个并随时删除 4 个。
我最初的想法是,一个带有简单的存储、过期和读取服务的普通 NTFS 文件系统实际上就足够了。我可以想象该服务为每年、每月、每天和每小时创建子文件夹,以将每个文件夹的文件数量保持在最低限度,并在需要时允许手动过期。
已经讨论了大型 NTFS 解决方案 here ,但我仍然可以使用一些建议,说明在使用上述规范构建存储时会出现哪些问题、预期会出现哪些维护问题以及存在哪些替代方案。如果可能且可行,我最好避免使用分布式存储。
编辑
感谢所有的意见和建议。有关该项目的更多奖励信息:
这不是最终用户提供图像的 Web 应用程序。没有透露太多,因为这是在契约(Contract)阶段,它更多地属于质量控制类别。想想带有传送带和传感器的生产工厂。这不是传统的质量控制,因为产品的值(value)完全取决于图像和元数据数据库的顺利运行。
自主应用程序以先进先出的顺序访问 99% 的图像,但也会发生用户应用程序的随机访问。超过一天的图像将主要用于存档目的,尽管该目的也非常重要。
由于各种原因,图像的到期遵循复杂的规则,但在某些日期,所有图像都应被删除。删除规则遵循依赖于元数据和用户交互的业务逻辑。
每天都会有停机时间,可以进行维护。
优选地,文件存储不必将图像位置传送回元数据服务器。如果选择了某种散列或分布式系统,则应该从元数据中唯一地扣除图像位置,可能通过映射数据库。
所以我的问题是:
最佳答案
以下是基于以下假设的关于实现和可能出现的问题的一些随机想法:平均图像大小为 100kb,稳定状态为 50M (5GB) 图像。这也假设用户不会直接访问文件存储,而是通过软件或网站来访问:
abcdef
,根目录为 ab
然后在该目录下名为 cd
,您将在其下存储名称为 abcdef
的图像.真实姓名将保存在其他地方(下面讨论)。关于architecture - 大规模图像存储,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4580862/
如果您设计分布式应用程序以实现轻松扩展,或者您只想使用 Amazon、Google 或 Microsoft 提供的任何新的“云计算”产品,那么您通常最终会使用一些典型的概念或组件: 分布式 blob
根据uncle Bob's Clean Architecture 、企业和应用程序业务规则(概念上由命令组成)位于外部接口(interface)层之下的层中。因此,无论何时调用接口(interface
我在网上找不到它的任何实现实际上为您提供了一种与框架无关且实用的实现方式。 我已经看到了几个解决它的低于标准的建议: 使存储库方法成为原子 使用例原子化 它们都不是理想的。 案例#1 :大多数用例依赖
我正在查看 Sparkle 项目的配置并注意到它们设置: 架构 = ppc i386 x86_64 有效架构 = i386 x86_64 来自苹果的有效架构描述: Space-separated li
只听本周的podcast并认为将您的一些经验组合在一起会很好,在这些经验中,您已经看到设计的“架构”方面比应有的支配更多东西。 Java 在这方面经常受到负面报道,而且随着 Java EE 的复杂性增
我正在阅读 Bob Martin (https://blog.8thlight.com/uncle-bob/2012/08/13/the-clean-architecture.html) 的清洁架构
OSGi是模块化架构,JavaBeans是组件架构。有什么区别? 最佳答案 OSGi 和 Java Beans 之间的主要区别在于类加载器的工作方式。在标准 .jar 文件或 EJB 中,rt.jar
我对 Clean Architecture 中的 Gateway to Entity 依赖有疑问。我认为以下同心圆图形经常被介绍为整洁的架构。 在上图中,Gateway并没有直视Entity。但是,还
我试图理解 TOGAF 9 的核心概念。 无论我多长时间阅读 TOGAF 手册中的解释,我都无法理解 Enterprise Continuum 和 Architecture Repository 之间
如果 Kappa 架构直接对流进行分析,而不是将数据拆分为两个流,那么在像 Kafka 这样的消息系统中,数据存储在哪里?或者它可以在数据库中进行重新计算? 单独的批处理层是否比使用流处理引擎重新计算
它们的含义是什么,我可以将它们设置为不同的值吗? 最佳答案 架构是您想要构建的架构,有效的架构是您可以设想使用您的代码库构建的架构。 所以也许您只想为 armv7 构建二进制文件,但相同的源代码可以为
我现在正在尝试在 Xcode 4.0 中构建的项目遇到问题,希望有人可以为我解释一下。 我正在尝试使用 ZBar SDK 并遵循此处概述的指南中概述的说明: http://zbar.sourcefor
在基于 Apple Silicon 的机器上使用 Interface builder 时,我当前的项目会引发 IBDesignable 错误。 我尝试排除用于调试的 arm64 架构,以及我在互联网上
Xcode 项目中出现警告: crypto was rejected as an implicit dependency for 'libcrypto.a' because its architect
我正在 Xcode 5 中开始新项目。我想使用 iOS SDK 7 开发应用程序,但部署目标为 iOS 5.0。当我在 Xcode 中创建新项目并尝试将部署目标更改为 5.0 时,我收到了这条消息:
编辑 :这个问题可能是旧的,它与 xcode 3 有关。 我正在开发一个需要 voip 支持的 iPhone 应用程序,所以我添加了 pjsip 的 ARM 版本图书馆。但如果我使用 iPhone 模
我们最近将最低 iOS 支持设置为 4.0,并开始使用 LLVM 编译器对当前可用的应用程序进行新更新。 将“架构”和“有效架构”设置为仅 armv7 是否会排除 iPhone 3G 等 armv6
我想在我的 64 位机器上启用额外的架构(32 位)。我做了 dpkg --print-architecture 来了解已知的架构,即 amd64 。之后我做了 dpkg --print--forei
操作系统:OS X Yosemite 版本 10.10.1 XCode:未安装 应用程序加载器3.0 (620) PhoneGap:3.7.0 PhoneGap 构建:在线 (build.phoneg
我们已经构建了一个具有多个 native 绑定(bind)的 Xamarin 应用程序(iOS、Android)。该应用程序在设备和模拟器上运行良好,我们能够毫无问题地构建存档(显然)。 问题是当我们
我是一名优秀的程序员,十分优秀!