Uber has scale, they are processing $15+ billion plus in rides a year. Millions of customers and millions of drivers that need tools built to service them.
Uber does almost 1 million rides per hour. About 100 million monthly active users are driven around 26 billion miles each year. Think about all these car locations, requests, passenger details, messages, prices, tips, customer support etc landing into their system every second. Think about price predictions that can be off by just few cents and could make a dent in your earnings or push customers to the competition. Add onto this reliability in at least 3 or 4 nines, latencies across the globe, security, fail-over, multi-platforms, privacy etc issues. Don't forget you need to operate in 700 cities worldwide with all kind of regulations, customizations and geographic/culture adaptation. Uber accomplishes 230,000 trips per employee and earns $500,000 per employee - which is on par with other tech companies. I think you will find that the scaling system without falling on your face every day, every hour is a pretty significant undertaking at this point.
Uber has always been kind of a head scratcher. Numbers vary but they do 20-30 million rides per day. Which sounds like a lot but is only 350 rides per second. It's kind of hard to figure out how you go from 350 customers/second to needing multiple data centers worth of servers.
lots of "uber scale" is self-induced over-engineering. I'm pretty sure for any enterprise piece of software that exists there is a parallel uber solution that does the same thing.
Given that their basic product is a smartphone app that connects car drivers and customers the size of the entire operation is quite ridiculous.
You should keep in mind that innovation exists in the context of the cost that is associated with it. Building giant software systems alone isn't enough.
I work for a company that does kinda similar software stuff for vehicles - Uber has about two orders of magnitude more drivers than my company, but about three orders of magnitude more engineers - it's almost like they've got diseconomies of scale.
It's not like you drive millions of miles without a small fleet of vehicle. Not only is that what they would do on large scale, it's what they already started to do on small scale.
Uber's a company whose current main product is software, that doesn't mean they can't branch out into new things and are forever tied to software. I'd also argue that Uber already has a lot more experience with working with a million different people than most other companies (currently drivers, in the future possibly mechanics, garage owners, etc).
Uber doesn't just make apps for phones.
They also have an entire self-driving car division (computer vision, etc), car routing, maps folks, payments, the separate driver apps, etc. A company that size and complexity has plenty of work for engineers.
Uber doesn’t make money. The bigger their enterprise is the less money they make. They should be firing anyone who says they need more complicated systems to scale when the idea could run on a PC under their desk.
To be fair to them, Uber is more than just a ride hailing service.
It's also a food buying marketplace with, a package, grocery and meal delivery service.
There's also their autonomous research division.
Plus even with just the ride hailing service, they have tons of things that require engineering like load balancing of their drivers to requests in an area, and predictions for pricing and route timing.
There's also the whole messaging component to it.
It's a lot more complex of a company than it appears on the surface.
A company with billions in revenue, live updates routing around traffic, has complex machine learning modes predicting ride times and costs, and operates in something like 65 countries.
Uber has always struck me as something of an engineer's sandbox. They hire too many engineers who build (and re-build) over-engineered solutions, and who are paid a lot. They have thousands of microservices for example.
Are you serious? With many 9s of uptime, low latency requirements and hundreds of millions of dollars in revenue on the line? Uber employs over 2k developers right now.
Despite popular belief, apps and communities don't run themselves. Uber is scaling at an ungodly speed, and they're hiring a ton of people to do so. Seriously, look at how many jobs they're hiring for right now: https://www.uber.com/jobs/list (then realize they're doing this in hundreds of cities simultaneously, in addition to the hundreds they're already in).
I'm actually blown away that they're losing so little, given the amount of revenue they're bringing in. Those are, despite what it may seem, really good numbers. If they can reach scale and capture the market (not trivial)... wow.
Uber operates in: ride sharing, food delivery, bike messenger, corporate travel, freight, helicopter, and gig economy jobs, and more - and these are just the publicly launched products. Each of those lines has its own external _and_ internal products, with their own features, and their own regulatory burden. They each have their own cost structure and incentive models. They're live in over 900 cities across 85 countries, many of which have their own local regulatory burden such as NYC.
Then, on top of that, you've got 91 million monthly active users. Assume each one takes only one ride per month, and only 1% of them have some kind of issue that requires them to reach out to support - that's still 30,000 new issues per day many of which will require coordinating between both parties involved in the transaction.
Do they have more employees than they need? Define need. It's easy to hire above what's necessary to sustain operations when the cost of capital is cheap. More people can develop new products and grow margins for the business overall. But Uber is seriously far from "an app together with some driver administration" any more than Amazon is "a website with some seller administration."
It surprises me that you think the tech aspect of Uber is the biggest. It's not; the biggest aspect of Uber is operations. For every city you have onboard, you need significant people on the ground that work on driver recruitment, dealing with local gov, training, driver support, local marketing. Some markets have their own apps (like Australia with its on driver-to-driver interim chat feature).
Uber's core business is a taxi app and I get that there are some clever algorithms involved, but I still don't really understand how they justify the size of their engineering team.
I read that they had 2,000 engineers out of 6,000 employees in 2016, though I don't know the numbers now. That seems gigantic.
Eh, they're solving different problems. I don't think you can necessarily call Uber's problem more complicated just because it's an order of magnitude more volume. I worked at a small ad tech start-up with a team of 5 engineers on a real-time bidding platform that was serving 1k requests/second and moved to a travel company that's now 100+ engineers that serves maybe ~250 requests/second at peak traffic, but the travel company's infrastructure is a lot more complicated even though the volume is smaller.
reply