MongoDB is a 2009-released NoSQL database that provides a flexible schema approach. It enables developers to rapidly construct applications and websites without spending much time setting a Database. It is fundamentally distinct from relational databases like Oracle, MySQL, and Microsoft SQL Server.
The term MongoDB is derived from “humongous,” which essentially translates to “huge.” MongoDB may also be used to store both structured and unstructured data. Numerous Professionals install MongoDB on Debian due to its adaptable and quick environment. MongoDB on Debian allows users to create scalable apps and utilize other Linux capabilities.
Most businesses favour Relational Database Management Systems (RDBMS) for storing and retrieving data. There are several benefits to using a DBMS. For instance, it provides enhanced Data Integration, transmission, and security options. It enables developers to generate rapid Database query solutions. If you’re looking for a solution to help standardize file usage, store data securely, and increase data accessibility, you’ve come to the right place.
Developers utilize MongoDB in Debian since it provides a vast array of tools via an open-source Linux interface. This post will explain how to install MongoDB Debian in easy stages and how to use MongoDB once the installation is complete.
Key features of MongoDB
MongoDB’s exceptional capabilities contribute to its widespread usability and popularity. Let’s examine the significant technological characteristics of MongoDB:
Indexing
Indexing is an essential component of a Database for enhancing search speed and query performance. Without indexing, a database would have to scan each page individually to determine which ones fit the query, which would be wasteful. However, the server can execute user requests rapidly if each query has an acceptable index. With MongoDB, any field or key in a document may be indexed, enabling complicated access patterns to datasets.
Facilitates Adhoc Queries
One of the most significant advantages distinguishing MongoDB is its efficiency while processing ad hoc queries on data that are typically updated in real-time. MongoDB supports field searches, range searches, and queries with regular expressions.
Schema-Less Database
Using a schema, traditional relational databases specify each functional element, including tables, rows, views, indexes, and relationships. In MongoDB, one collection keeps various documents. It has no schema. Therefore a collection may include many documents with separate keys, which may be unique. A schemaless database, such as MongoDB, is more flexible since it lacks these initial limitations and corresponds to a more “natural” database.
Click here to learn more about MongoDB.
Install MongoDB on Debian
Follow the steps provided herein to install MongoDB on Debian 11.
Step 1: Install the MongoDB Debian Dependencies
Install the MongoDB Debian requirements with the command below.
sudo apt-get install gnupg2 wget -y
data:image/s3,"s3://crabby-images/78c85/78c85357b9c7ee0424458424b9f790ef33397f0e" alt="install mongodb dependencies"
Install MongoDB dependencies
The MongoDB package is not included by default in the Debian repository. Therefore, you must add and install the official MongoDB repository for Debian to APT. Execute the following line of code in the terminal to include the official MongoDB repository.
wget -qO - https://www.mongodb.org/static/pgp/server-5.0.asc | sudo apt-key add - or echo "deb http://repo.mongodb.org/apt/debian buster/mongodb-org/5.0 main" | sudo tee /etc/apt/sources.list.d/mongodb-org-5.0.list
data:image/s3,"s3://crabby-images/f67a7/f67a7cbf98399a7d3aee1d975cc442f1bb058c02" alt="add mongodb repo"
Add MongoDB repo
Once you are done, update the repository cache with the following command:
sudo apt-get update -y
data:image/s3,"s3://crabby-images/5f5c1/5f5c1d59e94595cc2e74d1987c0a087eb2d293bf" alt="update repo caches"
Update repo caches
Step 2: Integrate the GPG key for MongoDB
To confirm that the packages we will obtain in order to install this database on Linux come from a legitimate source. Add the GPG key signed by the Database server’s developers.
Note: This step is optional
curl -sSL https://www.mongodb.org/static/pgp/server-5.0.asc -o mongoserver.asc gpg --no-default-keyring --keyring ./mongo_key_temp.gpg --import ./mongoserver.asc gpg --no-default-keyring --keyring ./mongo_key_temp.gpg --export > ./mongoserver_key.gpg sudo mv mongoserver_key.gpg /etc/apt/trusted.gpg.d/
data:image/s3,"s3://crabby-images/9e8c9/9e8c9d99bc1ab67dea77df1d7ff8803773c7ceff" alt="intergrate gpg key"
Intergrate GPG Key
Step 3: Run system update
On your Debian 11 terminal, execute a system update to ensure that all existing packages are up-to-date.
sudo apt update
data:image/s3,"s3://crabby-images/ca008/ca008d75e2d7fdf5ef6771d1d50c098bc6df8ef1" alt="update resources"
Update resources
Step 4: Install MongoDB on Debian11 Bullseye
That is all. We have already established the prerequisites for installing “database-tools, mongosh, additional tools, mongos; database server and shell” on Debian 11 bullseye
Hence, perform a simple command:
sudo apt install mongodb-org or sudo apt-get install mongodb-org -y
data:image/s3,"s3://crabby-images/02ddd/02dddb6a762542130267f53bf58e8aec542e5b64" alt="install mongodb"
Install MongoDB
After successfully installing the MongoDB Debian package, verify the MongoDB version using the command below.
mongod --version
data:image/s3,"s3://crabby-images/6e1b5/6e1b5435e9286a08d1fef24b2a4f19d2ba959ec0" alt="mongodb version"
MOngoDB version
Step 5: Enable and start the MongoDB service
Enable and start the Database server service after the installation is complete so that we do not need to run it every time the system boots.
sudo systemctl enable --now mongod
data:image/s3,"s3://crabby-images/196a4/196a4c9f948941e39176a720621f683612571a04" alt="enable mongodb"
Enable MongoDB
Proceed and check the MongoDB status by executing the command below:
sudo systemctl status mongod
data:image/s3,"s3://crabby-images/2c7a9/2c7a98f87e4fc199664fafc700846fa05e72e287" alt="check mongodb status"
Check MongoDB status
Step 6: Configure MongoDB
MongoDB is set by default to allow access without a password. It is always suggested to protect MongoDB using a username and password for security purposes.
To enable MongoDB authentication, you must modify the MongoDB configuration file:
sudo nano /etc/mongod.conf
Append the following lines to the mongod.conf file:
security: authorization: enabled
data:image/s3,"s3://crabby-images/3a9d3/3a9d39e0a92e35e003b5026f158b70459dfb732f" alt="mongodb authorization file"
MongoDB authorization file
After executing the file, save and close it, then restart the MongoDB service to effect the modifications.
systemctl restart mongod
data:image/s3,"s3://crabby-images/c14f5/c14f5edd83aae924c73d756c040bf00cb35dbd50" alt="restart mongodb"
Restart MongoDB
Next, you must create an admin user to complete the administrative operation. First, connect to the MongoDB using the command below:
mongo
data:image/s3,"s3://crabby-images/7f1be/7f1be3d1bbbe0d049876adaf3d1737fe79ac5023" alt="connect to mongo"
Connect to mongo
Once connected, use the following command to establish an admin Database:
use admin
data:image/s3,"s3://crabby-images/9cad3/9cad30713abacd4ff342c5f7cf52b191bb231839" alt="use admin"
Use admin
Next, establish an administrator account and set the password using the command:
> db.createUser( { user: "fosslinux", pwd: "fosslinux123", roles: [ { role: "userAdminAnyDatabase", db: "admin" } ] } )
data:image/s3,"s3://crabby-images/40f0b/40f0b3f881ad143ccae61e1cd33d1be79e8241d5" alt="create admin user"
Create admin user
Next, terminate the MongoDB shell with the following command:
quit()
data:image/s3,"s3://crabby-images/1031c/1031cd7c4b90fca00bc102172e5afda9e2134fef" alt="quit mongo server"
Quit mongo server
Step 7: How to alter MongoDB Debian default path?
The primary location for storing MongoDB data is /var/lib/mongo. However, this directory can be modified in the following manner:
- Stopping the MongoDB service is required.
sudo systemctl stop mongod.service
data:image/s3,"s3://crabby-images/598d9/598d946d7f8ca2ade7019c101cd3fa1a232e1f78" alt="stop mongodb"
Stop MongoDB
- Create a new MongoDB data directory.
mkdir fosslinux
data:image/s3,"s3://crabby-images/55302/5530274aec07e385c4f1cb11d29c3d9701adcf66" alt="create fosslinux directory"
Create fosslinux directory
- Set the directory’s ownership to MongoDB.
sudo chown -R mongodb:mongodb fosslinux
data:image/s3,"s3://crabby-images/df2d3/df2d317e415bc405043fdffdc47934c25d89afdd" alt="set directory ownership"
Set directory ownership
- Replace the previous directory with the current one. To install Rsync, do sudo apt install rsync.
sudo rsync -av /var/lib/mongodb fosslinux
data:image/s3,"s3://crabby-images/67321/673219f7b882c6e3508686f82c114a185ada5f35" alt="replace previous directory with current one"
Replace previous directory with current one
- Rename the previous backup directory.
sudo mv /var/lib/mongodb /var/lib/mongodb.bak
data:image/s3,"s3://crabby-images/d1cef/d1cef52314b94db90e8ba6626caa174839172a29" alt="rename previous directory"
Rename previous directory
- Establish a symbolic link to the new location.
sudo ln -s fosslinux /var/lib/mongodb
data:image/s3,"s3://crabby-images/13b66/13b66c58e991d9b8b45d014cff6fde82220803c2" alt="create a symbolic link"
Create a symbolic link
- After making these adjustments, restart the MongoDB service. MongoDB will immediately begin saving its data in the newly-created directory.
sudo systemctl start mongod.service
data:image/s3,"s3://crabby-images/45f48/45f48fae69119caee74bf77a75e6a14d57e8331e" alt="restart mongodb"
Restart MongoDB
Step 8: Enable Remote Connections
To allow distant connections, you must change the same file and add your private or internal IP address to the network interfaces. Your settings should be like the one seen below.
sudo nano /etc/mongod.conf
net: port: 27017 bindIp: 127.0.0.1,10.128.10.1
data:image/s3,"s3://crabby-images/a538f/a538f704c39dd9ed3a02c18f374b3e4693e9df72" alt="enable remote connections"
Enable remote connections
Replace the IP address (10.128.10.1) with your own IP address.
If a firewall exists, open port 27017.
Start MongoDB again.
sudo systemctl restart mongod
data:image/s3,"s3://crabby-images/6532e/6532ee039a98c90017404b9f02cad550b9652068" alt="restart mongodb service"
Restart MongoDB service
Verify whether MongoDB permits remote connections with the following command.
sudo lsof -i | grep mongo
data:image/s3,"s3://crabby-images/c12ed/c12ed63ead338ab2ccdf64553a9c540c7ccba3d0" alt="verify mongodb remote connection"
Verify MongoDB remote connection
How to uninstall or remove MongoDB on Debian 11
Those who are no longer interested in MongoDB and have no need for it can delete it using the command below:
sudo apt remove mongodb-org
Conclusion
MongoDB is a document-oriented db that gathers and stores data in compressed BSON files. Depending on their needs, developers may extract the gathered documents and information in JSON format. In addition, installing MongoDB Debian facilitates the development of applications with rapid performance because of its scalability features and customizable document schemas. You have learnt how to install, authenticate, and use databases within MongoDB in Debian. Let us know how you found this article guide. Thanks for reading this article guide, and keep following FOSSLinux for more in-depth Linux guides.