search
HomeOperation and MaintenanceCentOSHow to build MongoDB cluster on CentOS

How to build MongoDB cluster on CentOS

Apr 14, 2025 pm 06:30 PM
centosmongodbtoolredigs

To build a MongoDB cluster on the CentOS system, you need to complete MongoDB installation, instance configuration, replica set settings, and sharding steps. The following steps will guide you through this process in detail:

1. Preparation

Make sure the CentOS system is updated and install the necessary tools:

 sudo yum update -y
sudo yum install -y wget vim

2. Install MongoDB

  1. Add MongoDB YUM source: Create a mongodb.repo file and add MongoDB repository information (please adjust the version number according to the actual situation):
 echo "[mongodb-org-4.4]
name=MongoDB Repository
baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/4.4/x86_64/
gpgcheck=1
enabled=1
gpgkey=https://www.mongodb.org/static/pgp/server-4.4.asc" | sudo tee /etc/yum.repos.d/mongodb-org-4.4.repo
  1. Install MongoDB: Use the YUM command to install MongoDB and its dependent components:
 sudo yum install -y mongodb-org

3. Configure MongoDB instance

In this example, we will build a cluster that contains a Config Server and multiple Shards.

  1. Config Server: Modify the /etc/mongod.conf file (please replace config_server_ip with the actual IP address):
 sudo vim /etc/mongod.conf

Add the following configuration:

 <code>storage: dbPath: /var/lib/mongo/configdb systemLog: destination: file path: /var/log/mongodb/configdb.log logAppend: true net: bindIp: 0.0.0.0 port: 27019 sharding: clusterRole: configsvr</code>

Create a database directory and start the Config Server service:

 sudo mkdir -p /var/lib/mongo/configdb
sudo chown mongod:mongod /var/lib/mongo/configdb
sudo systemctl start mongod
sudo systemctl enable mongod
  1. Configure Shard: Configure a separate MongoDB instance for each Shard server. Modify the /etc/mongod.conf file (please replace shard_1_ip as the actual IP address, and create the corresponding directory and configuration file for each shard, such as /var/lib/mongo/shard_2 , /var/lib/mongo/shard_3 , etc.):
 sudo vim /etc/mongod.conf

Add the following configuration (example is shard_1):

 <code>storage: dbPath: /var/lib/mongo/shard_1 systemLog: destination: file path: /var/log/mongodb/shard_1.log logAppend: true net: bindIp: 0.0.0.0 port: 27018 sharding: clusterRole: shardsvr</code>

Create a database directory and start the Shard service:

 sudo mkdir -p /var/lib/mongo/shard_1
sudo chown mongod:mongod /var/lib/mongo/shard_1
sudo systemctl start mongod
sudo systemctl enable mongod

Repeat the above steps to configure multiple shards (such as shard_2, shard_3, etc.).

4. Configure Mongos router

  1. Install Mongos: (If not installed, please use sudo yum install -y mongodb-org-mongos to install)

  2. Configure /etc/mongos.conf : (Please replace config_server_ip as the IP address of Config Server, mongos_ip as the IP address of Mongos server):

 sudo vim /etc/mongos.conf

Add the following configuration:

 <code>sharding: configDB: config_server_ip:27019 net: bindIp: 0.0.0.0 port: 27017</code>
  1. Start Mongos service:
 sudo mongos --config /etc/mongos.conf

5. Add Shard to the cluster

Connect to Mongos server:

 mongo --host mongos_ip:27017

Then execute the following command to add Shard (please replace it with the actual shard IP address and port):

 sh.addShard("shard_1_ip:27018")
sh.addShard("shard_2_ip:27018")
sh.addShard("shard_3_ip:27018")

6. Monitoring and management

Use sh.status() command to view the cluster status:

 sh.status()

Through the above steps, you can build a MongoDB cluster on the CentOS system. Remember to replace the IP address and port number in the example for your actual server information. In addition, to ensure high availability, it is recommended that you further configure the replica set.

The above is the detailed content of How to build MongoDB cluster on CentOS. For more information, please follow other related articles on the PHP Chinese website!

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
CentOS's Purpose: Building Robust and Reliable ServersCentOS's Purpose: Building Robust and Reliable ServersMay 11, 2025 am 12:18 AM

CentOS is suitable for building powerful and reliable servers. Its advantages include: 1. Stability and reliability, support cycle up to 10 years; 2. Security, built-in SELinux and regular security patches; 3. Compatibility and ecosystem, highly compatible with RHEL, with a rich software warehouse; 4. Performance optimization, suitable for various hardware platforms and providing kernel tuning.

The Future of CentOS: Transitioning to New DistributionsThe Future of CentOS: Transitioning to New DistributionsMay 10, 2025 am 12:19 AM

CentOS will continue to evolve in the future, and users should choose alternative distributions. 1) Evaluate the requirements, choose such as RockyLinux or AlmaLinux, and focus on stability and support. 2) Develop a migration plan, use tools such as CentOS2Rocky, and pay attention to testing and verification. 3) Plan early, maintain contact with the open source community, and ensure a smooth transition.

CentOS: The Choice for Server EnvironmentsCentOS: The Choice for Server EnvironmentsMay 09, 2025 am 12:21 AM

CentOS is widely selected as a server operating system because it is stable, secure and free. 1.CentOS is based on RHEL, providing enterprise-level stability and a life cycle of up to 10 years. 2. It has rich software packages and strong community support. 3. Simple installation, use yum management software package, and intuitive configuration. 4. Improve server management efficiency through command line tools, regular backups and log management. 5. Optimize server performance by adjusting kernel and network parameters.

The Future of CentOS: What's Next?The Future of CentOS: What's Next?May 08, 2025 am 12:01 AM

CentOS will continue to develop through CentOSStream in the future. CentOSStream is no longer a direct clone of RHEL, but is part of RHEL development. Users can experience the new RHEL functions in advance and participate in development.

CentOS: From Development to Production EnvironmentsCentOS: From Development to Production EnvironmentsMay 07, 2025 am 12:08 AM

The transition from development to production in CentOS can be achieved through the following steps: 1. Ensure the consistent development and production environment, use the YUM package management system; 2. Use Git for version control; 3. Use Ansible and other tools to automatically deploy; 4. Use Docker for environmental isolation. Through these methods, CentOS provides powerful support from development to production, ensuring the stable operation of applications in different environments.

CentOS Stream: The Successor and its ImplicationsCentOS Stream: The Successor and its ImplicationsMay 06, 2025 am 12:02 AM

CentOSStream is a cutting-edge version of RHEL, providing an open platform for users to experience the new RHEL functions in advance. 1.CentOSStream is the upstream development and testing environment of RHEL, connecting RHEL and Fedora. 2. Through rolling releases, users can continuously receive updates, but they need to pay attention to stability. 3. The basic usage is similar to traditional CentOS and needs to be updated frequently; advanced usage can be used to develop new functions. 4. Frequently asked questions include package compatibility and configuration file changes, and requires debugging using dnf and diff. 5. Performance optimization suggestions include regular cleaning of the system, optimizing update policies and monitoring system performance.

CentOS: Examining the Reasons Behind the End of LifeCentOS: Examining the Reasons Behind the End of LifeMay 04, 2025 am 12:12 AM

The reason for the end of CentOS is RedHat's business strategy adjustment, community-business balance and market competition. Specifically manifested as: 1. RedHat accelerates the RHEL development cycle through CentOSStream and attracts more users to participate in the RHEL ecosystem. 2. RedHat needs to find a balance between supporting open source communities and promoting commercial products, and CentOSStream can better convert community contributions into RHEL improvements. 3. Faced with fierce competition in the Linux market, RedHat needs new strategies to maintain its leading position in the enterprise-level market.

The Reasons for CentOS's Shutdown: A Detailed AnalysisThe Reasons for CentOS's Shutdown: A Detailed AnalysisMay 03, 2025 am 12:05 AM

RedHat shut down CentOS8.x and launches CentOSStream because it hopes to provide a platform closer to the RHEL development cycle through the latter. 1. CentOSStream, as the upstream development platform of RHEL, adopts a rolling release mode. 2. This transformation aims to enable the community to get exposure to new RHEL features earlier and provide feedback to accelerate the RHEL development cycle. 3. Users need to adapt to changing systems and reevaluate system requirements and migration strategies.

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

SublimeText3 English version

SublimeText3 English version

Recommended: Win version, supports code prompts!

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Powerful PHP integrated development environment

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor