<rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>Hacker News: nbm</title><link>https://news.ycombinator.com/user?id=nbm</link><description>Hacker News RSS</description><docs>https://hnrss.org/</docs><generator>hnrss v2.1.1</generator><lastBuildDate>Wed, 13 May 2026 17:18:09 +0000</lastBuildDate><atom:link href="https://hnrss.org/user?id=nbm" rel="self" type="application/rss+xml"></atom:link><item><title><![CDATA[New comment by nbm in "Eden"]]></title><description><![CDATA[
<p>One thing to keep in mind for how development at larger tech companies works is that you’re often not building on your own desktop, you’re usually building on a development server that’s on a well-connected (effectively production-quality, if not literally the same) network.  You don’t see a ton of drops in those cases, so it works well.  Not that there hasn’t been effort to recover from networking issues encountered in this and other build tooling - at scale, someone’s development server is going to have a bad day every day.<p>You also need much better tools than grep and locate for a monorepo - or any sufficiently large repo probably.  Just load the full repo into memory in a few places around the world, and use an API to find the text you’re looking for.  If you already have expertise with search services in your company, this is not that challenging a step - and you can get fancy by using something like Tree-sitter to make those searches more advanced than text.  Hitting disk (especially for whole directory trees for “grep -r”) is a losing approach in a large repo.</p>
]]></description><pubDate>Wed, 13 Apr 2022 01:33:45 +0000</pubDate><link>https://news.ycombinator.com/item?id=31010268</link><dc:creator>nbm</dc:creator><comments>https://news.ycombinator.com/item?id=31010268</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=31010268</guid></item><item><title><![CDATA[New comment by nbm in "Ask HN: How to convince big tech team that tests and code quality matter?"]]></title><description><![CDATA[
<p>Since you mention a big tech company, what you’ll probably find is that there are people that care about these things around you, and they’re probably doing what they can and could do with support - not necessarily to do work, but also just moral support.  (I like to pretend I’m one of those people in the quality space in my area in my big tech company…)<p>As others mention, be careful trying to change the world (and especially saying bad things about what you see) before you grow your credibility.  But ask a few questions in team meetings (or, at something like FB, in workplace groups) about what test or staging or related infrastructure is available as part of ramping up, and that might get people that care to notice you’re a potential ally.<p>There’s even the (admittedly probably very) small chance that that the team wants to improve here, and doesn’t know how/didn’t have the resources to do better before - either way, you’ll learn more without alienating anyone.<p>Big tech companies also often offer mobility and culture variety, so keep your eye out for teams that align with what you care about.  Learn what they do and how they got started at least - or possibly move there.<p>(If you’re at FB, feel free to reach out to me - same account name.)</p>
]]></description><pubDate>Tue, 07 Dec 2021 06:33:06 +0000</pubDate><link>https://news.ycombinator.com/item?id=29469608</link><dc:creator>nbm</dc:creator><comments>https://news.ycombinator.com/item?id=29469608</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=29469608</guid></item><item><title><![CDATA[New comment by nbm in "More details about the October 4 outage"]]></title><description><![CDATA[
<p>Perhaps the right word is “system” - the combination of software (DNS protocol server software, health checker, BGP agent, and so forth) involved in making the DNS service available (or not, in this case).  These could be running on the same computer, or separate ones if you are particularly imaginative.<p>Unfortunately, “DNS system” means something very different than if you said “load balancing system”, so “server” is simpler.<p>(Usual disclaimer: work at FB, even on this exact stuff, but not representing it.)</p>
]]></description><pubDate>Wed, 06 Oct 2021 02:11:47 +0000</pubDate><link>https://news.ycombinator.com/item?id=28768394</link><dc:creator>nbm</dc:creator><comments>https://news.ycombinator.com/item?id=28768394</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=28768394</guid></item><item><title><![CDATA[New comment by nbm in "Big company tale: six months for a list and a button"]]></title><description><![CDATA[
<p>Stories (which is the medium used) about how things went right without effort are boring.  Which leaves two stories - things that went right that had a lot of effort, and things that went wrong.<p>In the case of things going right with a lot of effort, there’s the case where things went right because of that effort.  If you write stories about those, you can be accused of being self-aggrandizing - but they do give people practical options to consider in similar situations.<p>In the case of things going wrong, there’s the case where you tried to correct things, but were not successful.  There’s value in exploring what you could do better - but that’s not a story.  The story is the people and archetypes and systems and so forth.  In that case, you can be accused of seeking to blame others.<p>The other stories could be where you did something wrong (but which at the time seemed like they were good and necessary), but despite that the outcome was successful, or because of that, the outcome was unsuccessful.  If you’ve read enough of the back catalog, these do exist.<p>I like that these are presented as stories, and that they are representative of situations people will recognize and also find themselves in.  If you’ve seen them, it’s validating that others perceive the challenges the same.  If you haven’t, you’re forewarned about things that may come up.</p>
]]></description><pubDate>Sun, 29 Aug 2021 18:40:55 +0000</pubDate><link>https://news.ycombinator.com/item?id=28349320</link><dc:creator>nbm</dc:creator><comments>https://news.ycombinator.com/item?id=28349320</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=28349320</guid></item><item><title><![CDATA[New comment by nbm in "Big company tale: six months for a list and a button"]]></title><description><![CDATA[
<p>Her stories gain a sharper edge if you’ve worked in similar sorts of environments before.<p>If you aren’t aware of how there are teams trying to “own” turf, and prevent alternatives (even one-offs), and also how the entire company tries to funnel anything that matches a keyword to that team, even when it is the most tentative match, then you aren’t aware of the challenges faced to navigate them.<p>You see one path (going with the flow), but don’t see what happens when you don’t follow it.<p>Not going with the flow is definitely valuable - it’s something any good senior person should have in their tool belt.  And if you read Rachel’s stories, there are many examples of not going with the flow (and comments in the HN posts about how she’d be more effective if she didn’t go against the flow).<p>The challenge is that you can’t always go against the flow either.  It’s celebrated if you cut through some red tape - but at some point you’ll just get a reputation of being contrary.  Even if you don’t, it’s tiring to have to be the one trying to course-correct the world.  Either way, you have to choose your battles.  And a button on a dashboard probably isn’t worth using your capital on…<p>There’s a degree to which you can just go out and talk to people and build relationships. You’d be mistaken if you think that developing these relationships (as well as a reputation for solving real problems, which puts you on the right foot with many strong engineers) is an avenue that wasn’t explored.</p>
]]></description><pubDate>Sun, 29 Aug 2021 18:10:37 +0000</pubDate><link>https://news.ycombinator.com/item?id=28349045</link><dc:creator>nbm</dc:creator><comments>https://news.ycombinator.com/item?id=28349045</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=28349045</guid></item><item><title><![CDATA[New comment by nbm in "Mental health impacts of a big tech job"]]></title><description><![CDATA[
<p>At FB, most ICs are not hired for a specific team in advance, and instead choose between (for SWE, a long list of) teams during the Bootcamp process.  You can chat to future team mates (not just manager or lead) and ask them straight out about that.  (Some people also ask for the half-ly survey results for that team as well.)<p>If you’re being hired for a team specifically (at another company, say), ask for a “follow-up” meeting with future team mates after offer as a condition for accept.  You have a lot of power at that point.</p>
]]></description><pubDate>Sat, 28 Aug 2021 05:24:45 +0000</pubDate><link>https://news.ycombinator.com/item?id=28335861</link><dc:creator>nbm</dc:creator><comments>https://news.ycombinator.com/item?id=28335861</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=28335861</guid></item><item><title><![CDATA[New comment by nbm in "How Facebook encodes videos"]]></title><description><![CDATA[
<p>Keep in mind that the referenced paper that this page is based on is over a decade old now.  Many things have changed since then, as you can imagine.  Look for later papers and engineering blog posts for more about what’s changed since then.</p>
]]></description><pubDate>Mon, 26 Apr 2021 04:23:47 +0000</pubDate><link>https://news.ycombinator.com/item?id=26939225</link><dc:creator>nbm</dc:creator><comments>https://news.ycombinator.com/item?id=26939225</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=26939225</guid></item><item><title><![CDATA[New comment by nbm in "Plain Text Protocols"]]></title><description><![CDATA[
<p>In some ways, HTTP 3 is the same HTTP messages, just over QUIC.<p>But as you get into other features, there are differences.  And your clients and servers need to both have fallbacks to HTTP 2, since UDP connectivity might not be available, and fallback is expected.<p>So, you have to build support for having working push, or not.  Or having working priorities, or not.  Or having long-lived non-HTTP sockets, or using fallbacks like web sockets or even long polling.  There’s even more fun on the horizon, and I’m not looking forward to my colleagues thinking of a fallback strategy for some of those...</p>
]]></description><pubDate>Fri, 26 Feb 2021 04:40:24 +0000</pubDate><link>https://news.ycombinator.com/item?id=26271415</link><dc:creator>nbm</dc:creator><comments>https://news.ycombinator.com/item?id=26271415</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=26271415</guid></item><item><title><![CDATA[New comment by nbm in "Plain Text Protocols"]]></title><description><![CDATA[
<p>The main benefit is multiplexing - being able to use the same connection for multiple transactions at the same time.  This can have benefits in finding and keeping the congestion window at its calculated maximum size, reduce connection-related start-up, as well as overcome waiting for a currently-used connection to be free if you have a max connection per server model.<p>The other potential benefits were priorities and server-initiated push, but both I’d say largely went unused and/or were too much trouble to use.  Priorities were redesigned in HTTP 3 - more at <a href="https://blog.cloudflare.com/adopting-a-new-approach-to-http-prioritization/" rel="nofollow">https://blog.cloudflare.com/adopting-a-new-approach-to-http-...</a> - and Chrome recently decided push in HTTP 2 wasn’t worth keeping around - <a href="https://www.ctrl.blog/entry/http2-push-chromium-deprecation.html" rel="nofollow">https://www.ctrl.blog/entry/http2-push-chromium-deprecation....</a><p>HTTP 2’s main problem is head-of-line blocking in TCP - basically, if you lose a packet, you wait until you get that packet and acknowledge a maximum amount of packets thereafter - slowing the connection down.  With multiplexing, this means that a bunch of in-flight transactions, as well as potentially future ones, are blocked at the same time.  With multiple TCP connections, you don’t have this problem of a dropped packet affecting multiple transactions.<p>HTTP 3 has many more benefits - basically, all the benefits of multiplexing without the head of line blocking (instead, only that stream is affected), as well as ability to negotiate alternative congestion control algorithms when client TCP stacks don’t support newer ones - or come with bad defaults.  And the future is bright for non-HTTP and non-reliable streams as well over QUIC, the transport HTTP 3 is built on.</p>
]]></description><pubDate>Thu, 25 Feb 2021 18:23:07 +0000</pubDate><link>https://news.ycombinator.com/item?id=26266193</link><dc:creator>nbm</dc:creator><comments>https://news.ycombinator.com/item?id=26266193</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=26266193</guid></item><item><title><![CDATA[New comment by nbm in "Power-of-2-Choices in Practice"]]></title><description><![CDATA[
<p>Even in the proxy case (which is my day job), it's often worth the price of the up-front load polling to have sufficiently recent information to take action on.  The most obvious cases are those where you have some (or all) requests being expensive, as opposed to thousands of exclusively tiny requests.<p>This does depend on having a local load balancing layer (not, say, making a choice between two servers that are each 50+ms away from the load balancer), and also having a high-performance RPC stack (C++ on both sides, and Thrift, in my case).</p>
]]></description><pubDate>Sat, 20 Feb 2021 02:25:50 +0000</pubDate><link>https://news.ycombinator.com/item?id=26200897</link><dc:creator>nbm</dc:creator><comments>https://news.ycombinator.com/item?id=26200897</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=26200897</guid></item><item><title><![CDATA[New comment by nbm in "Power-of-2-Choices in Practice"]]></title><description><![CDATA[
<p>In the two cases mentioned, there isn't any extra _response_ time.<p>> servers cannot periodically advertise their load measures to clients<p>This is an asynchronous mechanism - you can use polling, push, or queue, or whatever.  Individual responses don't pay the cost.<p>> staple current load reports to query responses, which the client can cache and use for a period of time<p>This is just a few extra bytes in the response, which likely has negligible cost.  One can fairly reasonably say that responses don't pay any cost.<p>Obviously there are other costs - it just depends on what you're trading off between on whether it is the right decision.</p>
]]></description><pubDate>Fri, 19 Feb 2021 02:22:09 +0000</pubDate><link>https://news.ycombinator.com/item?id=26188770</link><dc:creator>nbm</dc:creator><comments>https://news.ycombinator.com/item?id=26188770</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=26188770</guid></item><item><title><![CDATA[New comment by nbm in "Power-of-2-Choices in Practice"]]></title><description><![CDATA[
<p>It comes from the paper "The Power of Two Random Choices: A Survey of Techniques and Results" - <a href="http://www.eecs.harvard.edu/~michaelm/postscripts/handbook2001.pdf" rel="nofollow">http://www.eecs.harvard.edu/~michaelm/postscripts/handbook20...</a></p>
]]></description><pubDate>Thu, 18 Feb 2021 23:42:03 +0000</pubDate><link>https://news.ycombinator.com/item?id=26187434</link><dc:creator>nbm</dc:creator><comments>https://news.ycombinator.com/item?id=26187434</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=26187434</guid></item><item><title><![CDATA[New comment by nbm in "Amazon, Apple and Google Cut Off Parler"]]></title><description><![CDATA[
<p>> Why did Twitter allow “Hang Mike Pence” to trend last night?<p>I happened to look at that trend.  Nobody that I saw were actually suggesting people do it - they were quoting (or referring to) what was being said by those at the Capitol, and then commenting on it.<p>I don’t see a double standard for those cases, although they did subsequently remove it the trend.  Possibly because some people might have been calling for it in the “latest” tab - not a fun place looking at tweets outside the featured tab...</p>
]]></description><pubDate>Sun, 10 Jan 2021 09:47:57 +0000</pubDate><link>https://news.ycombinator.com/item?id=25712924</link><dc:creator>nbm</dc:creator><comments>https://news.ycombinator.com/item?id=25712924</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=25712924</guid></item><item><title><![CDATA[New comment by nbm in "Developer progression as a function of navigating complexity"]]></title><description><![CDATA[
<p>Your job title/level/rank (“Principal Engineer”, “IC6”, ...) is what you’ve been deemed capable of (usually by doing it).  But your role on a particular project is going to depend on what’s needed.  Sometimes you’ll be the lead of the whole thing.  Or the lead of a piece of it.  Or just another contributor.<p>Some performance management systems are poorly designed to handle scenarios like this, admittedly.</p>
]]></description><pubDate>Thu, 31 Dec 2020 04:19:17 +0000</pubDate><link>https://news.ycombinator.com/item?id=25589547</link><dc:creator>nbm</dc:creator><comments>https://news.ycombinator.com/item?id=25589547</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=25589547</guid></item><item><title><![CDATA[New comment by nbm in "MacKenzie Scott, ex-wife of Jeff Bezos, says she gave $4.2B to charity"]]></title><description><![CDATA[
<p>But it’s not actually factually true - it’s her money according to the laws and contracts in place.  If it were his money, he’d have it.  He doesn’t, so it isn’t “factually” his money.<p>It’s only “his money” in a non-factual basis where we are implying something akin to “he earned it and she didn’t”.</p>
]]></description><pubDate>Wed, 16 Dec 2020 05:21:48 +0000</pubDate><link>https://news.ycombinator.com/item?id=25439372</link><dc:creator>nbm</dc:creator><comments>https://news.ycombinator.com/item?id=25439372</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=25439372</guid></item><item><title><![CDATA[New comment by nbm in "MacKenzie Scott, ex-wife of Jeff Bezos, says she gave $4.2B to charity"]]></title><description><![CDATA[
<p>Besides the advice in the other replies about choosing good charities, it’s also useful to separate giving to charities (organizations that have non-trivial resources and focus dedicated to handling and seeking donations and often figuring out which other orgs to send that money to) vs. direct charitable giving to colleges, food banks, clinics, universities and other non-profits with a local scope (which many of those receiving donations here appear to be).<p>Certainly not a guarantee it’ll be used effectively, and that sort of outsourcing of deciding the best way to use money is part of the appeal of the larger charities.</p>
]]></description><pubDate>Wed, 16 Dec 2020 05:15:38 +0000</pubDate><link>https://news.ycombinator.com/item?id=25439335</link><dc:creator>nbm</dc:creator><comments>https://news.ycombinator.com/item?id=25439335</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=25439335</guid></item><item><title><![CDATA[New comment by nbm in "Pope endorses same sex civil unions"]]></title><description><![CDATA[
<p>In general, the two biggest financial benefits have to do with reduced health (and other) insurance rates, and not paying taxes on all or some of gifts, inheritance, or other wealth transfers between spouses (similar to those between parents and children).<p>The largest financial penalty in many countries is that spouses will pay more income-related taxes in dual-income families vs. if they were single, due to how progressive taxation bands are set up.<p>The benefits of government recognition for most people who marry aren’t financial - they’re to do with parental, health, estate, citizenship/immigration-related, and other rights that largely can’t fully be reliably created by contracts.</p>
]]></description><pubDate>Thu, 22 Oct 2020 02:26:51 +0000</pubDate><link>https://news.ycombinator.com/item?id=24854337</link><dc:creator>nbm</dc:creator><comments>https://news.ycombinator.com/item?id=24854337</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=24854337</guid></item><item><title><![CDATA[New comment by nbm in "The majority of Facebook's traffic now uses QUIC and HTTP/3"]]></title><description><![CDATA[
<p>TCP has an explicit client and server (some caveats here).  The userspace API for TCP requires you to do a connect, which does the TCP handshake in the TCP stack, before you can send traffic.<p>For UDP, you just specify the destination IP and port, and send packets.<p>For TCP, new incoming SYNs to most (S)NAT addresses will just get dropped - especially CGNAT - making it impossible to communicate in that direction.  If you're both in that situation (really common, actually), you just can't talk to each other.<p>For UDP, the packets will also get dropped on the receiver side.  However, the act of sending the packet will often cause the originator's side's NAT to  register that five-tuple (source and destination IP and port + UDP proto), which would allow the other side to reply.  If both sides do this with the same IP/port pairs, then magically they can communicate - some of the time, at least.  There's a lot more involved (for example, how do you know your own external IP address behind NAT?) - read up on STUN - <a href="https://en.wikipedia.org/wiki/STUN" rel="nofollow">https://en.wikipedia.org/wiki/STUN</a> - for more details.</p>
]]></description><pubDate>Wed, 21 Oct 2020 22:56:46 +0000</pubDate><link>https://news.ycombinator.com/item?id=24853182</link><dc:creator>nbm</dc:creator><comments>https://news.ycombinator.com/item?id=24853182</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=24853182</guid></item><item><title><![CDATA[New comment by nbm in "The majority of Facebook's traffic now uses QUIC and HTTP/3"]]></title><description><![CDATA[
<p>Pretty much any HTTP proxy supports talking a set of negotiated protocol versions/features with the client, and a potentially different set of protocol versions/features with the server behind it.<p>The high-level flow is pretty much:<p>1) Set up client connection/negotiate stuff (TLS, alpn, NPN, blah blah)
2) Process requests from that client connection
2.1) Decode request from client connection
2.2) Manipulate request (add/remove headers, ...)
2.3) Send request to server
2.3.1) If necessary, create a new connection to server (TLS, alpn, NPN, ...)
2.3.2) Encode request to server connection
2.4) Decode response from server connection
2.5) Manipulate response (add/remove headers, ...)
2.6) Encode response to client connection<p>You can talk totally different protocols from Internet-side client to the proxy, and from the proxy to the server - and multiple layers of proxies in between if you like.  From an app point of view, there's essentially no difference.  If you want to for some reason, you can use various headers to do attempt to indicate to the client to upgrade/downgrade to particular protocols, but most apps won't care about that.</p>
]]></description><pubDate>Wed, 21 Oct 2020 20:27:18 +0000</pubDate><link>https://news.ycombinator.com/item?id=24851778</link><dc:creator>nbm</dc:creator><comments>https://news.ycombinator.com/item?id=24851778</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=24851778</guid></item><item><title><![CDATA[New comment by nbm in "The majority of Facebook's traffic now uses QUIC and HTTP/3"]]></title><description><![CDATA[
<p>Yes.  The Internet-side client and the proxy server can use different protocols and versions that they can negotiate however they like, receive the HTTP request over those, and the proxy can use a separately-negotiated connection to your server to send that request over.<p>Essentially, the core of standard HTTP requests and responses (method, path, headers, response code) is fairly unchanged since HTTP/1.0, and what's changed is how those requests/responses are encoded and carried.</p>
]]></description><pubDate>Wed, 21 Oct 2020 19:06:03 +0000</pubDate><link>https://news.ycombinator.com/item?id=24850967</link><dc:creator>nbm</dc:creator><comments>https://news.ycombinator.com/item?id=24850967</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=24850967</guid></item></channel></rss>