You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

82 lines
5.2 KiB
Plaintext

This file contains invisible Unicode characters!

This file contains invisible Unicode characters that may be processed differently from what appears below. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to reveal hidden characters.

00:01 Are you taking this class using your Linux desktop?
00:03 Well, let's get your machine all set up and configured with MongoDb.
00:07 So here we are just on the homepage mongodb.com,
00:10 I am going to go click download, and it's totally possible to click and say
00:16 download the tarball, but we could also say I would like to see
00:19 how to set this up on let's say Ubuntu, as you change this,
00:23 notice different things happen, so if we go to Amazon
00:27 it says here are instructions for installing with yum, that's the package manager there,
00:31 if I go to Ubuntu, so here's the instructions for installing with aptitude,
00:34 so we're going to go over here to that one,
00:36 make sure you pick the right distribution, do we want to read this— no.
00:40 So there's a couple of steps that we need to go through
00:43 and they're pretty simple, most importantly they just like walk us through it
00:47 so notice here that there is a package named mongodb.org
00:52 let's try to just install that, sudo apt install that,
01:00 oh it needs my password, okay, and nope, there's no mongodb,
01:05 darn, doesn't it say right here, here's how you install all the pieces?
01:08 It is true, but we got to go through a few steps to get there.
01:11 So first thing that we got to do is basically add a source to aptitude,
01:16 so we're going to go over here, and we're going to set a key,
01:19 so you're just going to go through a few copy paste steps,
01:21 so we're going to do our apt key here, it takes a moment,
01:26 and all right, that's all good, next thing to do
01:28 is we're going to create a list file, all right, great.
01:34 Be really careful about the version numbers here,
01:38 later is probably better, pick the one that matches yours.
01:40 So the next thing we need to do, is run a sudo apt update
01:44 and you can do apt.get or just apt, whatever
01:47 but you need to tell it hey, go pull all the sources
01:50 now the new one included and just have that list there.
01:53 We don't need to back up anything, so go away.
01:58 Alright, now everything is registered, we're pointing at the right package source,
02:02 we've updated it, now we can go over here and do
02:05 our thing that we tried to do originally.
02:08 So we wanted a sudo apt installed mongodb.org,
02:14 this time it knows what that means, hey look that's mongodb,
02:18 mongos which is a sharding server, mongo server, mongo shell, mongo tools,
02:22 I am just going to install them all.
02:25
02:29 Perfect, okay, so we have MongoDB all set up and ready to go,
02:35 and now we can just type mongo, and it tries to connect,
02:40 we have mongo now but we really need to start it.
02:44
02:51 So we started up mongod, great, now we can connect to it.
02:56 Awesome so it has some warnings again about access control
02:59 when we get to the deployment chapter,
03:02 we're actually going to set up Ubuntu as a cloud server
03:05 with some of these errors removed,
03:07 we're going to set it up with access control, with authentication,
03:10 with firewalls, all sorts of things, but for now, for the dev version,
03:13 we're going to just use this, okay.
03:16 So it looks like it's up and running, that's cool,
03:19 now the last thing is maybe we want to configure our server;
03:22 so, we can come over here to /etc/mongod/conf
03:30 and you can see we've got our storage path,
03:33 like here's where our data files are going to go, change that if you like,
03:36 journaling, you generally want that on,
03:38 it's going to be running with wired tiger,
03:41 it is an older style of database storage engine called this mmapv1,
03:45 that's how things used to work, they've switched the default to wired tiger
03:49 because it's faster, I believe it's much faster for inserts a little faster for reads,
03:53 here's where the log file goes, if it's not working and you want to see what's going on.
03:58 So most importantly though is this bit right there, this bindIp.
04:02 So the bindIp is set to 127.0.0.1, we should have our firewall turned on anyway,
04:08 we shouldn't be exposing this port, but we're only listening on the local host,
04:13 I think this machine actually right now has two ip adresses,
04:16 one public ipv6 and one net ipv4 ip address,
04:21 but it's not listening on either of them because of this, right.
04:24 So it's super important that this is here,
04:27 otherwise if someone can get to this port on your machine
04:30 and you don't set up authentication, bad things happen.
04:33 All right, so make sure this is here,
04:36 and only change that on your staging servers
04:38 and other things where you control the network, much more carefully.
04:41 Again, we'll talk way more about this in the deployment section
04:44 but for now, this should do for our development environment.
04:47 The other things we'll have to do is we want to set up a RoboMongo,
04:50 we want to set up PyCharm, and we want to make sure
04:54 that we have Python 3 on here, I believe we do, 3.5.3 is more than late enough,
05:00 so we don't need to install any Python,
05:02 but be sure to get RoboMongo and PyCharm,
05:05 whichever version you want set up so that you can follow along.