This is a guest post from Jared Wyatt, CTO of Matchbook, an app for remembering the places you love and want to try. I joined Matchbook as CTO in January with the goal of breathing new life into an iOS app that had a small, but very devote
This is a guest post from Jared Wyatt, CTO of Matchbook, an app for remembering the places you love and want to try.
I joined Matchbook as CTO in January with the goal of breathing new life into an iOS app that had a small, but very devoted following. For various reasons, we decided to start fresh and rebuild everything from the ground up—this included completely revamping the app itself and totally redesigning our API and backend infrastructure. The old system was using MySQL as a datastore, but MongoDB seemed like a better fit for our needs because of its excellent geospatial support and the flexibility offered by its document-oriented data model.
We submitted Matchbook 2.0 to the App Store at the end of June and within a few days received an email from Apple requesting design assets because they wanted to feature our app. So, of course we were all, like, “OMG OMG OMG.”
An Influx of Users
We had originally planned for a quiet roll-out of version 2.0 because it was a completely new codebase and had not really been tested under load. However, our cautious reasoning was replaced by grandiose visions of fame and glory when Apple offered to feature us.
Matchbook 2.0 launched in the App Store on July 3rd. ?It was listed on the App Store home page under “New & Noteworthy” with top billing in the “Food & Drink” category. Within a week, we had onboarded tens of thousands of new users. Sweeet! It was high-fives all around until it suddenly wasn’t.
As our user base exploded, our application performance monitoring tool (New Relic) indicated massive amounts of time spent in the database during spikes of heavy user activity. Many, many milliseconds were being squandered somewhere in the ether while our API server was chatting with our MongoDB server. Support tickets and tweets started coming in about how much we sucked. We started freaking out (just a little) and began to rue the day we let Apple promote our app.
Monitoring to the Rescue
Prior to the launch, in addition to setting up New Relic to monitor our application, we set up MMS to monitor MongoDB. New Relic showed us that the performance issue was related to the database, but didn’t provide us with the detail necessary to determine what was causing the slowdown. So, I went to MMS. The first thing that caught my eye was the cursors chart. There were some freakish spikes in concurrently open cursors for the amount of activity on the database. So I says to myself, I says, “Jared, that seems sketchy, but why is it happening?”
I poked around in MMS a bit and noticed the profile data log—it was empty. At the risk of sounding like a n00b, I didn’t know what MongoDB profiling was, but it seemed like something I should look into. The MongoDB profile documentation indicates that level 1 profiles slow operations. Wait—did someone say slow operations? That’s me! I have slow operations! So, I hopped over to our database and said { profile: 1, slowms: 200 }.
Suddenly, query profiles started showing up in MMS and the universe began to make sense. We discovered that our ODM was running a lot of searches on indexed fields (which is good) using regular expressions instead of strings (which is bad for speediness). Upon further investigation, we found that this was happening because we had used the ODM to assign certain case-insensitive validations to some of the data models in our code. We made the appropriate changes and saw our performance issues immediately disappear. Our users were happy again.
Post Mortem
Although it caused big problems, this turned out to be a simple error with a simple fix. If not for MMS, the discovery could have been very time-intensive and stressful. It simply did not occur to us that our case-insensitive validations would cause the ODM to build queries with regular expressions and thus result in mad-crazy performance issues. Thanks to MMS, we got a clear picture of what went wrong, and it led us to implement a more efficient solution that gives us the case-insensitive validations we need without running regex searches in MongoDB.
It’s widely accepted that enterprise level systems need good monitoring tools because of their size and complexity, but the same need is often overlooked in tech startups. In today’s ecosystem where everyone is standing on the shoulders of dozens of 3rd-party libraries/frameworks/whatever to build a simple app, it’s often difficult to deduce where things might be going wrong. More than ever, the small, lean tech startups need tools that give us good insight so we can optimize performance and solve problems without expending too many of the precious few resources that we have.
Takeaways
- Set up monitoring. Visibility into your operations and interpreting the data correctly is your lifeline. Set up some custom dashboards in MMS for at-a-glance views of key metrics.
- Load test. Then load test some more and watch the data. You will see strange and wonderful things that you never thought possible when you watch how your application and database operations perform under load. Try to discover and fix some of these things before you launch. Load testing can also inform you about what specific metrics you should pay close attention to for your particular application.
- Set up performance alerts. Once you have a pretty good idea of which metrics you need to pay attention to, create alerts for when these data points approach unacceptable levels.
- Set up basic alerts for your server configuration, e.g. a replication lag alert for your replica set.
- Strike a ninja-like offensive pose when you launch. You never know what will happen and must be ready with cat-like reflexes.
Learn more about Matchbook at matchbook.co. We’re currently hiring designers and developers, so feel free to drop us a line at jobs@matchbook.co for more info.
原文地址:Surviving Success at Matchbook: Using MMS To Track, 感谢原作者分享。

php中success方法是用于展示一个成功信息,其使用语法是“Success('...','Http://www.xxx.com/Admin/User/Index');”,当我们没有写Url的时候,系统则会判断有无上一页,如果有系统,则会跳转至上一页,否则将不会进行跳转。

在Laravel中,success方法用于在控制器中返回成功的响应。要使用success方法,我们需要在控制器中引入Response类,然后,可以使用该类的实例来调用success方法。可以通过设置响应的消息、需要返回的数据、响应的状态码,并将这些参数传递给success方法,将会返回一个成功的响应,其中包含了我们设置的消息和用户数据。

Shortly after Tesla launched the Model 3 Highland refresh towards the end of last year, the US federal EV tax incentive rules changed, cutting the potential discount in half for eligible buyers because of Tesla's use of Chinese LFP cells in the new M

US Kaspersky antivirus accounts have been sold to UltraAV, a division of the Pango Group. Pango was recently spun off from Aura, a security company founded by CEO Hari Ravichandran. Kaspersky was forced to abandon the US market after being banned by

Gate.io交易所是全球领先的加密货币交易平台之一。本指南提供分步教程,帮助用户注册和使用Gate.io进行交易。注册过程包括选择注册方式(电话、邮箱或社交账号)、填写信息、设置登录密码和完成身份认证。交易教程包括访问交易页面、选择交易对、输入交易信息、下单和查看订单状态。通过本文的指导,用户可以轻松开始在Gate.io上进行加密货币交易。

The Samsung Galaxy S24 FE has so far appeared in a number of leaks and rumours that all suggested it would be a competent flagship killer with an updated processor, larger display, and more RAM. However, a new leak from OnLeaks reveals that the S24 F

B3币:高效、低成本的区块链游戏生态系统及购买指南区块链游戏长期受限于可扩展性和交易速度等问题。B3项目基于Base构建,提供高效、低成本且开发者友好的水平扩展游戏生态系统,其原生代币B3币已于2月12日上线Coinbase交易所,引发市场关注。本文将详细介绍B3币的交易平台及购买方法。B3币交易平台目前,B3币已上线多个主流交易平台,包括CoinbasePro、Gate.io、MEXC、Bybit和CoinW等。这些平台各有特色,投资者可根据自身需求选择:CoinbasePro:美

学习PHP中success方法的最佳实践,需要具体代码示例PHP是一种流行的服务器端脚本语言,被广泛应用于Web开发领域。在PHP中,success方法是一种常见的用于判断操作成功与否的方法,通常用来返回成功的消息或代码。学习PHP中success方法的最佳实践,需要结合实际的代码示例进行演示和解释。首先,让我们来看一个简单的例子,展示一个成功的succes


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

Dreamweaver CS6
Visual web development tools

SublimeText3 Linux new version
SublimeText3 Linux latest version

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),
