Questo contenuto non è disponibile nella lingua selezionata.
8.4.3. MongoDB
		Use replica sets to achieve redundancy with MongoDB. See the following documents on the MongoDB website for more background information: 
		
	
- Replication - http://docs.mongodb.org/manual/replication/
- Convert a Standalone to a Replica Set - http://docs.mongodb.org/manual/tutorial/convert-standalone-to-replica-set/
		The following instructions describe how to create a replica set with the MongoDB package included with OpenShift Enterprise.
	
Procedure 8.10. To Install MongoDB on Each Host:
- On a minimum of three hosts, install MongoDB and turn on the MongoDB service to make it persistent:yum install -y mongodb-server mongodb chkconfig mongod on # yum install -y mongodb-server mongodb # chkconfig mongod onCopy to Clipboard Copied! Toggle word wrap Toggle overflow 
- If you choose to install MongoDB using the basic install script provided, you must also delete the initial data from all but one installation to make it a part of the replica set. Stop the MongoDB service and delete the data using:service mongod stop rm -rf /var/lib/mongodb/* # service mongod stop # rm -rf /var/lib/mongodb/*Copy to Clipboard Copied! Toggle word wrap Toggle overflow 
Procedure 8.11. To Configure the MongoDB Service on Each Host:
- Edit the/etc/mongodb.conffile and modify or add the following information:Copy to Clipboard Copied! Toggle word wrap Toggle overflow The following table provides a brief description of each setting from the example above.Expand Table 8.1. Descriptions of /etc/mongodb.conf Settings Setting Description bind_ip This specifies the IP address MongoDB listens on for connections. Although the value must be an external address to form a replica set, this procedure also requires it to be reachable on the localhostinterface. Specifying0.0.0.0binds to both.auth This enables the MongoDB authentication system, which requires a login to access databases or other information. rest This enables the simple REST API used by the replica set creation process. replSet This names a replica set, and must be consistent among all the members for replication to take place. keyFile This specifies the shared authentication key for the replica set, which is created in the next step. journal This enables writes to be journaled, which enables faster recoveries from crashes. smallfiles This reduces the initial size of data files, limits the files to 512MB, and reduces the size of the journal from 1GB to 128MB. 
- Create the shared key file with a secret value to synchronize the replica set. For security purposes, create a randomized value, and then copy it to all of the members of the replica set. Verify that the permissions are set correctly:echo "sharedkey" > /etc/mongodb.keyfile chown mongodb.mongodb /etc/mongodb.keyfile chmod 400 /etc/mongodb.keyfile # echo "sharedkey" > /etc/mongodb.keyfile # chown mongodb.mongodb /etc/mongodb.keyfile # chmod 400 /etc/mongodb.keyfileCopy to Clipboard Copied! Toggle word wrap Toggle overflow 
- Configure the firewall to allow MongoDB traffic on each host using thelokkitcommand:lokkit --port=27017:tcp # lokkit --port=27017:tcpCopy to Clipboard Copied! Toggle word wrap Toggle overflow Red Hat Enterprise Linux provides different methods for configuring firewall ports. Alternatively, useiptablesdirectly to configure firewall ports.
- Start the MongoDB service on each host:service mongod start # service mongod startCopy to Clipboard Copied! Toggle word wrap Toggle overflow 
Note
			If you use the kickstart or bash script, the 
configure_datastore_add_replicants function performs the steps in the previous two procedures.
		
		After all hosts to be included in the replica set are configured and started, use the MongoDB shell to connect to the primary instance and define the replica set. Although you might have already added data to the primary instance, other instances must be empty.
	
Procedure 8.12. To Form a Replica Set:
- Authenticate to theadmindatabase and initiate theosereplica set:Copy to Clipboard Copied! Toggle word wrap Toggle overflow 
- Wait a few moments then press Enter until you see theose:PRIMARYprompt. Then add new members to the replica set:ose:PRIMARY> rs.add("mongo2.example.com:27017") { "ok" : 1 }ose:PRIMARY> rs.add("mongo2.example.com:27017") { "ok" : 1 }Copy to Clipboard Copied! Toggle word wrap Toggle overflow Repeat as required for all datastore hosts, using the FQDN or any resolvable name for each host.
- Verify the replica set members:Copy to Clipboard Copied! Toggle word wrap Toggle overflow 
		Update all broker hosts to use the new replica set.
	
Procedure 8.13. To Configure the Broker Application to Use a Replica Set:
- If you have not configured a MongoDB user namedopenshiftto allow access to the broker host before forming the replica set as described in Chapter 7, Manually Installing and Configuring a Broker Host, add it now. Database changes at this point are synchronized among all members of the replica set.
- Edit the/etc/openshift/broker.conffile on all broker hosts and setMONGO_HOST_PORTto the appropriate replica set members:Copy to Clipboard Copied! Toggle word wrap Toggle overflow