The simple answer is to use multiple droplets.
The longer answer is, it depends - there are lots of approaches to this. We can get pretty far down the DevOps rabbit hole on this question. (And apologies if I’m explaining some things you already know.)
You’ll want to isolate your applications from each other as much as possible, but there are many ways of doing this. That article mentions Python’s
virtualenv tool, which isolates Python’s library directories per application, but your application could still write over some file another application was using, etc. Multiple applications could live side by side without problems, but the trend in server application development these days is to isolate them so you don’t have to take that chance.
So, multiple droplets is one way of doing this. In that case, I would recommend looking into tools like Ansible (or Chef, or Puppet, etc..) to allow you to set up a machine the same way every time with just what that application needs.
Another way of isolating applications is running them in Docker containers - which you can think of like little application-focused virtual machines running along side each other on your droplet.
Both of these approaches require learning a bit of tooling, and some processes to get them right for production-level deployments, and each have their pros and cons. If you’re a beginner, working on applications that aren’t going to be large-scale deployments - I’d say that you’ll probably be fine with whatever you choose. But the more isolation you can get (with either approach), the less headaches you’ll have down the road.